// Copyright (c) 2012 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 "chrome/common/extensions/features/complex_feature.h" #include "chrome/common/extensions/features/simple_feature.h" #include "chrome/common/extensions/value_builder.h" #include "testing/gtest/include/gtest/gtest.h" using chrome::VersionInfo; using extensions::ComplexFeature; using extensions::DictionaryBuilder; using extensions::Feature; using extensions::ListBuilder; using extensions::Manifest; using extensions::SimpleFeature; namespace { class ExtensionComplexFeatureTest : public testing::Test { protected: ExtensionComplexFeatureTest() : current_channel_(VersionInfo::CHANNEL_UNKNOWN) {} virtual ~ExtensionComplexFeatureTest() {} private: Feature::ScopedCurrentChannel current_channel_; }; TEST_F(ExtensionComplexFeatureTest, MultipleRulesWhitelist) { const std::string kIdFoo("fooabbbbccccddddeeeeffffgggghhhh"); const std::string kIdBar("barabbbbccccddddeeeeffffgggghhhh"); scoped_ptr features( new ComplexFeature::FeatureList()); // Rule: "extension", whitelist "foo". scoped_ptr simple_feature(new SimpleFeature()); scoped_ptr rule( DictionaryBuilder() .Set("whitelist", ListBuilder().Append(kIdFoo)) .Set("extension_types", ListBuilder().Append("extension")).Build()); simple_feature->Parse(rule.get()); features->push_back(simple_feature.release()); // Rule: "packaged_app", whitelist "bar". simple_feature.reset(new SimpleFeature()); rule = DictionaryBuilder() .Set("whitelist", ListBuilder().Append(kIdBar)) .Set("extension_types", ListBuilder().Append("packaged_app")).Build(); simple_feature->Parse(rule.get()); features->push_back(simple_feature.release()); scoped_ptr feature(new ComplexFeature(features.Pass())); // Test match 1st rule. EXPECT_EQ(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( kIdFoo, Manifest::TYPE_EXTENSION, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); // Test match 2nd rule. EXPECT_EQ(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( kIdBar, Manifest::TYPE_LEGACY_PACKAGED_APP, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); // Test whitelist with wrong extension type. EXPECT_NE(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( kIdBar, Manifest::TYPE_EXTENSION, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); EXPECT_NE(Feature::IS_AVAILABLE, feature->IsAvailableToManifest(kIdFoo, Manifest::TYPE_LEGACY_PACKAGED_APP, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); } TEST_F(ExtensionComplexFeatureTest, MultipleRulesChannels) { scoped_ptr features( new ComplexFeature::FeatureList()); // Rule: "extension", channel trunk. scoped_ptr simple_feature(new SimpleFeature()); scoped_ptr rule( DictionaryBuilder() .Set("channel", "trunk") .Set("extension_types", ListBuilder().Append("extension")).Build()); simple_feature->Parse(rule.get()); features->push_back(simple_feature.release()); // Rule: "packaged_app", channel stable. simple_feature.reset(new SimpleFeature()); rule = DictionaryBuilder() .Set("channel", "stable") .Set("extension_types", ListBuilder().Append("packaged_app")).Build(); simple_feature->Parse(rule.get()); features->push_back(simple_feature.release()); scoped_ptr feature(new ComplexFeature(features.Pass())); // Test match 1st rule. { Feature::ScopedCurrentChannel current_channel(VersionInfo::CHANNEL_UNKNOWN); EXPECT_EQ(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( "1", Manifest::TYPE_EXTENSION, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); } // Test match 2nd rule. { Feature::ScopedCurrentChannel current_channel(VersionInfo::CHANNEL_BETA); EXPECT_EQ(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( "2", Manifest::TYPE_LEGACY_PACKAGED_APP, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); } // Test feature not available to extensions above channel unknown. { Feature::ScopedCurrentChannel current_channel(VersionInfo::CHANNEL_BETA); EXPECT_NE(Feature::IS_AVAILABLE, feature->IsAvailableToManifest( "1", Manifest::TYPE_EXTENSION, Feature::UNSPECIFIED_LOCATION, Feature::UNSPECIFIED_PLATFORM, Feature::GetCurrentPlatform()).result()); } } } // namespace