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

Side by Side Diff: components/safe_browsing_db/v4_protocol_manager_util_unittest.cc

Issue 2057433002: Replace the old URL format for PVer4 requests with the new format. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: CR feedback: nparker. GetRequestUrlAndUpdateHeaders -> GetRequestUrlAndHeaders Created 4 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/safe_browsing_db/v4_protocol_manager_util.h" 5 #include "components/safe_browsing_db/v4_protocol_manager_util.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/base64.h" 9 #include "base/base64.h"
10 #include "base/time/time.h" 10 #include "base/time/time.h"
11 #include "net/base/escape.h" 11 #include "net/base/escape.h"
12 #include "net/http/http_request_headers.h"
12 #include "testing/gtest/include/gtest/gtest.h" 13 #include "testing/gtest/include/gtest/gtest.h"
13 14
14 using base::Time; 15 using base::Time;
15 using base::TimeDelta; 16 using base::TimeDelta;
16 17
17 namespace { 18 namespace {
18 19
19 const char kClient[] = "unittest"; 20 const char kClient[] = "unittest";
20 const char kAppVer[] = "1.0"; 21 const char kAppVer[] = "1.0";
21 const char kKeyParam[] = "test_key_param"; 22 const char kKeyParam[] = "test_key_param";
(...skipping 16 matching lines...) Expand all
38 39
39 // 1 error. 40 // 1 error.
40 base::TimeDelta next = V4ProtocolManagerUtil::GetNextBackOffInterval( 41 base::TimeDelta next = V4ProtocolManagerUtil::GetNextBackOffInterval(
41 &error_count, &back_off_multiplier); 42 &error_count, &back_off_multiplier);
42 EXPECT_EQ(1U, error_count); 43 EXPECT_EQ(1U, error_count);
43 EXPECT_EQ(1U, back_off_multiplier); 44 EXPECT_EQ(1U, back_off_multiplier);
44 EXPECT_LE(TimeDelta::FromMinutes(15), next); 45 EXPECT_LE(TimeDelta::FromMinutes(15), next);
45 EXPECT_GE(TimeDelta::FromMinutes(30), next); 46 EXPECT_GE(TimeDelta::FromMinutes(30), next);
46 47
47 // 2 errors. 48 // 2 errors.
48 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 49 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
49 &error_count, &back_off_multiplier); 50 &back_off_multiplier);
50 EXPECT_EQ(2U, error_count); 51 EXPECT_EQ(2U, error_count);
51 EXPECT_EQ(2U, back_off_multiplier); 52 EXPECT_EQ(2U, back_off_multiplier);
52 EXPECT_LE(TimeDelta::FromMinutes(30), next); 53 EXPECT_LE(TimeDelta::FromMinutes(30), next);
53 EXPECT_GE(TimeDelta::FromMinutes(60), next); 54 EXPECT_GE(TimeDelta::FromMinutes(60), next);
54 55
55 // 3 errors. 56 // 3 errors.
56 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 57 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
57 &error_count, &back_off_multiplier); 58 &back_off_multiplier);
58 EXPECT_EQ(3U, error_count); 59 EXPECT_EQ(3U, error_count);
59 EXPECT_EQ(4U, back_off_multiplier); 60 EXPECT_EQ(4U, back_off_multiplier);
60 EXPECT_LE(TimeDelta::FromMinutes(60), next); 61 EXPECT_LE(TimeDelta::FromMinutes(60), next);
61 EXPECT_GE(TimeDelta::FromMinutes(120), next); 62 EXPECT_GE(TimeDelta::FromMinutes(120), next);
62 63
63 // 4 errors. 64 // 4 errors.
64 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 65 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
65 &error_count, &back_off_multiplier); 66 &back_off_multiplier);
66 EXPECT_EQ(4U, error_count); 67 EXPECT_EQ(4U, error_count);
67 EXPECT_EQ(8U, back_off_multiplier); 68 EXPECT_EQ(8U, back_off_multiplier);
68 EXPECT_LE(TimeDelta::FromMinutes(120), next); 69 EXPECT_LE(TimeDelta::FromMinutes(120), next);
69 EXPECT_GE(TimeDelta::FromMinutes(240), next); 70 EXPECT_GE(TimeDelta::FromMinutes(240), next);
70 71
71 // 5 errors. 72 // 5 errors.
72 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 73 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
73 &error_count, &back_off_multiplier); 74 &back_off_multiplier);
74 EXPECT_EQ(5U, error_count); 75 EXPECT_EQ(5U, error_count);
75 EXPECT_EQ(16U, back_off_multiplier); 76 EXPECT_EQ(16U, back_off_multiplier);
76 EXPECT_LE(TimeDelta::FromMinutes(240), next); 77 EXPECT_LE(TimeDelta::FromMinutes(240), next);
77 EXPECT_GE(TimeDelta::FromMinutes(480), next); 78 EXPECT_GE(TimeDelta::FromMinutes(480), next);
78 79
79 // 6 errors. 80 // 6 errors.
80 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 81 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
81 &error_count, &back_off_multiplier); 82 &back_off_multiplier);
82 EXPECT_EQ(6U, error_count); 83 EXPECT_EQ(6U, error_count);
83 EXPECT_EQ(32U, back_off_multiplier); 84 EXPECT_EQ(32U, back_off_multiplier);
84 EXPECT_LE(TimeDelta::FromMinutes(480), next); 85 EXPECT_LE(TimeDelta::FromMinutes(480), next);
85 EXPECT_GE(TimeDelta::FromMinutes(960), next); 86 EXPECT_GE(TimeDelta::FromMinutes(960), next);
86 87
87 // 7 errors. 88 // 7 errors.
88 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 89 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
89 &error_count, &back_off_multiplier); 90 &back_off_multiplier);
90 EXPECT_EQ(7U, error_count); 91 EXPECT_EQ(7U, error_count);
91 EXPECT_EQ(64U, back_off_multiplier); 92 EXPECT_EQ(64U, back_off_multiplier);
92 EXPECT_LE(TimeDelta::FromMinutes(960), next); 93 EXPECT_LE(TimeDelta::FromMinutes(960), next);
93 EXPECT_GE(TimeDelta::FromMinutes(1920), next); 94 EXPECT_GE(TimeDelta::FromMinutes(1920), next);
94 95
95 // 8 errors, reached max backoff. 96 // 8 errors, reached max backoff.
96 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 97 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
97 &error_count, &back_off_multiplier); 98 &back_off_multiplier);
98 EXPECT_EQ(8U, error_count); 99 EXPECT_EQ(8U, error_count);
99 EXPECT_EQ(128U, back_off_multiplier); 100 EXPECT_EQ(128U, back_off_multiplier);
100 EXPECT_EQ(TimeDelta::FromHours(24), next); 101 EXPECT_EQ(TimeDelta::FromHours(24), next);
101 102
102 // 9 errors, reached max backoff and multiplier capped. 103 // 9 errors, reached max backoff and multiplier capped.
103 next = V4ProtocolManagerUtil::GetNextBackOffInterval( 104 next = V4ProtocolManagerUtil::GetNextBackOffInterval(&error_count,
104 &error_count, &back_off_multiplier); 105 &back_off_multiplier);
105 EXPECT_EQ(9U, error_count); 106 EXPECT_EQ(9U, error_count);
106 EXPECT_EQ(128U, back_off_multiplier); 107 EXPECT_EQ(128U, back_off_multiplier);
107 EXPECT_EQ(TimeDelta::FromHours(24), next); 108 EXPECT_EQ(TimeDelta::FromHours(24), next);
108 } 109 }
109 110
110 TEST_F(SafeBrowsingV4ProtocolManagerUtilTest, TestGetRequestUrl) { 111 TEST_F(SafeBrowsingV4ProtocolManagerUtilTest,
112 TestGetRequestUrlAndUpdateHeaders) {
111 V4ProtocolConfig config; 113 V4ProtocolConfig config;
112 PopulateV4ProtocolConfig(&config); 114 PopulateV4ProtocolConfig(&config);
113 115
116 net::HttpRequestHeaders headers;
117 GURL gurl;
118 V4ProtocolManagerUtil::GetRequestUrlAndHeaders("request_base64", "someMethod",
119 config, &gurl, &headers);
114 std::string expectedUrl = 120 std::string expectedUrl =
115 "https://safebrowsing.googleapis.com/v4/someMethod/request_base64?" 121 "https://safebrowsing.googleapis.com/v4/someMethod?"
116 "alt=proto&client_id=unittest&client_version=1.0&key=test_key_param"; 122 "$req=request_base64&$ct=application/x-protobuf&key=test_key_param";
117 EXPECT_EQ(expectedUrl, V4ProtocolManagerUtil::GetRequestUrl( 123 EXPECT_EQ(expectedUrl, gurl.spec());
118 "request_base64", "someMethod", config) 124 std::string header_value;
119 .spec()); 125 EXPECT_TRUE(headers.GetHeader("X-HTTP-Method-Override", &header_value));
126 EXPECT_EQ("POST", header_value);
120 } 127 }
121 128
122 } // namespace safe_browsing 129 } // namespace safe_browsing
OLDNEW
« no previous file with comments | « components/safe_browsing_db/v4_protocol_manager_util.cc ('k') | components/safe_browsing_db/v4_update_protocol_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698