Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2599)

Unified Diff: Source/platform/network/HTTPParsersTest.cpp

Issue 318613002: Allow empty header value in the blink HTTP header parser. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/platform/network/HTTPParsersTest.cpp
diff --git a/Source/platform/network/HTTPParsersTest.cpp b/Source/platform/network/HTTPParsersTest.cpp
index 506b5303c439117ea83d0e89924d905e1e78f121..cc4a162594fee65e1429439dc114fdda1e3dd385 100644
--- a/Source/platform/network/HTTPParsersTest.cpp
+++ b/Source/platform/network/HTTPParsersTest.cpp
@@ -6,12 +6,22 @@
#include "HTTPParsers.h"
#include "wtf/MathExtras.h"
+#include "wtf/testing/WTFTestHelpers.h"
#include "wtf/text/AtomicString.h"
#include <gtest/gtest.h>
namespace WebCore {
+namespace {
+
+size_t parseHTTPHeader(const char* data, String& failureReason, AtomicString& nameStr, AtomicString& valueStr)
+{
+ return WebCore::parseHTTPHeader(data, strlen(data), failureReason, nameStr, valueStr);
+}
+
+} // namespace
+
TEST(HTTPParsersTest, ParseCacheControl)
{
CacheControlHeader header;
@@ -94,5 +104,91 @@ TEST(HTTPParsersTest, ParseCacheControl)
EXPECT_TRUE(std::isnan(header.maxAge));
}
+TEST(HTTPParsersTest, parseHTTPHeaderSimple)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(11u, parseHTTPHeader("foo: bar\r\notherdata", failureReason, name, value));
+ EXPECT_TRUE(failureReason.isEmpty());
+ EXPECT_EQ("foo", name.string());
+ EXPECT_EQ("bar", value.string());
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderEmptyName)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader(": bar\r\notherdata", failureReason, name, value));
+ EXPECT_EQ("Invalid UTF-8 sequence in header name", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderEmptyValue)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(6u, parseHTTPHeader("foo: \r\notherdata", failureReason, name, value));
+ EXPECT_TRUE(failureReason.isEmpty());
+ EXPECT_EQ("foo", name.string());
+ EXPECT_TRUE(value.isEmpty());
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderEmpty)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("", failureReason, name, value));
+ EXPECT_EQ("Unterminated header name", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderEmptyLine)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(2u, parseHTTPHeader("\r\notherdata", failureReason, name, value));
+ EXPECT_TRUE(failureReason.isEmpty());
+ EXPECT_TRUE(name.isNull());
+ EXPECT_TRUE(value.isNull());
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderUnexpectedCRinName)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("foo\rotherdata\n", failureReason, name, value));
+ EXPECT_EQ("Unexpected CR in name at foo", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderUnexpectedLFinName)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("foo\notherdata\n", failureReason, name, value));
+ EXPECT_EQ("Unexpected LF in name at foo", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderUnexpectedLFinValue)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("foo: bar\notherdata\n", failureReason, name, value));
+ EXPECT_EQ("Unexpected LF in value at bar", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderNoLFAtEndOfLine)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("foo: bar\r", failureReason, name, value));
+ EXPECT_EQ("CR doesn't follow LF after value at ", failureReason);
+}
+
+TEST(HTTPParsersTest, parseHTTPHeaderNoLF)
+{
+ String failureReason;
+ AtomicString name, value;
+ EXPECT_EQ(0u, parseHTTPHeader("foo: bar\rhoge\r\n", failureReason, name, value));
+ EXPECT_EQ("CR doesn't follow LF after value at hoge\r\n", failureReason);
+}
+
tyoshino (SeeGerritForStatus) 2014/06/04 08:24:12 add a test that takes input of two lines and check
yhirano 2014/06/04 09:14:03 Done.
} // namespace WebCore
« Source/platform/network/HTTPParsers.cpp ('K') | « Source/platform/network/HTTPParsers.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698