X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=cgi-auth-flexible.git;a=blobdiff_plain;f=tests%2Fautotest;h=1cea707f8df1a4263a988a6196659c0acd8f6cee;hp=2561f5667fb24e268f2a344baf996d633477a943;hb=829bdfa8f56bef52b9eb22d9e4753463cd945dd0;hpb=f23f69e812a3ded0e9030f64a5090e692ca81655 diff --git a/tests/autotest b/tests/autotest index 2561f56..1cea707 100755 --- a/tests/autotest +++ b/tests/autotest @@ -1,33 +1,44 @@ #!/usr/bin/expect -f -set tt tests/tmp +set testfile [lindex $argv 0] + +switch -glob -- $testfile { + tests/*.at { + regsub {^tests/} $testfile {} id + regsub {\.at$} $id {} id + set tt "tests/tmp/$id" + } + * { + set id "\[[info pid]\]" + set tt tests/tmp/[info pid] + } +} exec rm -rf $tt -exec mkdir $tt +file mkdir tests/tmp $tt set pwd [pwd] set env(HOME) $tt set env(CAFTEST_CAF) $pwd +set env(CAFTEST_TMP) $pwd/$tt set env(TERM) vt100 +set env(CAFTEST_NOSRCDUMP) 1 +set env(LC_ALL) en_GB.utf-8 log_user 0 log_file -a $tt/expect.log -spawn -nottycopy \ -w3m -config /dev/null -o cgi_bin=$pwd/tests file:///cgi-bin/wrap/Tsuffix - proc timeout-abort {} { send_log "\r\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n" - error "aborting due to timeout" + error "$id: aborting due to timeout" } -set timeout 5 - -expect_after timeout timeout-abort +set timeout 10 proc elog {args} { + global id set m "[list expect [lindex $args end]]" - puts stderr $m + puts stderr "$id: $m" # send_log "\n$m\n" eval expect $args } @@ -41,7 +52,16 @@ proc epage {str} { etxt $str } -epage {You need to log in} +proc dospawn {} { + global pwd spawn_id + + spawn -nottycopy \ + w3m -config /dev/null -o cgi_bin=$pwd/tests file:///cgi-bin/wrap/Tsuffix + + expect_after timeout timeout-abort + + epage {You need to log in} +} proc fillformfield {value} { send "\t\r$value\r" @@ -53,25 +73,13 @@ proc submitform-expect {wanttxt} { epage $wanttxt } -fillformfield alice -fillformfield bogus -send "\t" -submitform-expect "wrong password" - -fillformfield alice -fillformfield sesame -send "\t" -submitform-expect "ACCESSGRANTED" - -etxt {path = '/Tsuffix'} - -send "/Make worms\r" -submitform-expect "MAKING-worms" - -send "/Logout\r" -submitform-expect "You have been logged out" +proc loginas {user {password sesame} {wanttxt ACCESSGRANTED}} { + fillformfield $user + fillformfield $password + send "\t" + submitform-expect $wanttxt +} -send "B\x10/Make sponges\r" -#submitform-expect "Something sane" +source $testfile -puts ok +puts "$id: ok"