// Copyright (c) 2011 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 <string> #include "base/command_line.h" #include "base/file_util.h" #include "base/test/test_file_util.h" #include "base/values.h" #include "base/memory/scoped_temp_dir.h" #include "build/build_config.h" #include "chrome/common/chrome_constants.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/pref_names.h" #include "chrome/test/automation/browser_proxy.h" #include "chrome/test/automation/window_proxy.h" #include "chrome/test/ui/ui_test.h" #include "content/common/json_value_serializer.h" #include "ui/gfx/rect.h" class PreferenceServiceTest : public UITest { public: void SetUp() { ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); FilePath tmp_profile = temp_dir_.path().AppendASCII("tmp_profile"); ASSERT_TRUE(file_util::CreateDirectory(tmp_profile)); FilePath reference_pref_file; if (new_profile_) { reference_pref_file = test_data_directory_ .AppendASCII("profiles") .AppendASCII("window_placement") .AppendASCII("Default") .Append(chrome::kPreferencesFilename); tmp_pref_file_ = tmp_profile.AppendASCII("Default"); ASSERT_TRUE(file_util::CreateDirectory(tmp_pref_file_)); tmp_pref_file_ = tmp_pref_file_.Append(chrome::kPreferencesFilename); } else { reference_pref_file = test_data_directory_ .AppendASCII("profiles") .AppendASCII("window_placement") .Append(chrome::kLocalStateFilename); tmp_pref_file_ = tmp_profile.Append(chrome::kLocalStateFilename); } ASSERT_TRUE(file_util::PathExists(reference_pref_file)); // Copy only the Preferences file if |new_profile_|, or Local State if not, // and the rest will be automatically created. ASSERT_TRUE(file_util::CopyFile(reference_pref_file, tmp_pref_file_)); #if defined(OS_WIN) // Make the copy writable. On POSIX we assume the umask allows files // we create to be writable. ASSERT_TRUE(::SetFileAttributesW(tmp_pref_file_.value().c_str(), FILE_ATTRIBUTE_NORMAL)); #endif launch_arguments_.AppendSwitchPath(switches::kUserDataDir, tmp_profile); } bool LaunchAppWithProfile() { if (!file_util::PathExists(tmp_pref_file_)) return false; UITest::SetUp(); return true; } void TearDown() { UITest::TearDown(); } public: bool new_profile_; FilePath tmp_pref_file_; private: ScopedTempDir temp_dir_; }; #if !defined(OS_LINUX) // This test verifies that the window position from the prefs file is restored // when the app restores. This doesn't really make sense on Linux, where // the window manager might fight with you over positioning. However, we // might be able to make this work on buildbots. // TODO(port): revisit this. TEST_F(PreferenceServiceTest, PreservedWindowPlacementIsLoaded) { // The window should open with the new reference profile, with window // placement values stored in the user data directory. new_profile_ = true; ASSERT_TRUE(LaunchAppWithProfile()); ASSERT_TRUE(file_util::PathExists(tmp_pref_file_)); JSONFileValueSerializer deserializer(tmp_pref_file_); scoped_ptr<Value> root(deserializer.Deserialize(NULL, NULL)); ASSERT_TRUE(root.get()); ASSERT_TRUE(root->IsType(Value::TYPE_DICTIONARY)); DictionaryValue* root_dict = static_cast<DictionaryValue*>(root.get()); // Retrieve the screen rect for the launched window scoped_refptr<BrowserProxy> browser(automation()->GetBrowserWindow(0)); ASSERT_TRUE(browser.get()); scoped_refptr<WindowProxy> window(browser->GetWindow()); ASSERT_TRUE(window.get()); gfx::Rect bounds; ASSERT_TRUE(window->GetBounds(&bounds)); // Retrieve the expected rect values from "Preferences" int bottom = 0; std::string kBrowserWindowPlacement(prefs::kBrowserWindowPlacement); EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".bottom", &bottom)); EXPECT_EQ(bottom, bounds.y() + bounds.height()); int top = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".top", &top)); EXPECT_EQ(top, bounds.y()); int left = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".left", &left)); EXPECT_EQ(left, bounds.x()); int right = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".right", &right)); EXPECT_EQ(right, bounds.x() + bounds.width()); // Find if launched window is maximized. bool is_window_maximized = false; ASSERT_TRUE(window->IsMaximized(&is_window_maximized)); bool is_maximized = false; EXPECT_TRUE(root_dict->GetBoolean(kBrowserWindowPlacement + ".maximized", &is_maximized)); EXPECT_EQ(is_maximized, is_window_maximized); } #endif #if !defined(OS_LINUX) TEST_F(PreferenceServiceTest, PreservedWindowPlacementIsMigrated) { // The window should open with the old reference profile, with window // placement values stored in Local State. new_profile_ = false; ASSERT_TRUE(LaunchAppWithProfile()); ASSERT_TRUE(file_util::PathExists(tmp_pref_file_)); JSONFileValueSerializer deserializer(tmp_pref_file_); scoped_ptr<Value> root(deserializer.Deserialize(NULL, NULL)); ASSERT_TRUE(root.get()); ASSERT_TRUE(root->IsType(Value::TYPE_DICTIONARY)); // Retrieve the screen rect for the launched window scoped_refptr<BrowserProxy> browser(automation()->GetBrowserWindow(0)); ASSERT_TRUE(browser.get()); scoped_refptr<WindowProxy> window(browser->GetWindow()); ASSERT_TRUE(window.get()); gfx::Rect bounds; ASSERT_TRUE(window->GetBounds(&bounds)); // Values from old reference profile in Local State should have been // correctly migrated to the user's Preferences -- if so, the window // should be set to values taken from the user's Local State. DictionaryValue* root_dict = static_cast<DictionaryValue*>(root.get()); // Retrieve the expected rect values from User Preferences, where they // should have been migrated from Local State. int bottom = 0; std::string kBrowserWindowPlacement(prefs::kBrowserWindowPlacement); EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".bottom", &bottom)); EXPECT_EQ(bottom, bounds.y() + bounds.height()); int top = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".top", &top)); EXPECT_EQ(top, bounds.y()); int left = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".left", &left)); EXPECT_EQ(left, bounds.x()); int right = 0; EXPECT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + ".right", &right)); EXPECT_EQ(right, bounds.x() + bounds.width()); // Find if launched window is maximized. bool is_window_maximized = false; ASSERT_TRUE(window->IsMaximized(&is_window_maximized)); bool is_maximized = false; EXPECT_TRUE(root_dict->GetBoolean(kBrowserWindowPlacement + ".maximized", &is_maximized)); EXPECT_EQ(is_maximized, is_window_maximized); } #endif