summaryrefslogtreecommitdiffstats
path: root/chrome/common
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/common')
-rw-r--r--chrome/common/json_value_serializer.h10
-rw-r--r--chrome/common/pref_service_uitest.cc46
-rw-r--r--chrome/common/temp_scaffolding_stubs.cc6
3 files changed, 34 insertions, 28 deletions
diff --git a/chrome/common/json_value_serializer.h b/chrome/common/json_value_serializer.h
index 92bd069..2c71e47 100644
--- a/chrome/common/json_value_serializer.h
+++ b/chrome/common/json_value_serializer.h
@@ -2,8 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_COMMON_JSON_VALUE_SERIALIZER_H__
-#define CHROME_COMMON_JSON_VALUE_SERIALIZER_H__
+#ifndef CHROME_COMMON_JSON_VALUE_SERIALIZER_H_
+#define CHROME_COMMON_JSON_VALUE_SERIALIZER_H_
#include <string>
@@ -67,7 +67,7 @@ class JSONFileValueSerializer : public ValueSerializer {
// deserialization or the destination of the serialization.
// When deserializing, the file should exist, but when serializing, the
// serializer will attempt to create the file at the specified location.
- JSONFileValueSerializer(const FilePath& json_file_path)
+ explicit JSONFileValueSerializer(const FilePath& json_file_path)
: json_file_path_(json_file_path) {}
~JSONFileValueSerializer() {}
@@ -92,7 +92,7 @@ class JSONFileValueSerializer : public ValueSerializer {
private:
FilePath json_file_path_;
- DISALLOW_EVIL_CONSTRUCTORS(JSONFileValueSerializer);
+ DISALLOW_IMPLICIT_CONSTRUCTORS(JSONFileValueSerializer);
};
-#endif // CHROME_COMMON_JSON_VALUE_SERIALIZER_H__
+#endif // CHROME_COMMON_JSON_VALUE_SERIALIZER_H_
diff --git a/chrome/common/pref_service_uitest.cc b/chrome/common/pref_service_uitest.cc
index 61d6506..e5da154 100644
--- a/chrome/common/pref_service_uitest.cc
+++ b/chrome/common/pref_service_uitest.cc
@@ -8,6 +8,7 @@
#include "base/file_path.h"
#include "base/file_util.h"
#include "base/values.h"
+#include "build/build_config.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/json_value_serializer.h"
@@ -20,32 +21,34 @@ class PreferenceServiceTest : public UITest {
public:
void SetUp() {
PathService::Get(base::DIR_TEMP, &tmp_profile_);
- file_util::AppendToPath(&tmp_profile_, L"tmp_profile");
+ tmp_profile_ = tmp_profile_.AppendASCII("tmp_profile");
// Create a fresh, empty copy of this directory.
file_util::Delete(tmp_profile_, true);
- ::CreateDirectory(tmp_profile_.c_str(), NULL);
+ file_util::CreateDirectory(tmp_profile_);
- std::wstring reference_pref_file(test_data_directory_);
- file_util::AppendToPath(&reference_pref_file, L"profiles");
- file_util::AppendToPath(&reference_pref_file, L"window_placement");
- file_util::AppendToPath(&reference_pref_file, chrome::kLocalStateFilename);
+ FilePath reference_pref_file =
+ FilePath::FromWStringHack(test_data_directory_)
+ .AppendASCII("profiles")
+ .AppendASCII("window_placement")
+ .Append(chrome::kLocalStateFilename);
- tmp_pref_file_ = tmp_profile_;
- file_util::AppendToPath(&tmp_pref_file_, chrome::kLocalStateFilename);
+ tmp_pref_file_ = tmp_profile_.Append(chrome::kLocalStateFilename);
ASSERT_TRUE(file_util::PathExists(reference_pref_file));
// Copy only the Local State file, the rest will be automatically created
- ASSERT_TRUE(::CopyFileW(reference_pref_file.c_str(), tmp_pref_file_.c_str(),
- TRUE));
+ ASSERT_TRUE(file_util::CopyFile(reference_pref_file, tmp_pref_file_));
- // Make the copy writable
- ASSERT_TRUE(::SetFileAttributesW(tmp_pref_file_.c_str(),
+#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_.AppendSwitchWithValue(switches::kUserDataDir,
- tmp_profile_);
+ tmp_profile_.ToWStringHack());
}
bool LaunchAppWithProfile() {
@@ -62,18 +65,25 @@ public:
}
public:
- std::wstring tmp_pref_file_;
- std::wstring tmp_profile_;
+ FilePath tmp_pref_file_;
+ FilePath tmp_profile_;
};
+#if defined(OS_WIN)
+// 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.
+// Also, not sure what should happen on the mac. In any case, the code below
+// (minus the Windows bits) compiles fine on my Linux box now.
+// TODO(port): revisit this.
TEST_F(PreferenceServiceTest, PreservedWindowPlacementIsLoaded) {
// The window should open with the reference profile
ASSERT_TRUE(LaunchAppWithProfile());
ASSERT_TRUE(file_util::PathExists(tmp_pref_file_));
- JSONFileValueSerializer deserializer =
- FilePath::FromWStringHack(tmp_pref_file_);
+ JSONFileValueSerializer deserializer(tmp_pref_file_);
scoped_ptr<Value> root(deserializer.Deserialize(NULL));
ASSERT_TRUE(root.get());
@@ -85,6 +95,7 @@ TEST_F(PreferenceServiceTest, PreservedWindowPlacementIsLoaded) {
scoped_ptr<BrowserProxy> browser(automation()->GetBrowserWindow(0));
ASSERT_TRUE(browser.get());
scoped_ptr<WindowProxy> window(browser->GetWindow());
+
HWND hWnd;
ASSERT_TRUE(window->GetHWND(&hWnd));
@@ -121,3 +132,4 @@ TEST_F(PreferenceServiceTest, PreservedWindowPlacementIsLoaded) {
&is_maximized));
ASSERT_EQ(is_maximized, is_window_maximized);
}
+#endif
diff --git a/chrome/common/temp_scaffolding_stubs.cc b/chrome/common/temp_scaffolding_stubs.cc
index 73191cb..1ee64ea 100644
--- a/chrome/common/temp_scaffolding_stubs.cc
+++ b/chrome/common/temp_scaffolding_stubs.cc
@@ -47,12 +47,6 @@
//--------------------------------------------------------------------------
-WebContents* AutomationProvider::GetWebContentsForHandle(
- int handle, NavigationController** tab) {
- NOTIMPLEMENTED();
- return NULL;
-}
-
void AutomationProvider::GetActiveWindow(int* handle) { NOTIMPLEMENTED(); }
void AutomationProvider::IsWindowActive(int handle, bool* success,