diff options
author | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-29 22:02:47 +0000 |
---|---|---|
committer | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-29 22:02:47 +0000 |
commit | 270c641ccd0cd589b8488c5123e5c5830ee10a0b (patch) | |
tree | cd0a3f192a7305e3c18e8a9edf5ed5d716476baf /net/http/http_request_headers_unittest.cc | |
parent | 11de360780b9cbb846161cd7c772cc26d6f29616 (diff) | |
download | chromium_src-270c641ccd0cd589b8488c5123e5c5830ee10a0b.zip chromium_src-270c641ccd0cd589b8488c5123e5c5830ee10a0b.tar.gz chromium_src-270c641ccd0cd589b8488c5123e5c5830ee10a0b.tar.bz2 |
Reland r42300: "HttpRequestHeaders refactor."
Adds a fix and tests for empty header values. The particular bug happened when the value was non-empty, but was all LWS, so it was effectively empty.
BUG=22588
Review URL: http://codereview.chromium.org/1370001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@43000 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/http/http_request_headers_unittest.cc')
-rw-r--r-- | net/http/http_request_headers_unittest.cc | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/net/http/http_request_headers_unittest.cc b/net/http/http_request_headers_unittest.cc new file mode 100644 index 0000000..29431d9 --- /dev/null +++ b/net/http/http_request_headers_unittest.cc @@ -0,0 +1,140 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "net/http/http_request_headers.h" + +#include "testing/gtest/include/gtest/gtest.h" + +namespace net { + +namespace { + +TEST(HttpRequestHeaders, SetRequestLine) { + HttpRequestHeaders headers; + headers.SetRequestLine( + HttpRequestHeaders::kGetMethod, "/foo", "1.1"); + EXPECT_EQ("GET /foo HTTP/1.1\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, SetHeader) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, SetMultipleHeaders) { + HttpRequestHeaders headers; + headers.SetHeader("Cookie-Monster", "Nom nom nom"); + headers.SetHeader("Domo-Kun", "Loves Chrome"); + EXPECT_EQ("Cookie-Monster: Nom nom nom\r\nDomo-Kun: Loves Chrome\r\n\r\n", + headers.ToString()); +} + +TEST(HttpRequestHeaders, SetHeaderTwice) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + headers.SetHeader("Foo", "bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, SetHeaderTwiceCaseInsensitive) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + headers.SetHeader("FoO", "Bar"); + EXPECT_EQ("Foo: Bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, SetHeaderTwiceSamePrefix) { + HttpRequestHeaders headers; + headers.SetHeader("FooBar", "smokes"); + headers.SetHeader("Foo", "crack"); + EXPECT_EQ("FooBar: smokes\r\nFoo: crack\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, SetEmptyHeader) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "Bar"); + headers.SetHeader("Bar", ""); + EXPECT_EQ("Foo: Bar\r\nBar:\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, RemoveHeader) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + headers.RemoveHeader("Foo"); + EXPECT_EQ("\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, RemoveHeaderMissingHeader) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + headers.RemoveHeader("Bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, RemoveHeaderCaseInsensitive) { + HttpRequestHeaders headers; + headers.SetHeader("Foo", "bar"); + headers.SetHeader("All-Your-Base", "Belongs To Chrome"); + headers.RemoveHeader("foo"); + EXPECT_EQ("All-Your-Base: Belongs To Chrome\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromString) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo: bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringNoLeadingWhitespace) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo:bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringMoreLeadingWhitespace) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo: \t \t bar"); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringTrailingWhitespace) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo: bar \t \t "); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringLeadingTrailingWhitespace) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo: \t bar\t "); + EXPECT_EQ("Foo: bar\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringWithEmptyValue) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo:"); + EXPECT_EQ("Foo:\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, AddHeaderFromStringWithWhitespaceValue) { + HttpRequestHeaders headers; + headers.AddHeaderFromString("Foo: "); + EXPECT_EQ("Foo:\r\n\r\n", headers.ToString()); +} + +TEST(HttpRequestHeaders, MergeFrom) { + HttpRequestHeaders headers; + headers.SetHeader("A", "A"); + headers.SetHeader("B", "B"); + + HttpRequestHeaders headers2; + headers2.SetHeader("B", "b"); + headers2.SetHeader("C", "c"); + headers.MergeFrom(headers2); + EXPECT_EQ("A: A\r\nB: b\r\nC: c\r\n\r\n", headers.ToString()); +} + +} // namespace + +} // namespace net |