X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/9b25ac098512e993a24dbbc98424b0a61ed9a339..274986f21a7bdfbc18117e41d93c67833996e5f1:/test/oauth/test-send diff --git a/test/oauth/test-send b/test/oauth/test-send index ad40dbdd..98efb2b5 100755 --- a/test/oauth/test-send +++ b/test/oauth/test-send @@ -1,6 +1,6 @@ #!/bin/sh # -# Test the XOAUTH2 support in sen +# Test the XOAUTH2 support in send # if test -z "${MH_OBJ_DIR}"; then @@ -163,29 +163,32 @@ setup_draft # TEST start_test 'no service definition' -run_test "send -draft -server 127.0.0.1 -port ${smtp_port} -saslmech xoauth2 -authservice bogus -user nobody@example.com" 'send: incomplete OAuth2 service definition: scope is missing' +run_test "send -draft -server 127.0.0.1 -port ${smtp_port} -saslmech xoauth2 -authservice bogus -user nobody@example.com" 'send: Unable to retrieve oauth profile entries: scope is missing' # TEST start_test 'no creds file -- should tell user to mhlogin' rm -f "${MHTMPDIR}/oauth-test" -test_send_no_servers 'send: no credentials -- run mhlogin -saslmech xoauth2 -authservice test' +test_send_only_fakesmtp 'post: no credentials -- run mhlogin -saslmech xoauth2 -authservice test +send: message not delivered to anyone' # TEST start_test 'empty creds file -- should tell user to mhlogin' fake_creds < /dev/null -test_send_no_servers 'send: user not found in cred file: nobody@example.com' +test_send_only_fakesmtp 'post: user not found in cred file: nobody@example.com +send: message not delivered to anyone' # TEST start_test 'garbage creds file' echo bork | fake_creds -test_send_no_servers 'send: eof encountered in field "bork" -send: error loading cred file' +test_send_only_fakesmtp 'post: eof encountered in field "bork" +post: error loading cred file +send: message not delivered to anyone' # TEST start_test 'unexpected field in creds file' @@ -195,7 +198,8 @@ bork: bork access-nobody@example.com: test-access EOF -test_send_no_servers 'send: error loading cred file: unexpected field' +test_send_only_fakesmtp 'post: error loading cred file: unexpected field +send: message not delivered to anyone' # TEST start_test 'garbage expiration time' @@ -205,7 +209,8 @@ access-nobody@example.com: test-access expire-nobody@example.com: 99999999999999999999999999999999 EOF -test_send_no_servers 'send: error loading cred file: invalid expiration time' +test_send_only_fakesmtp 'post: error loading cred file: invalid expiration time +send: message not delivered to anyone' # TEST start_test 'refresh response has no access token' @@ -223,8 +228,9 @@ fake_json_response < "${testname}.expected-send-output" < "${testname}.send-output" 2>&1 || true # Clear out an error message we get from libcurl on some systems (seen at least # 3 different versions of this error message, on FreeBSD 10.1, Ubuntu 12.04, and # Ubuntu 14.04). f="${testname}.send-output" -sed 's/\(send: error making HTTP request to OAuth2 authorization endpoint:\).*/\1 [details]/' "$f" > "$f".clean +sed 's/\(post: error making HTTP request to OAuth2 authorization endpoint:\).*/\1 [details]/' "$f" > "$f".clean check "$f".clean "${testname}.expected-send-output" rm "$f" @@ -279,8 +289,9 @@ Content-Type: text/html doh! EOF -test_send_only_fakehttp 'send: error refreshing OAuth2 token -send: invalid response' +test_send 'post: error refreshing OAuth2 token +post: invalid response +send: message not delivered to anyone' # TEST start_test 'refresh gets 500 response from http server' @@ -293,8 +304,9 @@ Content-Type: text/html doh! EOF -test_send_only_fakehttp 'send: error refreshing OAuth2 token -send: invalid response' +test_send 'post: error refreshing OAuth2 token +post: invalid response +send: message not delivered to anyone' # TEST start_test 'refresh gets proper error from http' @@ -309,7 +321,8 @@ Content-Type: application/json } EOF -test_send_only_fakehttp 'send: credentials rejected -- run mhlogin -saslmech xoauth2 -authservice test' +test_send 'post: credentials rejected -- run mhlogin -saslmech xoauth2 -authservice test +send: message not delivered to anyone' # TEST start_test 'refresh gets response too big' @@ -331,8 +344,9 @@ EOF awk 'BEGIN { for (i = 0; i < 8192; i++) { print "." } }' \ >> "${testname}.http-res" -test_send_only_fakehttp 'send: error refreshing OAuth2 token -send: refusing to process response body larger than 8192 bytes' +test_send 'post: error refreshing OAuth2 token +post: refusing to process response body larger than 8192 bytes +send: message not delivered to anyone' # TEST start_test 'smtp server rejects token' @@ -347,14 +361,6 @@ EOF test_send_only_fakesmtp 'post: problem initializing server; [BHST] Not no way, not no how! send: message not delivered to anyone' -# TEST -start_test "smtp server doesn't support oauth" - -unset XOAUTH - -test_send_only_fakesmtp 'post: problem initializing server; [BHST] SMTP server does not support SASL XOAUTH2 -send: message not delivered to anyone' - # TEST start_test 'botched json response' @@ -370,8 +376,17 @@ fake_json_response <