| OLD | NEW |
| 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 "chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_
registry.h" | 5 #include "chrome/browser/extensions/api/declarative_webrequest/webrequest_rules_
registry.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/memory/linked_ptr.h" | 9 #include "base/memory/linked_ptr.h" |
| 10 #include "base/message_loop.h" | 10 #include "base/message_loop.h" |
| (...skipping 320 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 331 | 331 |
| 332 std::vector<linked_ptr<RulesRegistry::Rule> > rules_to_add_2(1); | 332 std::vector<linked_ptr<RulesRegistry::Rule> > rules_to_add_2(1); |
| 333 rules_to_add_2[0] = CreateRedirectRule("http://www.bar.com"); | 333 rules_to_add_2[0] = CreateRedirectRule("http://www.bar.com"); |
| 334 error = registry->AddRules(kExtensionId2, rules_to_add_2); | 334 error = registry->AddRules(kExtensionId2, rules_to_add_2); |
| 335 EXPECT_EQ("", error); | 335 EXPECT_EQ("", error); |
| 336 | 336 |
| 337 GURL url("http://www.google.com"); | 337 GURL url("http://www.google.com"); |
| 338 TestURLRequestContext context; | 338 TestURLRequestContext context; |
| 339 TestURLRequest request(url, NULL, &context); | 339 TestURLRequest request(url, NULL, &context); |
| 340 std::list<LinkedPtrEventResponseDelta> deltas = | 340 std::list<LinkedPtrEventResponseDelta> deltas = |
| 341 registry->CreateDeltas(NULL, &request, ON_BEFORE_REQUEST, | 341 registry->CreateDeltas(NULL, NULL, &request, false, ON_BEFORE_REQUEST, |
| 342 WebRequestRule::OptionalRequestData()); | 342 WebRequestRule::OptionalRequestData()); |
| 343 | 343 |
| 344 // The second extension is installed later and will win for this reason | 344 // The second extension is installed later and will win for this reason |
| 345 // in conflict resolution. | 345 // in conflict resolution. |
| 346 ASSERT_EQ(2u, deltas.size()); | 346 ASSERT_EQ(2u, deltas.size()); |
| 347 deltas.sort(&helpers::InDecreasingExtensionInstallationTimeOrder); | 347 deltas.sort(&helpers::InDecreasingExtensionInstallationTimeOrder); |
| 348 | 348 |
| 349 std::list<LinkedPtrEventResponseDelta>::iterator i = deltas.begin(); | 349 std::list<LinkedPtrEventResponseDelta>::iterator i = deltas.begin(); |
| 350 LinkedPtrEventResponseDelta winner = *i++; | 350 LinkedPtrEventResponseDelta winner = *i++; |
| 351 LinkedPtrEventResponseDelta loser = *i; | 351 LinkedPtrEventResponseDelta loser = *i; |
| (...skipping 27 matching lines...) Expand all Loading... |
| 379 | 379 |
| 380 std::vector<linked_ptr<RulesRegistry::Rule> > rules_to_add_3(1); | 380 std::vector<linked_ptr<RulesRegistry::Rule> > rules_to_add_3(1); |
| 381 rules_to_add_3[0] = CreateIgnoreRule(); | 381 rules_to_add_3[0] = CreateIgnoreRule(); |
| 382 error = registry->AddRules(kExtensionId, rules_to_add_3); | 382 error = registry->AddRules(kExtensionId, rules_to_add_3); |
| 383 EXPECT_EQ("", error); | 383 EXPECT_EQ("", error); |
| 384 | 384 |
| 385 GURL url("http://www.google.com/index.html"); | 385 GURL url("http://www.google.com/index.html"); |
| 386 TestURLRequestContext context; | 386 TestURLRequestContext context; |
| 387 TestURLRequest request(url, NULL, &context); | 387 TestURLRequest request(url, NULL, &context); |
| 388 std::list<LinkedPtrEventResponseDelta> deltas = | 388 std::list<LinkedPtrEventResponseDelta> deltas = |
| 389 registry->CreateDeltas(NULL, &request, ON_BEFORE_REQUEST, | 389 registry->CreateDeltas(NULL, NULL, &request, false, ON_BEFORE_REQUEST, |
| 390 WebRequestRule::OptionalRequestData()); | 390 WebRequestRule::OptionalRequestData()); |
| 391 | 391 |
| 392 // The redirect by the first extension is ignored due to the ignore rule. | 392 // The redirect by the first extension is ignored due to the ignore rule. |
| 393 ASSERT_EQ(1u, deltas.size()); | 393 ASSERT_EQ(1u, deltas.size()); |
| 394 LinkedPtrEventResponseDelta effective_rule = *(deltas.begin()); | 394 LinkedPtrEventResponseDelta effective_rule = *(deltas.begin()); |
| 395 | 395 |
| 396 EXPECT_EQ(kExtensionId2, effective_rule->extension_id); | 396 EXPECT_EQ(kExtensionId2, effective_rule->extension_id); |
| 397 EXPECT_EQ(base::Time() + base::TimeDelta::FromDays(2), | 397 EXPECT_EQ(base::Time() + base::TimeDelta::FromDays(2), |
| 398 effective_rule->extension_install_time); | 398 effective_rule->extension_install_time); |
| 399 EXPECT_EQ(GURL("http://www.bar.com"), effective_rule->new_url); | 399 EXPECT_EQ(GURL("http://www.bar.com"), effective_rule->new_url); |
| 400 } | 400 } |
| 401 } // namespace extensions | 401 } // namespace extensions |
| OLD | NEW |