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

Side by Side Diff: net/test/embedded_test_server/http_request_unittest.cc

Issue 640593004: Fix a pair of Cronet upload bugs and add tests. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Reorder fields Created 6 years, 2 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 unified diff | Download patch
« no previous file with comments | « net/test/embedded_test_server/http_request.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "net/test/embedded_test_server/http_request.h" 5 #include "net/test/embedded_test_server/http_request.h"
6 6
7 #include "testing/gtest/include/gtest/gtest.h" 7 #include "testing/gtest/include/gtest/gtest.h"
8 8
9 namespace net { 9 namespace net {
10 namespace test_server { 10 namespace test_server {
(...skipping 17 matching lines...) Expand all
28 parser.ProcessChunk("Content-Length: 10\r\n\r\n"); 28 parser.ProcessChunk("Content-Length: 10\r\n\r\n");
29 EXPECT_EQ(HttpRequestParser::WAITING, parser.ParseRequest()); 29 EXPECT_EQ(HttpRequestParser::WAITING, parser.ParseRequest());
30 // Content data and another request in the same chunk (possible in http/1.1). 30 // Content data and another request in the same chunk (possible in http/1.1).
31 parser.ProcessChunk("1234567890GET /another.html HTTP/1.1\r\n\r\n"); 31 parser.ProcessChunk("1234567890GET /another.html HTTP/1.1\r\n\r\n");
32 ASSERT_EQ(HttpRequestParser::ACCEPTED, parser.ParseRequest()); 32 ASSERT_EQ(HttpRequestParser::ACCEPTED, parser.ParseRequest());
33 33
34 // Fetch the first request and validate it. 34 // Fetch the first request and validate it.
35 { 35 {
36 scoped_ptr<HttpRequest> request = parser.GetRequest(); 36 scoped_ptr<HttpRequest> request = parser.GetRequest();
37 EXPECT_EQ("/foobar.html", request->relative_url); 37 EXPECT_EQ("/foobar.html", request->relative_url);
38 EXPECT_EQ("POST", request->method_string);
38 EXPECT_EQ(METHOD_POST, request->method); 39 EXPECT_EQ(METHOD_POST, request->method);
39 EXPECT_EQ("1234567890", request->content); 40 EXPECT_EQ("1234567890", request->content);
40 ASSERT_EQ(3u, request->headers.size()); 41 ASSERT_EQ(3u, request->headers.size());
41 42
42 EXPECT_EQ(1u, request->headers.count("Host")); 43 EXPECT_EQ(1u, request->headers.count("Host"));
43 EXPECT_EQ(1u, request->headers.count("Multi-line-header")); 44 EXPECT_EQ(1u, request->headers.count("Multi-line-header"));
44 EXPECT_EQ(1u, request->headers.count("Content-Length")); 45 EXPECT_EQ(1u, request->headers.count("Content-Length"));
45 46
46 EXPECT_EQ("localhost:1234", request->headers["Host"]); 47 EXPECT_EQ("localhost:1234", request->headers["Host"]);
47 EXPECT_EQ("abcd efgh ijkl", request->headers["Multi-line-header"]); 48 EXPECT_EQ("abcd efgh ijkl", request->headers["Multi-line-header"]);
(...skipping 23 matching lines...) Expand all
71 HttpRequestParser parser; 72 HttpRequestParser parser;
72 73
73 parser.ProcessChunk("POST /foobar.html HTTP/1.1\r\n\r\n"); 74 parser.ProcessChunk("POST /foobar.html HTTP/1.1\r\n\r\n");
74 ASSERT_EQ(HttpRequestParser::ACCEPTED, parser.ParseRequest()); 75 ASSERT_EQ(HttpRequestParser::ACCEPTED, parser.ParseRequest());
75 76
76 scoped_ptr<HttpRequest> request = parser.GetRequest(); 77 scoped_ptr<HttpRequest> request = parser.GetRequest();
77 EXPECT_EQ("", request->content); 78 EXPECT_EQ("", request->content);
78 EXPECT_FALSE(request->has_content); 79 EXPECT_FALSE(request->has_content);
79 } 80 }
80 81
82 TEST(HttpRequestTest, ParseGet) {
83 HttpRequestParser parser;
84
85 parser.ProcessChunk("GET /foobar.html HTTP/1.1\r\n\r\n");
86 ASSERT_EQ(HttpRequestParser::ACCEPTED, parser.ParseRequest());
87
88 scoped_ptr<HttpRequest> request = parser.GetRequest();
89 EXPECT_EQ("/foobar.html", request->relative_url);
90 EXPECT_EQ("GET", request->method_string);
91 EXPECT_EQ(METHOD_GET, request->method);
92 EXPECT_EQ("", request->content);
93 EXPECT_FALSE(request->has_content);
94 }
95
81 } // namespace test_server 96 } // namespace test_server
82 } // namespace net 97 } // namespace net
OLDNEW
« no previous file with comments | « net/test/embedded_test_server/http_request.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698