Added test for "+" not followed by space in continue_req.
This commit is contained in:
parent
599be47555
commit
24eff0069b
@ -31,6 +31,7 @@ VMIME_TEST_SUITE_BEGIN(IMAPParserTest)
|
|||||||
|
|
||||||
VMIME_TEST_LIST_BEGIN
|
VMIME_TEST_LIST_BEGIN
|
||||||
VMIME_TEST(testExtraSpaceInCapaResponse)
|
VMIME_TEST(testExtraSpaceInCapaResponse)
|
||||||
|
VMIME_TEST(testContinueReqWithoutSpace)
|
||||||
VMIME_TEST_LIST_END
|
VMIME_TEST_LIST_END
|
||||||
|
|
||||||
|
|
||||||
@ -64,4 +65,40 @@ VMIME_TEST_SUITE_BEGIN(IMAPParserTest)
|
|||||||
VASSERT_THROW("strict mode", parser->readResponse(/* literalHandler */ NULL), vmime::exceptions::invalid_response);
|
VASSERT_THROW("strict mode", parser->readResponse(/* literalHandler */ NULL), vmime::exceptions::invalid_response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For Apple iCloud/Exchange IMAP server
|
||||||
|
void testContinueReqWithoutSpace()
|
||||||
|
{
|
||||||
|
// continue_req ::= "+" SPACE (resp_text / base64)
|
||||||
|
//
|
||||||
|
// Some servers do not send SPACE when response text is empty.
|
||||||
|
// IMAP parser should allow this in non-strict mode.
|
||||||
|
//
|
||||||
|
// Eg:
|
||||||
|
//
|
||||||
|
// C: a002 AUTHENTICATE xxx[CR][LF]
|
||||||
|
// S: +[CR][LF]
|
||||||
|
|
||||||
|
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>();
|
||||||
|
|
||||||
|
socket->localSend("+\r\n");
|
||||||
|
|
||||||
|
vmime::shared_ptr <vmime::net::imap::IMAPParser> parser =
|
||||||
|
vmime::make_shared <vmime::net::imap::IMAPParser>
|
||||||
|
(tag, vmime::dynamicCast <vmime::net::socket>(socket), toh);
|
||||||
|
|
||||||
|
parser->setStrict(false);
|
||||||
|
VASSERT_NO_THROW("non-strict mode", parser->readResponse());
|
||||||
|
|
||||||
|
++(*tag);
|
||||||
|
|
||||||
|
socket->localSend("+\r\n");
|
||||||
|
|
||||||
|
parser->setStrict(true);
|
||||||
|
VASSERT_THROW("strict mode", parser->readResponse(), vmime::exceptions::invalid_response);
|
||||||
|
}
|
||||||
|
|
||||||
VMIME_TEST_SUITE_END
|
VMIME_TEST_SUITE_END
|
||||||
|
Loading…
Reference in New Issue
Block a user