diff options
author | vincent-richard <[email protected]> | 2020-04-06 16:20:03 +0000 |
---|---|---|
committer | vincent-richard <[email protected]> | 2020-04-06 16:20:03 +0000 |
commit | fe5492ceb3d2c13ff6cc8904787acf8801728a86 (patch) | |
tree | fb7b56ba1fa26356909f003f9564f76feff11716 /tests/net/imap/IMAPParserTest.cpp | |
parent | Map '*' to '\*' in non-strict mode. (diff) | |
download | vmime-fe5492ceb3d2c13ff6cc8904787acf8801728a86.tar.gz vmime-fe5492ceb3d2c13ff6cc8904787acf8801728a86.zip |
Fixed false positives in tests.
Diffstat (limited to 'tests/net/imap/IMAPParserTest.cpp')
-rw-r--r-- | tests/net/imap/IMAPParserTest.cpp | 166 |
1 files changed, 94 insertions, 72 deletions
diff --git a/tests/net/imap/IMAPParserTest.cpp b/tests/net/imap/IMAPParserTest.cpp index 303902ae..60ce16d7 100644 --- a/tests/net/imap/IMAPParserTest.cpp +++ b/tests/net/imap/IMAPParserTest.cpp @@ -44,35 +44,39 @@ VMIME_TEST_SUITE_BEGIN(IMAPParserTest) // For Apple iCloud IMAP server void testExtraSpaceInCapaResponse() { - vmime::shared_ptr <testSocket> socket = vmime::make_shared <testSocket>(); - vmime::shared_ptr <vmime::net::timeoutHandler> toh = vmime::make_shared <testTimeoutHandler>(); + const char* resp = + "* CAPABILITY IMAP4rev1 AUTH=ATOKEN AUTH=PLAIN \r\n" // extra space at end + "a001 OK Capability completed.\r\n"; - vmime::shared_ptr <vmime::net::imap::IMAPTag> tag = - vmime::make_shared <vmime::net::imap::IMAPTag>(); + // Strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - socket->localSend( - "* CAPABILITY IMAP4rev1 AUTH=ATOKEN AUTH=PLAIN \r\n" // extra space at end - "a001 OK Capability completed.\r\n" - ); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - vmime::shared_ptr <vmime::net::imap::IMAPParser> parser = - vmime::make_shared <vmime::net::imap::IMAPParser>(); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(true); - parser->setSocket(socket); - parser->setTimeoutHandler(toh); + VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + } - parser->setStrict(false); - VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag, /* literalHandler */ NULL)); + // Non-strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - ++(*tag); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - socket->localSend( - "* CAPABILITY IMAP4rev1 AUTH=ATOKEN AUTH=PLAIN \r\n" // extra space at end - "a002 OK Capability completed.\r\n" - ); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(false); - parser->setStrict(true); - VASSERT_THROW("strict mode", parser->readResponse(*tag, /* literalHandler */ NULL), vmime::exceptions::invalid_response); + VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + } } // For Apple iCloud/Exchange IMAP server @@ -119,31 +123,37 @@ VMIME_TEST_SUITE_BEGIN(IMAPParserTest) // --> http://support.microsoft.com/kb/975918/en-us void testNILValueInBodyFldEnc() { - vmime::shared_ptr <testSocket> socket = vmime::make_shared <testSocket>(); - vmime::shared_ptr <vmime::net::timeoutHandler> toh = vmime::make_shared <testTimeoutHandler>(); - - vmime::shared_ptr <vmime::net::imap::IMAPTag> tag = - vmime::make_shared <vmime::net::imap::IMAPTag>(); - const char* resp = "* 7970 FETCH (UID 8036 FLAGS () BODYSTRUCTURE (\"text\" \"html\" (\"charset\" \"utf-8\") NIL NIL NIL 175501 1651 NIL NIL NIL NIL) RFC822.HEADER {3}\r\nx\r\n)\r\na001 OK FETCH complete\r\n"; - socket->localSend(resp); + // Strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - vmime::shared_ptr <vmime::net::imap::IMAPParser> parser = - vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setSocket(socket); - parser->setTimeoutHandler(toh); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(true); - parser->setStrict(false); - VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + } - ++(*tag); + // Non-strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - socket->localSend(resp); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setStrict(true); - VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(false); + + VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + } } // "body_fld_lang" is optional after "body_fld_dsp" in "body_ext_mpart" (Yahoo) @@ -172,61 +182,73 @@ VMIME_TEST_SUITE_BEGIN(IMAPParserTest) // https://www.ietf.org/mail-archive/web/imapext/current/msg05442.html void testFETCHBodyStructure_NIL_body_fld_param_value() { - vmime::shared_ptr <testSocket> socket = vmime::make_shared <testSocket>(); - vmime::shared_ptr <vmime::net::timeoutHandler> toh = vmime::make_shared <testTimeoutHandler>(); - - vmime::shared_ptr <vmime::net::imap::IMAPTag> tag = - vmime::make_shared <vmime::net::imap::IMAPTag>(); - // ...("boundary" NIL)))... is an invalid syntax for a "body_fld_param_item" const char* resp = "* 1 FETCH (BODYSTRUCTURE ((\"text\" \"plain\" (\"charset\" \"utf-8\") NIL NIL \"8bit\" 536 0 NIL NIL NIL NIL)(\"text\" \"html\" (\"charset\" \"utf-8\") NIL NIL \"8bit\" 7130 0 NIL NIL NIL NIL) \"alternative\" (\"boundary\" NIL)))\r\na001 OK FETCH complete\r\n"; - socket->localSend(resp); + // Strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - vmime::shared_ptr <vmime::net::imap::IMAPParser> parser = - vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setSocket(socket); - parser->setTimeoutHandler(toh); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(true); - parser->setStrict(false); - VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + } - ++(*tag); + // Non-strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - socket->localSend(resp); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setStrict(true); - VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(false); + + VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + } } void testFETCHBodyStructure_empty_body_fld_param_instead_of_NIL() { - vmime::shared_ptr <testSocket> socket = vmime::make_shared <testSocket>(); - vmime::shared_ptr <vmime::net::timeoutHandler> toh = vmime::make_shared <testTimeoutHandler>(); - - vmime::shared_ptr <vmime::net::imap::IMAPTag> tag = - vmime::make_shared <vmime::net::imap::IMAPTag>(); - const char* resp = "* 1 FETCH (BODYSTRUCTURE ((\"text\" \"html\" (\"charset\" \"cp1251\") NIL NIL \"base64\" 84056 0 NIL (\"inline\" NIL) NIL NIL)(\"image\" \"gif\" () \"25b2b55b5d97f04e9ea939fe32a46a65.gif\" NIL \"base64\" 20776 NIL (\"inline\" NIL) NIL NIL) \"related\" (\"boundary\" NIL)))\r\na001 OK FETCH complete\r\n"; - socket->localSend(resp); + // Strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - vmime::shared_ptr <vmime::net::imap::IMAPParser> parser = - vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setSocket(socket); - parser->setTimeoutHandler(toh); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(true); - parser->setStrict(false); - VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + } - ++(*tag); + // Non-strict mode + { + auto socket = vmime::make_shared <testSocket>(); + socket->localSend(resp); - socket->localSend(resp); + auto parser = vmime::make_shared <vmime::net::imap::IMAPParser>(); + auto tag = vmime::make_shared <vmime::net::imap::IMAPTag>(); - parser->setStrict(true); - VASSERT_THROW("strict mode", parser->readResponse(*tag), vmime::exceptions::invalid_response); + parser->setSocket(socket); + parser->setTimeoutHandler(vmime::make_shared <testTimeoutHandler>()); + parser->setStrict(false); + + VASSERT_NO_THROW("non-strict mode", parser->readResponse(*tag)); + } } // Test pipelined and out-of-order replies |