// Copyright 2013 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 "extensions/browser/api/declarative/rules_registry.h" #include #include "base/message_loop/message_loop.h" #include "content/public/test/test_browser_thread.h" #include "extensions/browser/api/declarative/rules_registry_service.h" #include "extensions/browser/api/declarative/test_rules_registry.h" #include "testing/gtest/include/gtest/gtest.h" namespace { const char kExtensionId[] = "foobar"; const char kRuleId[] = "foo"; const int key = extensions::RulesRegistryService::kDefaultRulesRegistryID; } // namespace namespace extensions { TEST(RulesRegistryTest, FillOptionalIdentifiers) { base::MessageLoopForUI message_loop; content::TestBrowserThread thread(content::BrowserThread::UI, &message_loop); std::string error; scoped_refptr registry = new TestRulesRegistry(content::BrowserThread::UI, "" /*event_name*/, key); // Add rules and check that their identifiers are filled and unique. std::vector > add_rules; add_rules.push_back(make_linked_ptr(new RulesRegistry::Rule)); add_rules.push_back(make_linked_ptr(new RulesRegistry::Rule)); error = registry->AddRules(kExtensionId, add_rules); EXPECT_TRUE(error.empty()) << error; std::vector > get_rules; registry->GetAllRules(kExtensionId, &get_rules); ASSERT_EQ(2u, get_rules.size()); ASSERT_TRUE(get_rules[0]->id.get()); EXPECT_NE("", *get_rules[0]->id); ASSERT_TRUE(get_rules[1]->id.get()); EXPECT_NE("", *get_rules[1]->id); EXPECT_NE(*get_rules[0]->id, *get_rules[1]->id); EXPECT_EQ(1u /*extensions*/ + 2u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); // Check that we cannot add a new rule with the same ID. std::vector > add_rules_2; add_rules_2.push_back(make_linked_ptr(new RulesRegistry::Rule)); add_rules_2[0]->id.reset(new std::string(*get_rules[0]->id)); error = registry->AddRules(kExtensionId, add_rules_2); EXPECT_FALSE(error.empty()); std::vector > get_rules_2; registry->GetAllRules(kExtensionId, &get_rules_2); ASSERT_EQ(2u, get_rules_2.size()); EXPECT_EQ(1u /*extensions*/ + 2u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); // Check that we can register the old rule IDs once they were unregistered. std::vector remove_rules_3; remove_rules_3.push_back(*get_rules[0]->id); error = registry->RemoveRules(kExtensionId, remove_rules_3); EXPECT_TRUE(error.empty()) << error; EXPECT_EQ(1u /*extensions*/ + 1u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); std::vector > get_rules_3a; registry->GetAllRules(kExtensionId, &get_rules_3a); ASSERT_EQ(1u, get_rules_3a.size()); std::vector > add_rules_3; add_rules_3.push_back(make_linked_ptr(new RulesRegistry::Rule)); add_rules_3[0]->id.reset(new std::string(*get_rules[0]->id)); error = registry->AddRules(kExtensionId, add_rules_3); EXPECT_TRUE(error.empty()) << error; EXPECT_EQ(1u /*extensions*/ + 2u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); std::vector > get_rules_3b; registry->GetAllRules(kExtensionId, &get_rules_3b); ASSERT_EQ(2u, get_rules_3b.size()); // Check that we can register a rule with an ID that is not modified. error = registry->RemoveAllRules(kExtensionId); EXPECT_TRUE(error.empty()) << error; EXPECT_EQ(0u /*extensions*/ + 0u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); std::vector > get_rules_4a; registry->GetAllRules(kExtensionId, &get_rules_4a); ASSERT_TRUE(get_rules_4a.empty()); std::vector > add_rules_4; add_rules_4.push_back(make_linked_ptr(new RulesRegistry::Rule)); add_rules_4[0]->id.reset(new std::string(kRuleId)); error = registry->AddRules(kExtensionId, add_rules_4); EXPECT_TRUE(error.empty()) << error; EXPECT_EQ(1u /*extensions*/ + 1u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); std::vector > get_rules_4b; registry->GetAllRules(kExtensionId, &get_rules_4b); ASSERT_EQ(1u, get_rules_4b.size()); ASSERT_TRUE(get_rules_4b[0]->id.get()); EXPECT_EQ(kRuleId, *get_rules_4b[0]->id); registry->OnExtensionUninstalled(kExtensionId); EXPECT_EQ(0u /*extensions*/ + 0u /*rules*/, registry->GetNumberOfUsedRuleIdentifiersForTesting()); // Make sure that deletion traits of registry are executed. registry = NULL; message_loop.RunUntilIdle(); } TEST(RulesRegistryTest, FillOptionalPriority) { base::MessageLoopForUI message_loop; content::TestBrowserThread thread(content::BrowserThread::UI, &message_loop); std::string error; scoped_refptr registry = new TestRulesRegistry(content::BrowserThread::UI, "" /*event_name*/, key); // Add rules and check that their priorities are filled if they are empty. std::vector > add_rules; add_rules.push_back(make_linked_ptr(new RulesRegistry::Rule)); add_rules[0]->priority.reset(new int(2)); add_rules.push_back(make_linked_ptr(new RulesRegistry::Rule)); error = registry->AddRules(kExtensionId, add_rules); EXPECT_TRUE(error.empty()) << error; std::vector > get_rules; registry->GetAllRules(kExtensionId, &get_rules); ASSERT_EQ(2u, get_rules.size()); ASSERT_TRUE(get_rules[0]->priority.get()); ASSERT_TRUE(get_rules[1]->priority.get()); // Verify the precondition so that the following EXPECT_EQ statements work. EXPECT_GT(RulesRegistry::DEFAULT_PRIORITY, 2); EXPECT_EQ(2, std::min(*get_rules[0]->priority, *get_rules[1]->priority)); EXPECT_EQ(RulesRegistry::DEFAULT_PRIORITY, std::max(*get_rules[0]->priority, *get_rules[1]->priority)); // Make sure that deletion traits of registry are executed. registry = NULL; message_loop.RunUntilIdle(); } } // namespace extensions