Chromium Code Reviews| Index: chrome/browser/media_gallery/media_galleries_preferences_unittest.cc |
| diff --git a/chrome/browser/media_gallery/media_galleries_preferences_unittest.cc b/chrome/browser/media_gallery/media_galleries_preferences_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..2610921ef21252370488c4f093824abde2c85cdd |
| --- /dev/null |
| +++ b/chrome/browser/media_gallery/media_galleries_preferences_unittest.cc |
| @@ -0,0 +1,325 @@ |
| +// 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. |
| + |
| +// MediaGalleriesPreferences unit tests. |
| + |
| +#include "chrome/browser/media_gallery/media_galleries_preferences.h" |
| + |
| +#include "base/command_line.h" |
| +#include "base/file_util.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "base/message_loop.h" |
| +#include "base/utf_string_conversions.h" |
| +#include "base/values.h" |
| +#include "chrome/browser/extensions/extension_service.h" |
| +#include "chrome/browser/extensions/extension_system.h" |
| +#include "chrome/browser/extensions/test_extension_system.h" |
| +#include "chrome/browser/media_gallery/media_file_system_registry.h" |
| +#include "chrome/common/chrome_switches.h" |
| +#include "chrome/common/extensions/extension.h" |
| +#include "chrome/common/extensions/extension_manifest_constants.h" |
| +#include "chrome/test/base/testing_profile.h" |
| +#include "content/public/test/test_browser_thread.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace chrome { |
| + |
| +namespace { |
| + |
| +class TestMediaGalleriesPreferences : public MediaGalleriesPreferences { |
| + public: |
| + static string16 GetDisplayNameForPath(const FilePath& path) { |
| + return MediaGalleriesPreferences::ComputeDisplayName(path); |
| + } |
| +}; |
| + |
| +class MediaGalleriesPreferencesTest : public testing::Test { |
| + public: |
| + MediaGalleriesPreferencesTest() |
| + : ui_thread_(content::BrowserThread::UI, &loop_), |
| + file_thread_(content::BrowserThread::FILE, &loop_), |
| + profile_(new TestingProfile()), |
| + extension_service_(NULL) { |
| + } |
| + |
| + virtual ~MediaGalleriesPreferencesTest() {} |
| + |
| + virtual void SetUp() OVERRIDE { |
| + CommandLine::ForCurrentProcess()->AppendSwitch( |
| + switches::kEnableMediaGalleryUI); |
| + extensions_dir_ = profile_->GetPath().AppendASCII("Extensions"); |
| + ASSERT_TRUE(file_util::CreateDirectory(extensions_dir_)); |
| + |
| + extensions::TestExtensionSystem* extension_system( |
| + static_cast<extensions::TestExtensionSystem*>( |
| + extensions::ExtensionSystem::Get(profile_.get()))); |
| + extension_service_ = extension_system->CreateExtensionService( |
| + CommandLine::ForCurrentProcess(), extensions_dir_, false); |
| + |
| + MediaGalleriesPreferences::RegisterUserPrefs(profile_->GetPrefs()); |
| + gallery_prefs_.reset(new MediaGalleriesPreferences(profile_.get())); |
| + |
| + // Load the default galleries into the expectations. |
| + if (gallery_prefs_->known_galleries().size()) { |
| + const MediaGalleriesPrefInfoMap& known_galleries = |
| + gallery_prefs_->known_galleries(); |
| + ASSERT_EQ(1U, known_galleries.size()); |
| + MediaGalleriesPrefInfoMap::const_iterator it = known_galleries.begin(); |
| + expected_galleries_[it->first] = it->second; |
| + } |
| + |
| + std::vector<std::string> read_permissions; |
| + read_permissions.push_back("mediaGalleriesRead"); |
| + std::vector<std::string> all_permissions; |
| + read_permissions.push_back("mediaGalleriesAllGalleries"); |
| + read_permissions.push_back("mediaGalleriesRead"); |
| + |
| + all_permission_extension = AddExtension("all", all_permissions); |
| + regular_permission_extension = AddExtension("regular", read_permissions); |
| + no_permissions_extension = AddExtension("no", read_permissions); |
| + } |
| + |
| + virtual void TearDown() OVERRIDE { |
| + Verify(); |
| + } |
| + |
| + void Verify() { |
| + const MediaGalleriesPrefInfoMap& known_galleries = |
| + gallery_prefs_->known_galleries(); |
| + EXPECT_EQ(expected_galleries_.size(), known_galleries.size()); |
| + for (MediaGalleriesPrefInfoMap::const_iterator it = known_galleries.begin(); |
| + it != known_galleries.end(); |
| + ++it) { |
| + VerifyGalleryInfo(&it->second, it->first); |
| + } |
| + |
| + std::set<MediaGalleryPrefId> galleries_for_all = |
| + gallery_prefs_->GalleriesForExtension(*all_permission_extension.get()); |
| + EXPECT_EQ(expected_galleries_for_all, galleries_for_all); |
| +printf("All: %zu\n", galleries_for_all.size()); |
|
Lei Zhang
2012/08/03 19:22:04
debug code?
vandebo (ex-Chrome)
2012/08/03 20:27:27
Yea, tests are still coming along. Removed.
|
| + |
| + std::set<MediaGalleryPrefId> galleries_for_regular = |
| + gallery_prefs_->GalleriesForExtension( |
| + *regular_permission_extension.get()); |
| + EXPECT_EQ(expected_galleries_for_regular, galleries_for_regular); |
| + |
| + std::set<MediaGalleryPrefId> galleries_for_no = |
| + gallery_prefs_->GalleriesForExtension(*no_permissions_extension.get()); |
| + EXPECT_EQ(0U, galleries_for_no.size()); |
| + } |
| + |
| + void VerifyGalleryInfo(const MediaGalleryPrefInfo* actual, |
| + MediaGalleryPrefId expected_id) const { |
| + MediaGalleriesPrefInfoMap::const_iterator in_expectation = |
| + expected_galleries_.find(expected_id); |
| + EXPECT_NE(in_expectation, expected_galleries_.end()); |
| + EXPECT_EQ(in_expectation->second.pref_id, actual->pref_id); |
| + EXPECT_EQ(in_expectation->second.display_name, actual->display_name); |
| + EXPECT_EQ(in_expectation->second.device_id, actual->device_id); |
| + EXPECT_EQ(in_expectation->second.path.value(), actual->path.value()); |
| + EXPECT_EQ(in_expectation->second.type, actual->type); |
| + } |
| + |
| + MediaGalleriesPreferences* gallery_prefs() { |
| + return gallery_prefs_.get(); |
| + } |
| + |
| + void AddGalleryExpectation(MediaGalleryPrefId id, std::string display_name, |
| + std::string device_id, FilePath::StringType path, |
| + MediaGalleryPrefInfo::Type type) { |
| + expected_galleries_[id].pref_id = id; |
| + expected_galleries_[id].display_name = ASCIIToUTF16(display_name); |
| + expected_galleries_[id].device_id = device_id; |
| + expected_galleries_[id].path = FilePath(path); |
| + expected_galleries_[id].type = type; |
| + |
| + if (type == MediaGalleryPrefInfo::kAutoDetected) |
| + expected_galleries_for_all.insert(id); |
| + } |
| + |
| + scoped_refptr<extensions::Extension> all_permission_extension; |
| + scoped_refptr<extensions::Extension> regular_permission_extension; |
| + scoped_refptr<extensions::Extension> no_permissions_extension; |
| + |
| + std::set<MediaGalleryPrefId> expected_galleries_for_all; |
| + std::set<MediaGalleryPrefId> expected_galleries_for_regular; |
| + |
| + MediaGalleriesPrefInfoMap expected_galleries_; |
| + |
| + private: |
| + scoped_refptr<extensions::Extension> AddExtension( |
| + std::string name, |
| + std::vector<std::string> permissions) { |
| + scoped_ptr<DictionaryValue> manifest(new DictionaryValue); |
| + manifest->SetString(extension_manifest_keys::kName, name); |
| + manifest->SetString(extension_manifest_keys::kVersion, "0.1"); |
| + ListValue* permission_list = new ListValue;; |
| + for (size_t i = 0; i < permissions.size(); i++) |
| + permission_list->Append(Value::CreateStringValue(permissions[i])); |
| + manifest->Set(extension_manifest_keys::kPermissions, permission_list); |
| + |
| + FilePath path = extensions_dir_.AppendASCII(name); |
| + std::string errors; |
| + scoped_refptr<extensions::Extension> extension = |
| + extensions::Extension::Create(path, |
| + extensions::Extension::INTERNAL, |
| + *manifest.get(), |
| + extensions::Extension::NO_FLAGS, |
| + &errors); |
| + EXPECT_TRUE(extension.get() != NULL); |
| + EXPECT_TRUE(extensions::Extension::IdIsValid(extension->id())); |
| + if (!extension.get() || |
| + !extensions::Extension::IdIsValid(extension->id())) { |
| + return NULL; |
| + } |
| + |
| + extension_service_->extension_prefs()->OnExtensionInstalled( |
| + extension, extensions::Extension::ENABLED, false, |
| + StringOrdinal::CreateInitialOrdinal()); |
| + |
| + return extension; |
| + } |
| + |
| + // Needed for extension service & friends to work. |
| + MessageLoop loop_; |
| + content::TestBrowserThread ui_thread_; |
| + content::TestBrowserThread file_thread_; |
| + |
| + scoped_ptr<TestingProfile> profile_; |
| + scoped_ptr<MediaGalleriesPreferences> gallery_prefs_; |
| + FilePath extensions_dir_; |
| + ExtensionService* extension_service_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(MediaGalleriesPreferencesTest); |
| +}; |
| + |
| +FilePath MakePath(std::string dir) { |
| +#if defined(OS_WINDOWS) |
| + return FilePath(FILE_PATH_LITERAL("C:")).Append(UTF8ToWide(dir)); |
| +#elif defined(OS_POSIX) |
| + return FilePath(FILE_PATH_LITERAL("/")).Append(dir); |
| +#else |
| + NOTREACHED(); |
| +#endif |
| +} |
| + |
| +TEST_F(MediaGalleriesPreferencesTest, DISABLED_GalleryManagement) { |
| + MediaGalleryPrefId auto_id, user_added_id, id; |
| + FilePath path; |
| + std::string device_id; |
| + ASSERT_EQ(1UL, gallery_prefs()->known_galleries().begin()->first); |
| + Verify(); |
| + |
| + // Add a new auto detected gallery. |
| + path = MakePath("new_auto"); |
| + device_id = MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path); |
| + id = gallery_prefs()->AddGallery(device_id, ASCIIToUTF16("NewAutoGallery"), |
| + path, false /*auto*/); |
| + EXPECT_EQ(2UL, id); |
| + auto_id = id; |
| + AddGalleryExpectation(id, "NewAutoGallery", device_id, |
| + FILE_PATH_LITERAL("new_auto"), |
| + MediaGalleryPrefInfo::kAutoDetected); |
| + Verify(); |
| + |
| + // Add it again (as user), nothing should happen. |
| + id = gallery_prefs()->AddGallery(device_id, ASCIIToUTF16("NewAutoGallery"), |
| + path, true /*user*/); |
| + EXPECT_EQ(auto_id, id); |
| + Verify(); |
| + |
| + // Add a new user added gallery. |
| + path = MakePath("new_user"); |
| + device_id = MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path); |
| + id = gallery_prefs()->AddGallery(device_id, ASCIIToUTF16("NewUserGallery"), |
| + path, true /*user*/); |
| + EXPECT_EQ(3UL, id); |
| + user_added_id = id; |
| + AddGalleryExpectation(id, "NewUserGallery", device_id, |
| + FILE_PATH_LITERAL("new_user"), |
| + MediaGalleryPrefInfo::kUserAdded); |
| + Verify(); |
| + |
| + // Lookup some galleries. |
| + EXPECT_TRUE(gallery_prefs()->LookUpGalleryByPath(MakePath("new_auto"), NULL)); |
| + EXPECT_TRUE(gallery_prefs()->LookUpGalleryByPath(MakePath("new_user"), NULL)); |
| + EXPECT_FALSE(gallery_prefs()->LookUpGalleryByPath(MakePath("other"), NULL)); |
| + |
| + // Check that we always get the gallery info. |
| + MediaGalleryPrefInfo gallery_info; |
| + EXPECT_TRUE(gallery_prefs()->LookUpGalleryByPath(MakePath("new_auto"), |
| + &gallery_info)); |
| + VerifyGalleryInfo(&gallery_info, auto_id); |
| + EXPECT_TRUE(gallery_prefs()->LookUpGalleryByPath(MakePath("new_user"), |
| + &gallery_info)); |
| + VerifyGalleryInfo(&gallery_info, user_added_id); |
| + |
| + path = MakePath("other"); |
| + EXPECT_FALSE(gallery_prefs()->LookUpGalleryByPath(path, &gallery_info)); |
| + EXPECT_EQ(kInvalidMediaGalleryPrefId, gallery_info.pref_id); |
| + EXPECT_EQ(TestMediaGalleriesPreferences::GetDisplayNameForPath(path), |
| + gallery_info.display_name); |
| + EXPECT_EQ(MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path), |
| + gallery_info.device_id); |
| + EXPECT_EQ(FilePath(FILE_PATH_LITERAL("other")).value(), |
| + gallery_info.path.value()); |
| + |
| + // Remove an auto added gallery (i.e. make it blacklisted). |
| + gallery_prefs()->ForgetGalleryById(auto_id); |
| + expected_galleries_[auto_id].type = MediaGalleryPrefInfo::kBlackListed; |
| + Verify(); |
| + |
| + // Remove a user added gallery and it should go away. |
| + gallery_prefs()->ForgetGalleryById(user_added_id); |
| + expected_galleries_.erase(user_added_id); |
| + Verify(); |
| +} |
| + |
| +TEST_F(MediaGalleriesPreferencesTest, DISABLED_GalleryPermissions) { |
| + MediaGalleryPrefId auto_id, user_added_id, to_blacklist_id, id; |
| + FilePath path; |
| + std::string device_id; |
| + ASSERT_EQ(1UL, gallery_prefs()->known_galleries().begin()->first); |
| + Verify(); |
| + |
| + // Add some galleries to test with. |
| + path = MakePath("new_user"); |
| + device_id = MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path); |
| + id = gallery_prefs()->AddGallery(device_id, ASCIIToUTF16("NewUserGallery"), |
| + path, true /*user*/); |
| + EXPECT_EQ(2UL, id); |
| + user_added_id = id; |
| + AddGalleryExpectation(id, "NewUserGallery", device_id, |
| + FILE_PATH_LITERAL("new_user"), |
| + MediaGalleryPrefInfo::kUserAdded); |
| + Verify(); |
| + |
| + path = MakePath("new_auto"); |
| + device_id = MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path); |
| + id = gallery_prefs()->AddGallery(device_id, ASCIIToUTF16("NewAutoGallery"), |
| + path, false /*auto*/); |
| + EXPECT_EQ(3UL, id); |
| + auto_id = id; |
| + AddGalleryExpectation(id, "NewAutoGallery", device_id, |
| + FILE_PATH_LITERAL("new_auto"), |
| + MediaGalleryPrefInfo::kAutoDetected); |
| + Verify(); |
| + |
| + path = MakePath("to_blacklist"); |
| + device_id = MediaFileSystemRegistry::GetInstance()->GetDeviceIdFromPath(path); |
| + id = gallery_prefs()->AddGallery(device_id, |
| + ASCIIToUTF16("ToBlacklistGallery"), path, |
| + false /*auto*/); |
| + EXPECT_EQ(4UL, id); |
| + to_blacklist_id = id; |
| + AddGalleryExpectation(id, "ToBlacklistGallery", device_id, |
| + FILE_PATH_LITERAL("to_blacklist"), |
| + MediaGalleryPrefInfo::kAutoDetected); |
| + Verify(); |
| +} |
| + |
| +} // namespace |
| + |
| +} // namespace chrome |