3 # It returns 1 in case of errors, and no tests should be run then!
5 # Ensure we have our mocked out AUTOENV_AUTH_FILE
8 # Treat unset variables as errors.
9 # Not handled in varstash yet.
12 export AUTOENV_AUTH_FILE="$CRAMTMP/autoenv/.autoenv_auth"
14 # Abort this setup script on any error.
15 _save_errexit=${options[errexit]}
18 # Can be defined in .zshenv, e.g. tests/ZDOTDIR.loadviafunction/.zshenv.
19 if [[ -z $TEST_SOURCE_AUTOENV ]]; then
20 TEST_SOURCE_AUTOENV=(source $TESTDIR/../autoenv.plugin.zsh)
24 # Reset any authentication.
25 if [[ -f $AUTOENV_AUTH_FILE ]]; then
26 echo -n >| $AUTOENV_AUTH_FILE
29 # Add file ($1), version ($2), and optional hash ($3) to authentication file.
30 test_autoenv_add_to_env() {
31 [[ -d ${AUTOENV_AUTH_FILE:h} ]] || mkdir -p ${AUTOENV_AUTH_FILE:h}
32 _autoenv_deauthorize $1
35 _autoenv_hash_pair $1 2 ${2:-} && echo $ret_pair
36 } >>| $AUTOENV_AUTH_FILE
39 # Add enter and leave env files to authentication file.
40 test_autoenv_auth_env_files() {
42 test_autoenv_add_to_env $dir/$AUTOENV_FILE_ENTER
43 test_autoenv_add_to_env $dir/$AUTOENV_FILE_LEAVE
46 # Now keep on going on errors again.
47 options[errexit]=$_save_errexit