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

Unified Diff: chrome/browser/extensions/api/web_request/web_request_api_unittest.cc

Issue 10407105: Improve error messaging of webRequest API in case of conflicts (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Store ExtensionWarnings as values in set rather than pointers Created 8 years, 3 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: chrome/browser/extensions/api/web_request/web_request_api_unittest.cc
diff --git a/chrome/browser/extensions/api/web_request/web_request_api_unittest.cc b/chrome/browser/extensions/api/web_request/web_request_api_unittest.cc
index 8976a1d76fe5984c7c9268c77869de12e345a34e..a69cfdae7d9ca499c46dab0252f2e76c11143bba 100644
--- a/chrome/browser/extensions/api/web_request/web_request_api_unittest.cc
+++ b/chrome/browser/extensions/api/web_request/web_request_api_unittest.cc
@@ -20,6 +20,7 @@
#include "chrome/browser/extensions/api/web_request/web_request_api_constants.h"
#include "chrome/browser/extensions/api/web_request/web_request_api_helpers.h"
#include "chrome/browser/extensions/event_router_forwarder.h"
+#include "chrome/browser/extensions/extension_warning_set.h"
#include "chrome/browser/net/chrome_network_delegate.h"
#include "chrome/common/extensions/extension_messages.h"
#include "chrome/common/pref_names.h"
@@ -54,6 +55,8 @@ using helpers::ResponseHeader;
using helpers::ResponseHeaders;
using helpers::StringToCharList;
+namespace extensions {
+
namespace {
static void EventHandledOnIOThread(
void* profile,
@@ -75,6 +78,17 @@ bool Contains(const Collection& collection, const Key& key) {
collection.end();
}
+// Returns whether |warnings| contains an extension for |extension_id|.
+bool HasWarning(const ExtensionWarningSet& warnings,
+ const std::string& extension_id) {
+ for (ExtensionWarningSet::const_iterator i = warnings.begin();
+ i != warnings.end(); ++i) {
+ if (i->extension_id() == extension_id)
+ return true;
+ }
+ return false;
+}
+
} // namespace
// A mock event router that responds to events with a pre-arranged queue of
@@ -124,7 +138,7 @@ class ExtensionWebRequestTest : public testing::Test {
protected:
virtual void SetUp() OVERRIDE {
- event_router_ = new extensions::EventRouterForwarder();
+ event_router_ = new EventRouterForwarder();
enable_referrers_.Init(
prefs::kEnableReferrers, profile_.GetTestingPrefService(), NULL);
network_delegate_.reset(new ChromeNetworkDelegate(
@@ -143,7 +157,7 @@ class ExtensionWebRequestTest : public testing::Test {
TestDelegate delegate_;
BooleanPrefMember enable_referrers_;
TestIPCSender ipc_sender_;
- scoped_refptr<extensions::EventRouterForwarder> event_router_;
+ scoped_refptr<EventRouterForwarder> event_router_;
scoped_refptr<ExtensionInfoMap> extension_info_map_;
scoped_ptr<ChromeNetworkDelegate> network_delegate_;
scoped_ptr<TestURLRequestContext> context_;
@@ -439,7 +453,7 @@ class ExtensionWebRequestHeaderModificationTest :
protected:
virtual void SetUp() {
- event_router_ = new extensions::EventRouterForwarder();
+ event_router_ = new EventRouterForwarder();
enable_referrers_.Init(
prefs::kEnableReferrers, profile_.GetTestingPrefService(), NULL);
network_delegate_.reset(new ChromeNetworkDelegate(
@@ -461,7 +475,7 @@ class ExtensionWebRequestHeaderModificationTest :
TestDelegate delegate_;
BooleanPrefMember enable_referrers_;
TestIPCSender ipc_sender_;
- scoped_refptr<extensions::EventRouterForwarder> event_router_;
+ scoped_refptr<EventRouterForwarder> event_router_;
scoped_refptr<ExtensionInfoMap> extension_info_map_;
scoped_ptr<ChromeNetworkDelegate> network_delegate_;
scoped_ptr<net::MockHostResolver> host_resolver_;
@@ -953,7 +967,7 @@ TEST(ExtensionWebRequestHelpersTest, TestCalculateOnHeadersReceivedDelta) {
EXPECT_TRUE(Contains(delta->deleted_response_headers,
ResponseHeader("Key2", "Value2, Bar")));
EXPECT_TRUE(Contains(delta->deleted_response_headers,
- ResponseHeader("Key3", "Value3")));
+ ResponseHeader("Key3", "Value3")));
}
TEST(ExtensionWebRequestHelpersTest, TestCalculateOnAuthRequiredDelta) {
@@ -1004,7 +1018,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
EventResponseDeltas deltas;
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
GURL effective_new_url;
// No redirect
@@ -1012,7 +1026,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
new EventResponseDelta("extid0", base::Time::FromInternalValue(0)));
deltas.push_back(d0);
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_TRUE(effective_new_url.is_empty());
// Single redirect.
@@ -1024,9 +1038,9 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_TRUE(conflicting_extensions.empty());
+ EXPECT_TRUE(warning_set.empty());
EXPECT_EQ(1u, capturing_net_log.GetSize());
// Ignored redirect (due to precedence).
@@ -1036,12 +1050,13 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
d2->new_url = GURL(new_url_2);
deltas.push_back(d2);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(2u, capturing_net_log.GetSize());
// Overriding redirect.
@@ -1051,14 +1066,14 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
d3->new_url = GURL(new_url_3);
deltas.push_back(d3);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_3, effective_new_url);
- EXPECT_EQ(2u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid1"));
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(2u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid1"));
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(3u, capturing_net_log.GetSize());
// Check that identical redirects don't cause a conflict.
@@ -1067,14 +1082,14 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses) {
d4->new_url = GURL(new_url_3);
deltas.push_back(d4);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_3, effective_new_url);
- EXPECT_EQ(2u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid1"));
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(2u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid1"));
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(4u, capturing_net_log.GetSize());
}
@@ -1084,7 +1099,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses2) {
EventResponseDeltas deltas;
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
GURL effective_new_url;
// Single redirect.
@@ -1094,7 +1109,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses2) {
d0->new_url = GURL(new_url_0);
deltas.push_back(d0);
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_0, effective_new_url);
// Cancel request by redirecting to a data:// URL. This shall override
@@ -1105,11 +1120,12 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses2) {
d1->new_url = GURL(new_url_1);
deltas.push_back(d1);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_TRUE(conflicting_extensions.empty());
+ EXPECT_TRUE(warning_set.empty());
EXPECT_EQ(1u, capturing_net_log.GetSize());
// Cancel request by redirecting to the same data:// URL. This shall
@@ -1120,11 +1136,12 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses2) {
d2->new_url = GURL(new_url_2);
deltas.push_back(d2);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_TRUE(conflicting_extensions.empty());
+ EXPECT_TRUE(warning_set.empty());
EXPECT_EQ(2u, capturing_net_log.GetSize());
// Cancel redirect by redirecting to a different data:// URL. This needs
@@ -1135,12 +1152,13 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses2) {
d3->new_url = GURL(new_url_3);
deltas.push_back(d3);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid3"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid3"));
EXPECT_EQ(3u, capturing_net_log.GetSize());
}
@@ -1150,7 +1168,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses3) {
EventResponseDeltas deltas;
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
GURL effective_new_url;
// Single redirect.
@@ -1160,7 +1178,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses3) {
d0->new_url = GURL(new_url_0);
deltas.push_back(d0);
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_0, effective_new_url);
// Cancel request by redirecting to about:blank. This shall override
@@ -1171,11 +1189,12 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeRequestResponses3) {
d1->new_url = GURL(new_url_1);
deltas.push_back(d1);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
capturing_net_log.Clear();
MergeOnBeforeRequestResponses(
- deltas, &effective_new_url, &conflicting_extensions, &net_log);
+ deltas, &effective_new_url, &warning_set, &net_log);
EXPECT_EQ(new_url_1, effective_new_url);
- EXPECT_TRUE(conflicting_extensions.empty());
+ EXPECT_TRUE(warning_set.empty());
EXPECT_EQ(1u, capturing_net_log.GetSize());
}
@@ -1185,7 +1204,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
base_headers.AddHeaderFromString("key2: value 2");
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
std::string header_value;
EventResponseDeltas deltas;
@@ -1195,13 +1214,12 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
deltas.push_back(d0);
net::HttpRequestHeaders headers0;
headers0.MergeFrom(base_headers);
- MergeOnBeforeSendHeadersResponses(
- deltas, &headers0, &conflicting_extensions, &net_log);
+ MergeOnBeforeSendHeadersResponses(deltas, &headers0, &warning_set, &net_log);
ASSERT_TRUE(headers0.GetHeader("key1", &header_value));
EXPECT_EQ("value 1", header_value);
ASSERT_TRUE(headers0.GetHeader("key2", &header_value));
EXPECT_EQ("value 2", header_value);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
// Delete, modify and add a header.
@@ -1212,16 +1230,17 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
d1->modified_request_headers.AddHeaderFromString("key3: value 3");
deltas.push_back(d1);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
+ warning_set.clear();
+ capturing_net_log.Clear();
net::HttpRequestHeaders headers1;
headers1.MergeFrom(base_headers);
- MergeOnBeforeSendHeadersResponses(
- deltas, &headers1, &conflicting_extensions, &net_log);
+ MergeOnBeforeSendHeadersResponses(deltas, &headers1, &warning_set, &net_log);
EXPECT_FALSE(headers1.HasHeader("key1"));
ASSERT_TRUE(headers1.GetHeader("key2", &header_value));
EXPECT_EQ("value 3", header_value);
ASSERT_TRUE(headers1.GetHeader("key3", &header_value));
EXPECT_EQ("value 3", header_value);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(1u, capturing_net_log.GetSize());
// Check that conflicts are atomic, i.e. if one header modification
@@ -1233,20 +1252,19 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
d2->modified_request_headers.AddHeaderFromString("key4: value 4");
deltas.push_back(d2);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
net::HttpRequestHeaders headers2;
headers2.MergeFrom(base_headers);
- MergeOnBeforeSendHeadersResponses(
- deltas, &headers2, &conflicting_extensions, &net_log);
+ MergeOnBeforeSendHeadersResponses(deltas, &headers2, &warning_set, &net_log);
EXPECT_FALSE(headers2.HasHeader("key1"));
ASSERT_TRUE(headers2.GetHeader("key2", &header_value));
EXPECT_EQ("value 3", header_value);
ASSERT_TRUE(headers2.GetHeader("key3", &header_value));
EXPECT_EQ("value 3", header_value);
EXPECT_FALSE(headers2.HasHeader("key4"));
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(2u, capturing_net_log.GetSize());
// Check that identical modifications don't conflict and operations
@@ -1258,12 +1276,11 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
d3->modified_request_headers.AddHeaderFromString("key5: value 5");
deltas.push_back(d3);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
net::HttpRequestHeaders headers3;
headers3.MergeFrom(base_headers);
- MergeOnBeforeSendHeadersResponses(
- deltas, &headers3, &conflicting_extensions, &net_log);
+ MergeOnBeforeSendHeadersResponses(deltas, &headers3, &warning_set, &net_log);
EXPECT_FALSE(headers3.HasHeader("key1"));
ASSERT_TRUE(headers3.GetHeader("key2", &header_value));
EXPECT_EQ("value 3", header_value);
@@ -1271,8 +1288,8 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnBeforeSendHeadersResponses) {
EXPECT_EQ("value 3", header_value);
ASSERT_TRUE(headers3.GetHeader("key5", &header_value));
EXPECT_EQ("value 5", header_value);
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(3u, capturing_net_log.GetSize());
}
@@ -1283,7 +1300,7 @@ TEST(ExtensionWebRequestHelpersTest,
"Cookie: name=value; name2=value2; name3=value3");
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
std::string header_value;
EventResponseDeltas deltas;
@@ -1328,12 +1345,12 @@ TEST(ExtensionWebRequestHelpersTest,
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
net::HttpRequestHeaders headers1;
headers1.MergeFrom(base_headers);
- MergeOnBeforeSendHeadersResponses(
- deltas, &headers1, &conflicting_extensions, &net_log);
+ warning_set.clear();
+ MergeOnBeforeSendHeadersResponses(deltas, &headers1, &warning_set, &net_log);
EXPECT_TRUE(headers1.HasHeader("Cookie"));
ASSERT_TRUE(headers1.GetHeader("Cookie", &header_value));
EXPECT_EQ("name=new value; name2=new value; name4=\"value 4\"", header_value);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
}
@@ -1341,7 +1358,7 @@ TEST(ExtensionWebRequestHelpersTest,
TestMergeCookiesInOnHeadersReceivedResponses) {
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
std::string header_value;
EventResponseDeltas deltas;
@@ -1363,10 +1380,9 @@ TEST(ExtensionWebRequestHelpersTest,
deltas.push_back(d0);
scoped_refptr<net::HttpResponseHeaders> new_headers0;
MergeCookiesInOnHeadersReceivedResponses(
- deltas, base_headers.get(), &new_headers0, &conflicting_extensions,
- &net_log);
+ deltas, base_headers.get(), &new_headers0, &warning_set, &net_log);
EXPECT_FALSE(new_headers0.get());
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
linked_ptr<ResponseCookieModification> add_cookie =
@@ -1414,8 +1430,9 @@ TEST(ExtensionWebRequestHelpersTest,
net::HttpUtil::AssembleRawHeaders(
base_headers_string, sizeof(base_headers_string))));
scoped_refptr<net::HttpResponseHeaders> new_headers1;
+ warning_set.clear();
MergeCookiesInOnHeadersReceivedResponses(
- deltas, headers1.get(), &new_headers1, &conflicting_extensions, &net_log);
+ deltas, headers1.get(), &new_headers1, &warning_set, &net_log);
EXPECT_TRUE(new_headers1->HasHeader("Foo"));
void* iter = NULL;
@@ -1428,14 +1445,14 @@ TEST(ExtensionWebRequestHelpersTest,
while (new_headers1->EnumerateHeader(&iter, "Set-Cookie", &cookie_string))
actual_cookies.insert(cookie_string);
EXPECT_EQ(expected_cookies, actual_cookies);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
}
TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
std::string header_value;
EventResponseDeltas deltas;
@@ -1454,11 +1471,10 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
new EventResponseDelta("extid0", base::Time::FromInternalValue(3000)));
deltas.push_back(d0);
scoped_refptr<net::HttpResponseHeaders> new_headers0;
- MergeOnHeadersReceivedResponses(
- deltas, base_headers.get(), &new_headers0, &conflicting_extensions,
- &net_log);
+ MergeOnHeadersReceivedResponses(deltas, base_headers.get(), &new_headers0,
+ &warning_set, &net_log);
EXPECT_FALSE(new_headers0.get());
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
linked_ptr<EventResponseDelta> d1(
@@ -1468,12 +1484,11 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
d1->added_response_headers.push_back(ResponseHeader("Key2", "Value3"));
deltas.push_back(d1);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
scoped_refptr<net::HttpResponseHeaders> new_headers1;
MergeOnHeadersReceivedResponses(
- deltas, base_headers.get(), &new_headers1, &conflicting_extensions,
- &net_log);
+ deltas, base_headers.get(), &new_headers1, &warning_set, &net_log);
ASSERT_TRUE(new_headers1.get());
std::multimap<std::string, std::string> expected1;
expected1.insert(std::pair<std::string, std::string>("Key2", "Value3"));
@@ -1485,7 +1500,7 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
actual1.insert(std::pair<std::string, std::string>(name, value));
}
EXPECT_EQ(expected1, actual1);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(1u, capturing_net_log.GetSize());
// Check that we replace response headers only once.
@@ -1497,12 +1512,11 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
d2->added_response_headers.push_back(ResponseHeader("Key2", "Value4"));
deltas.push_back(d2);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
scoped_refptr<net::HttpResponseHeaders> new_headers2;
MergeOnHeadersReceivedResponses(
- deltas, base_headers.get(), &new_headers2, &conflicting_extensions,
- &net_log);
+ deltas, base_headers.get(), &new_headers2, &warning_set, &net_log);
ASSERT_TRUE(new_headers2.get());
iter = NULL;
std::multimap<std::string, std::string> actual2;
@@ -1510,8 +1524,8 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnHeadersReceivedResponses) {
actual2.insert(std::pair<std::string, std::string>(name, value));
}
EXPECT_EQ(expected1, actual2);
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(2u, capturing_net_log.GetSize());
}
@@ -1520,7 +1534,7 @@ TEST(ExtensionWebRequestHelpersTest,
TestMergeOnHeadersReceivedResponsesDeletion) {
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
std::string header_value;
EventResponseDeltas deltas;
@@ -1542,8 +1556,7 @@ TEST(ExtensionWebRequestHelpersTest,
deltas.push_back(d1);
scoped_refptr<net::HttpResponseHeaders> new_headers1;
MergeOnHeadersReceivedResponses(
- deltas, base_headers.get(), &new_headers1, &conflicting_extensions,
- &net_log);
+ deltas, base_headers.get(), &new_headers1, &warning_set, &net_log);
ASSERT_TRUE(new_headers1.get());
std::multimap<std::string, std::string> expected1;
expected1.insert(std::pair<std::string, std::string>("Key1", "Value1"));
@@ -1557,14 +1570,14 @@ TEST(ExtensionWebRequestHelpersTest,
actual1.insert(std::pair<std::string, std::string>(name, value));
}
EXPECT_EQ(expected1, actual1);
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(1u, capturing_net_log.GetSize());
}
TEST(ExtensionWebRequestHelpersTest, TestMergeOnAuthRequiredResponses) {
net::CapturingBoundNetLog capturing_net_log;
net::BoundNetLog net_log = capturing_net_log.bound();
- std::set<std::string> conflicting_extensions;
+ ExtensionWarningSet warning_set;
EventResponseDeltas deltas;
string16 username = ASCIIToUTF16("foo");
string16 password = ASCIIToUTF16("bar");
@@ -1576,10 +1589,10 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnAuthRequiredResponses) {
deltas.push_back(d0);
net::AuthCredentials auth0;
bool credentials_set = MergeOnAuthRequiredResponses(
- deltas, &auth0, &conflicting_extensions, &net_log);
+ deltas, &auth0, &warning_set, &net_log);
EXPECT_FALSE(credentials_set);
EXPECT_TRUE(auth0.Empty());
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(0u, capturing_net_log.GetSize());
// Check that we can set AuthCredentials.
@@ -1588,16 +1601,16 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnAuthRequiredResponses) {
d1->auth_credentials.reset(new net::AuthCredentials(username, password));
deltas.push_back(d1);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
net::AuthCredentials auth1;
credentials_set = MergeOnAuthRequiredResponses(
- deltas, &auth1, &conflicting_extensions, &net_log);
+ deltas, &auth1, &warning_set, &net_log);
EXPECT_TRUE(credentials_set);
EXPECT_FALSE(auth1.Empty());
EXPECT_EQ(username, auth1.username());
EXPECT_EQ(password, auth1.password());
- EXPECT_EQ(0u, conflicting_extensions.size());
+ EXPECT_EQ(0u, warning_set.size());
EXPECT_EQ(1u, capturing_net_log.GetSize());
// Check that we set AuthCredentials only once.
@@ -1606,17 +1619,17 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnAuthRequiredResponses) {
d2->auth_credentials.reset(new net::AuthCredentials(username, password2));
deltas.push_back(d2);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
net::AuthCredentials auth2;
credentials_set = MergeOnAuthRequiredResponses(
- deltas, &auth2, &conflicting_extensions, &net_log);
+ deltas, &auth2, &warning_set, &net_log);
EXPECT_TRUE(credentials_set);
EXPECT_FALSE(auth2.Empty());
EXPECT_EQ(username, auth1.username());
EXPECT_EQ(password, auth1.password());
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(2u, capturing_net_log.GetSize());
// Check that we can set identical AuthCredentials twice without causing
@@ -1626,17 +1639,18 @@ TEST(ExtensionWebRequestHelpersTest, TestMergeOnAuthRequiredResponses) {
d3->auth_credentials.reset(new net::AuthCredentials(username, password));
deltas.push_back(d3);
deltas.sort(&InDecreasingExtensionInstallationTimeOrder);
- conflicting_extensions.clear();
+ warning_set.clear();
capturing_net_log.Clear();
net::AuthCredentials auth3;
credentials_set = MergeOnAuthRequiredResponses(
- deltas, &auth3, &conflicting_extensions, &net_log);
+ deltas, &auth3, &warning_set, &net_log);
EXPECT_TRUE(credentials_set);
EXPECT_FALSE(auth3.Empty());
EXPECT_EQ(username, auth1.username());
EXPECT_EQ(password, auth1.password());
- EXPECT_EQ(1u, conflicting_extensions.size());
- EXPECT_TRUE(ContainsKey(conflicting_extensions, "extid2"));
+ EXPECT_EQ(1u, warning_set.size());
+ EXPECT_TRUE(HasWarning(warning_set, "extid2"));
EXPECT_EQ(3u, capturing_net_log.GetSize());
}
+} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698