| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
 | // Copyright (c) 2006-2008 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/values.h"
#include "chrome/common/chrome_constants.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/json_value_serializer.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"
class PreferenceServiceTest : public UITest {
public:
  void SetUp() {
    PathService::Get(base::DIR_TEMP, &tmp_profile_);
    file_util::AppendToPath(&tmp_profile_, L"tmp_profile");
    // Create a fresh, empty copy of this directory.
    file_util::Delete(tmp_profile_, true);
    ::CreateDirectory(tmp_profile_.c_str(), NULL);
    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);
    tmp_pref_file_ = tmp_profile_;
    file_util::AppendToPath(&tmp_pref_file_, 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));
    // Make the copy writable
    ASSERT_TRUE(::SetFileAttributesW(tmp_pref_file_.c_str(),
        FILE_ATTRIBUTE_NORMAL));
    CommandLine::AppendSwitchWithValue(&launch_arguments_,
                                       switches::kUserDataDir,
                                       tmp_profile_);
  }
  bool LaunchAppWithProfile() {
    if (!file_util::PathExists(tmp_pref_file_))
      return false;
    UITest::SetUp();
    return true;
  }
  void TearDown() {
    UITest::TearDown();
    const int kWaitForDeleteMs = 100;
    int num_retries = 5;
    while (num_retries > 0) {
      file_util::Delete(tmp_profile_, true);
      if (!file_util::PathExists(tmp_profile_))
        break;
      --num_retries;
      Sleep(kWaitForDeleteMs);
    }
    EXPECT_FALSE(file_util::PathExists(tmp_profile_));
  }
public:
  std::wstring tmp_pref_file_;
  std::wstring tmp_profile_;
};
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(tmp_pref_file_);
  Value* root = NULL;
  ASSERT_TRUE(deserializer.Deserialize(&root));
  ASSERT_TRUE(root);
  ASSERT_TRUE(root->IsType(Value::TYPE_DICTIONARY));
  DictionaryValue* root_dict = static_cast<DictionaryValue*>(root);
  // Retrieve the screen rect for the launched window
  scoped_ptr<BrowserProxy> browser(automation()->GetBrowserWindow(0));
  ASSERT_TRUE(browser.get());
  scoped_ptr<WindowProxy> window(
      automation()->GetWindowForBrowser(browser.get()));
  HWND hWnd;
  ASSERT_TRUE(window->GetHWND(&hWnd));
  WINDOWPLACEMENT window_placement;
  ASSERT_TRUE(GetWindowPlacement(hWnd, &window_placement));
  // Retrieve the expected rect values from "Preferences"
  int bottom = 0;
  std::wstring kBrowserWindowPlacement(prefs::kBrowserWindowPlacement);
  ASSERT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + L".bottom",
      &bottom));
  ASSERT_EQ(bottom, window_placement.rcNormalPosition.bottom);
  int top = 0;
  ASSERT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + L".top",
      &top));
  ASSERT_EQ(top, window_placement.rcNormalPosition.top);
  int left = 0;
  ASSERT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + L".left",
      &left));
  ASSERT_EQ(left, window_placement.rcNormalPosition.left);
  int right = 0;
  ASSERT_TRUE(root_dict->GetInteger(kBrowserWindowPlacement + L".right",
      &right));
  ASSERT_EQ(right, window_placement.rcNormalPosition.right);
  // Find if launched window is maximized
  bool is_window_maximized = (window_placement.showCmd == SW_MAXIMIZE);
  bool is_maximized = false;
  ASSERT_TRUE(root_dict->GetBoolean(kBrowserWindowPlacement + L".maximized",
      &is_maximized));
  ASSERT_EQ(is_maximized, is_window_maximized);
  delete root;
}
 |