summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/browser/sessions/session_service_test_helper.cc9
-rw-r--r--chrome/browser/sessions/session_service_test_helper.h9
-rw-r--r--chrome/browser/sync/abstract_profile_sync_service_test.cc4
-rw-r--r--chrome/browser/sync/abstract_profile_sync_service_test.h3
-rw-r--r--chrome/chrome_tests.gypi11
-rw-r--r--chrome/test/live_sync/live_bookmarks_sync_test.cc262
-rw-r--r--chrome/test/live_sync/live_bookmarks_sync_test.h224
-rw-r--r--chrome/test/live_sync/live_sessions_sync_test.cc312
-rw-r--r--chrome/test/live_sync/live_sessions_sync_test.h296
-rw-r--r--chrome/test/live_sync/live_sync_test.cc4
-rw-r--r--chrome/test/live_sync/live_sync_test.h6
-rw-r--r--chrome/test/live_sync/many_client_live_bookmarks_sync_test.cc6
-rw-r--r--chrome/test/live_sync/many_client_live_passwords_sync_test.cc4
-rw-r--r--chrome/test/live_sync/many_client_live_preferences_sync_test.cc3
-rw-r--r--chrome/test/live_sync/multiple_client_live_passwords_sync_test.cc3
-rw-r--r--chrome/test/live_sync/multiple_client_live_preferences_sync_test.cc3
-rw-r--r--chrome/test/live_sync/multiple_client_live_sessions_sync_test.cc4
-rw-r--r--chrome/test/live_sync/single_client_live_bookmarks_sync_test.cc6
-rw-r--r--chrome/test/live_sync/single_client_live_extensions_sync_test.cc6
-rw-r--r--chrome/test/live_sync/single_client_live_passwords_sync_test.cc3
-rw-r--r--chrome/test/live_sync/single_client_live_preferences_sync_test.cc3
-rw-r--r--chrome/test/live_sync/single_client_live_sessions_sync_test.cc3
-rw-r--r--chrome/test/live_sync/single_client_live_themes_sync_test.cc6
-rw-r--r--chrome/test/live_sync/two_client_live_autofill_sync_test.cc3
-rw-r--r--chrome/test/live_sync/two_client_live_bookmarks_sync_test.cc6
-rw-r--r--chrome/test/live_sync/two_client_live_passwords_sync_test.cc4
-rw-r--r--chrome/test/live_sync/two_client_live_preferences_sync_test.cc3
-rw-r--r--chrome/test/live_sync/two_client_live_sessions_sync_test.cc4
-rw-r--r--chrome/test/live_sync/two_client_live_themes_sync_test.cc6
-rw-r--r--chrome/test/sync/engine/test_directory_setter_upper.cc4
-rw-r--r--chrome/test/sync/engine/test_directory_setter_upper.h3
-rw-r--r--chrome/test/webdriver/automation.cc6
-rw-r--r--chrome/test/webdriver/automation.h5
-rw-r--r--chrome/test/webdriver/commands/command.cc25
-rw-r--r--chrome/test/webdriver/commands/command.h18
-rw-r--r--chrome/test/webdriver/commands/find_element_commands.cc19
-rw-r--r--chrome/test/webdriver/commands/find_element_commands.h12
-rw-r--r--chrome/test/webdriver/keymap.cc4
-rw-r--r--chrome/test/webdriver/keymap.h3
-rw-r--r--chrome/test/webdriver/session.cc4
-rw-r--r--chrome/test/webdriver/session.h6
-rw-r--r--chrome/test/webdriver/session_manager.cc6
-rw-r--r--chrome/test/webdriver/session_manager.h5
-rw-r--r--webkit/mocks/mock_webframe.cc393
-rw-r--r--webkit/mocks/mock_webframe.h345
-rw-r--r--webkit/mocks/mock_weburlloader.cc18
-rw-r--r--webkit/mocks/mock_weburlloader.h9
-rw-r--r--webkit/tools/test_shell/test_shell.gypi2
48 files changed, 1328 insertions, 775 deletions
diff --git a/chrome/browser/sessions/session_service_test_helper.cc b/chrome/browser/sessions/session_service_test_helper.cc
index fda500b..5a87303 100644
--- a/chrome/browser/sessions/session_service_test_helper.cc
+++ b/chrome/browser/sessions/session_service_test_helper.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
+// 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.
@@ -13,6 +13,13 @@
using base::Time;
+SessionServiceTestHelper::SessionServiceTestHelper() {}
+
+SessionServiceTestHelper::SessionServiceTestHelper(SessionService* service)
+ : service_(service) {}
+
+SessionServiceTestHelper::~SessionServiceTestHelper() {}
+
void SessionServiceTestHelper::RestoreSessionFromCommands(
const std::vector<SessionCommand*>& commands,
std::vector<SessionWindow*>* valid_windows) {
diff --git a/chrome/browser/sessions/session_service_test_helper.h b/chrome/browser/sessions/session_service_test_helper.h
index 062bb1c..882a0b5 100644
--- a/chrome/browser/sessions/session_service_test_helper.h
+++ b/chrome/browser/sessions/session_service_test_helper.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -23,10 +23,9 @@ class TabNavigation;
class SessionServiceTestHelper {
public:
- explicit SessionServiceTestHelper() {}
-
- explicit SessionServiceTestHelper(SessionService* service)
- : service_(service) {}
+ explicit SessionServiceTestHelper();
+ explicit SessionServiceTestHelper(SessionService* service);
+ ~SessionServiceTestHelper();
void RestoreSessionFromCommands(const std::vector<SessionCommand*>& commands,
std::vector<SessionWindow*>* valid_windows);
diff --git a/chrome/browser/sync/abstract_profile_sync_service_test.cc b/chrome/browser/sync/abstract_profile_sync_service_test.cc
index 26c9094..3c54e23 100644
--- a/chrome/browser/sync/abstract_profile_sync_service_test.cc
+++ b/chrome/browser/sync/abstract_profile_sync_service_test.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 20111 The Chromium Authors. All rights reserved.
+// 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.
@@ -98,6 +98,8 @@ bool ProfileSyncServiceTestHelper::CreateRoot(
AbstractProfileSyncServiceTest::AbstractProfileSyncServiceTest()
: ui_thread_(BrowserThread::UI, &message_loop_) {}
+AbstractProfileSyncServiceTest::~AbstractProfileSyncServiceTest() {}
+
bool AbstractProfileSyncServiceTest::CreateRoot(ModelType model_type) {
return ProfileSyncServiceTestHelper::CreateRoot(
model_type,
diff --git a/chrome/browser/sync/abstract_profile_sync_service_test.h b/chrome/browser/sync/abstract_profile_sync_service_test.h
index 522af54..8e67378 100644
--- a/chrome/browser/sync/abstract_profile_sync_service_test.h
+++ b/chrome/browser/sync/abstract_profile_sync_service_test.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -40,6 +40,7 @@ class ProfileSyncServiceTestHelper {
class AbstractProfileSyncServiceTest : public testing::Test {
public:
AbstractProfileSyncServiceTest();
+ virtual ~AbstractProfileSyncServiceTest();
bool CreateRoot(syncable::ModelType model_type);
diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi
index ccce188..2b56187 100644
--- a/chrome/chrome_tests.gypi
+++ b/chrome/chrome_tests.gypi
@@ -86,12 +86,14 @@
'browser/renderer_host/test/test_backing_store.h',
'browser/renderer_host/test/test_render_view_host.cc',
'browser/renderer_host/test/test_render_view_host.h',
- 'browser/tab_contents/test_tab_contents.cc',
- 'browser/tab_contents/test_tab_contents.h',
+ 'browser/sessions/session_service_test_helper.cc',
+ 'browser/sessions/session_service_test_helper.h',
'browser/sync/profile_sync_service_mock.cc',
'browser/sync/profile_sync_service_mock.h',
'browser/sync/syncable/syncable_mock.cc',
'browser/sync/syncable/syncable_mock.h',
+ 'browser/tab_contents/test_tab_contents.cc',
+ 'browser/tab_contents/test_tab_contents.h',
'browser/ui/browser.h',
'browser/ui/cocoa/browser_test_helper.h',
'browser/ui/tab_contents/test_tab_contents_wrapper.cc',
@@ -1407,8 +1409,6 @@
'browser/search_engines/template_url_scraper_unittest.cc',
'browser/search_engines/template_url_unittest.cc',
'browser/sessions/session_backend_unittest.cc',
- 'browser/sessions/session_service_test_helper.cc',
- 'browser/sessions/session_service_test_helper.h',
'browser/sessions/session_service_unittest.cc',
'browser/shell_integration_unittest.cc',
'browser/speech/endpointer/endpointer_unittest.cc',
@@ -2915,13 +2915,13 @@
'app/chrome_dll_version.rc.version',
'browser/password_manager/password_form_data.cc',
'browser/sessions/session_backend.cc',
- 'browser/sessions/session_service_test_helper.cc',
'browser/sync/glue/session_model_associator.cc',
'test/bookmark_load_observer.h',
'test/out_of_proc_test_runner.cc',
'test/live_sync/bookmark_model_verifier.cc',
'test/live_sync/bookmark_model_verifier.h',
'test/live_sync/live_autofill_sync_test.h',
+ 'test/live_sync/live_bookmarks_sync_test.cc',
'test/live_sync/live_bookmarks_sync_test.h',
'test/live_sync/live_extensions_sync_test_base.cc',
'test/live_sync/live_extensions_sync_test_base.h',
@@ -2929,6 +2929,7 @@
'test/live_sync/live_extensions_sync_test.h',
'test/live_sync/live_passwords_sync_test.h',
'test/live_sync/live_preferences_sync_test.h',
+ 'test/live_sync/live_sessions_sync_test.cc',
'test/live_sync/live_sessions_sync_test.h',
'test/live_sync/live_themes_sync_test.cc',
'test/live_sync/live_themes_sync_test.h',
diff --git a/chrome/test/live_sync/live_bookmarks_sync_test.cc b/chrome/test/live_sync/live_bookmarks_sync_test.cc
new file mode 100644
index 0000000..50faab4
--- /dev/null
+++ b/chrome/test/live_sync/live_bookmarks_sync_test.cc
@@ -0,0 +1,262 @@
+// 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 "chrome/test/live_sync/live_bookmarks_sync_test.h"
+
+#include "base/utf_string_conversions.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/test/ui_test_utils.h"
+#include "third_party/skia/include/core/SkBitmap.h"
+#include "ui/gfx/codec/png_codec.h"
+
+LiveBookmarksSyncTest::LiveBookmarksSyncTest(TestType test_type)
+ : LiveSyncTest(test_type) {}
+
+LiveBookmarksSyncTest::~LiveBookmarksSyncTest() {}
+
+bool LiveBookmarksSyncTest::SetupClients() {
+ if (!LiveSyncTest::SetupClients())
+ return false;
+ for (int i = 0; i < num_clients(); ++i) {
+ ui_test_utils::WaitForBookmarkModelToLoad(
+ GetProfile(i)->GetBookmarkModel());
+ }
+ verifier_helper_.reset(
+ new BookmarkModelVerifier(GetVerifierBookmarkModel()));
+ ui_test_utils::WaitForBookmarkModelToLoad(verifier()->GetBookmarkModel());
+ return true;
+}
+
+BookmarkModel* LiveBookmarksSyncTest::GetBookmarkModel(int index) {
+ return GetProfile(index)->GetBookmarkModel();
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::GetBookmarkBarNode(int index) {
+ return GetBookmarkModel(index)->GetBookmarkBarNode();
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::GetOtherNode(int index) {
+ return GetBookmarkModel(index)->other_node();
+}
+
+BookmarkModel* LiveBookmarksSyncTest::GetVerifierBookmarkModel() {
+ return verifier()->GetBookmarkModel();
+}
+
+void LiveBookmarksSyncTest::DisableVerifier() {
+ verifier_helper_->set_use_verifier_model(false);
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddURL(int profile,
+ const std::wstring& title,
+ const GURL& url) {
+ return verifier_helper_->AddURL(GetBookmarkModel(profile),
+ GetBookmarkBarNode(profile),
+ 0, WideToUTF16(title), url);
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddURL(int profile,
+ int index,
+ const std::wstring& title,
+ const GURL& url) {
+ return verifier_helper_->AddURL(GetBookmarkModel(profile),
+ GetBookmarkBarNode(profile),
+ index, WideToUTF16(title), url);
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddURL(int profile,
+ const BookmarkNode* parent,
+ int index,
+ const std::wstring& title,
+ const GURL& url) {
+ EXPECT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent);
+ return verifier_helper_->AddURL(GetBookmarkModel(profile), parent, index,
+ WideToUTF16(title), url);
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddGroup(int profile,
+ const std::wstring& title) {
+ return verifier_helper_->AddGroup(GetBookmarkModel(profile),
+ GetBookmarkBarNode(profile),
+ 0, WideToUTF16(title));
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddGroup(int profile,
+ int index,
+ const std::wstring& title) {
+ return verifier_helper_->AddGroup(GetBookmarkModel(profile),
+ GetBookmarkBarNode(profile),
+ index, WideToUTF16(title));
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::AddGroup(int profile,
+ const BookmarkNode* parent,
+ int index,
+ const std::wstring& title) {
+ if (GetBookmarkModel(profile)->GetNodeByID(parent->id()) != parent) {
+ LOG(ERROR) << "Node " << parent->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ return NULL;
+ }
+ return verifier_helper_->AddGroup(
+ GetBookmarkModel(profile), parent, index, WideToUTF16(title));
+}
+
+void LiveBookmarksSyncTest::SetTitle(int profile,
+ const BookmarkNode* node,
+ const std::wstring& new_title) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
+ << "Node " << node->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ verifier_helper_->SetTitle(
+ GetBookmarkModel(profile), node, WideToUTF16(new_title));
+}
+
+void LiveBookmarksSyncTest::SetFavicon(
+ int profile,
+ const BookmarkNode* node,
+ const std::vector<unsigned char>& icon_bytes_vector) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
+ << "Node " << node->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ ASSERT_EQ(BookmarkNode::URL, node->type())
+ << "Node " << node->GetTitle() << " must be a url.";
+ verifier_helper_->SetFavicon(
+ GetBookmarkModel(profile), node, icon_bytes_vector);
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::SetURL(int profile,
+ const BookmarkNode* node,
+ const GURL& new_url) {
+ if (GetBookmarkModel(profile)->GetNodeByID(node->id()) != node) {
+ LOG(ERROR) << "Node " << node->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ return NULL;
+ }
+ return verifier_helper_->SetURL(GetBookmarkModel(profile), node, new_url);
+}
+
+void LiveBookmarksSyncTest::Move(int profile,
+ const BookmarkNode* node,
+ const BookmarkNode* new_parent,
+ int index) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
+ << "Node " << node->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ verifier_helper_->Move(
+ GetBookmarkModel(profile), node, new_parent, index);
+}
+
+
+void LiveBookmarksSyncTest::Remove(int profile, const BookmarkNode* parent,
+ int index) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
+ << "Node " << parent->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ verifier_helper_->Remove(GetBookmarkModel(profile), parent, index);
+}
+
+void LiveBookmarksSyncTest::SortChildren(int profile,
+ const BookmarkNode* parent) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
+ << "Node " << parent->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ verifier_helper_->SortChildren(GetBookmarkModel(profile), parent);
+}
+
+void LiveBookmarksSyncTest::ReverseChildOrder(int profile,
+ const BookmarkNode* parent) {
+ ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
+ << "Node " << parent->GetTitle() << " does not belong to "
+ << "Profile " << profile;
+ verifier_helper_->ReverseChildOrder(GetBookmarkModel(profile), parent);
+}
+
+bool LiveBookmarksSyncTest::ModelMatchesVerifier(int profile) {
+ if (verifier_helper_->use_verifier_model() == false) {
+ LOG(ERROR) << "Illegal to call ModelMatchesVerifier() after "
+ << "DisableVerifier(). Use ModelsMatch() instead.";
+ return false;
+ }
+ return BookmarkModelVerifier::ModelsMatch(
+ GetVerifierBookmarkModel(), GetBookmarkModel(profile));
+}
+
+bool LiveBookmarksSyncTest::AllModelsMatchVerifier() {
+ if (verifier_helper_->use_verifier_model() == false) {
+ LOG(ERROR) << "Illegal to call AllModelsMatchVerifier() after "
+ << "DisableVerifier(). Use AllModelsMatch() instead.";
+ return false;
+ }
+ for (int i = 0; i < num_clients(); ++i) {
+ if (!ModelMatchesVerifier(i)) {
+ LOG(ERROR) << "Model " << i << " does not match the verifier.";
+ return false;
+ }
+ }
+ return true;
+}
+
+bool LiveBookmarksSyncTest::ModelsMatch(int profile_a, int profile_b) {
+ return BookmarkModelVerifier::ModelsMatch(
+ GetBookmarkModel(profile_a), GetBookmarkModel(profile_b));
+}
+
+bool LiveBookmarksSyncTest::AllModelsMatch() {
+ for (int i = 1; i < num_clients(); ++i) {
+ if (!ModelsMatch(0, i)) {
+ LOG(ERROR) << "Model " << i << " does not match Model 0.";
+ return false;
+ }
+ }
+ return true;
+}
+
+bool LiveBookmarksSyncTest::ContainsDuplicateBookmarks(int profile) {
+ return BookmarkModelVerifier::ContainsDuplicateBookmarks(
+ GetBookmarkModel(profile));
+}
+
+const BookmarkNode* LiveBookmarksSyncTest::GetUniqueNodeByURL(int profile,
+ const GURL& url) {
+ std::vector<const BookmarkNode*> nodes;
+ GetBookmarkModel(profile)->GetNodesByURL(url, &nodes);
+ EXPECT_EQ(1U, nodes.size());
+ if (nodes.empty())
+ return NULL;
+ return nodes[0];
+}
+
+int LiveBookmarksSyncTest::CountBookmarksWithTitlesMatching(
+ int profile,
+ const std::wstring& title) {
+ return verifier_helper_->CountNodesWithTitlesMatching(
+ GetBookmarkModel(profile), BookmarkNode::URL, WideToUTF16(title));
+}
+
+int LiveBookmarksSyncTest::CountFoldersWithTitlesMatching(
+ int profile,
+ const std::wstring& title) {
+ return verifier_helper_->CountNodesWithTitlesMatching(
+ GetBookmarkModel(profile), BookmarkNode::FOLDER, WideToUTF16(title));
+}
+
+// static
+std::vector<unsigned char> LiveBookmarksSyncTest::CreateFavicon(int seed) {
+ const int w = 16;
+ const int h = 16;
+ SkBitmap bmp;
+ bmp.setConfig(SkBitmap::kARGB_8888_Config, w, h);
+ bmp.allocPixels();
+ uint32_t* src_data = bmp.getAddr32(0, 0);
+ for (int i = 0; i < w * h; ++i) {
+ src_data[i] = SkPreMultiplyARGB((seed + i) % 255,
+ (seed + i) % 250,
+ (seed + i) % 245,
+ (seed + i) % 240);
+ }
+ std::vector<unsigned char> favicon;
+ gfx::PNGCodec::EncodeBGRASkBitmap(bmp, false, &favicon);
+ return favicon;
+}
diff --git a/chrome/test/live_sync/live_bookmarks_sync_test.h b/chrome/test/live_sync/live_bookmarks_sync_test.h
index 16ab5b5..9c20618 100644
--- a/chrome/test/live_sync/live_bookmarks_sync_test.h
+++ b/chrome/test/live_sync/live_bookmarks_sync_test.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -11,68 +11,42 @@
#include "base/compiler_specific.h"
#include "chrome/browser/bookmarks/bookmark_model.h"
-#include "chrome/browser/profiles/profile.h"
#include "chrome/test/live_sync/bookmark_model_verifier.h"
#include "chrome/test/live_sync/live_sync_test.h"
-#include "chrome/test/ui_test_utils.h"
-#include "googleurl/src/gurl.h"
#include "testing/gtest/include/gtest/gtest.h"
-#include "third_party/skia/include/core/SkBitmap.h"
-#include "ui/gfx/codec/png_codec.h"
+
+class GURL;
+class Profile;
class LiveBookmarksSyncTest : public LiveSyncTest {
public:
- explicit LiveBookmarksSyncTest(TestType test_type)
- : LiveSyncTest(test_type) {}
-
- virtual ~LiveBookmarksSyncTest() {}
+ explicit LiveBookmarksSyncTest(TestType test_type);
+ virtual ~LiveBookmarksSyncTest();
// Sets up sync profiles and clients and initializes the bookmark verifier.
- virtual bool SetupClients() WARN_UNUSED_RESULT {
- if (!LiveSyncTest::SetupClients())
- return false;
- for (int i = 0; i < num_clients(); ++i) {
- ui_test_utils::WaitForBookmarkModelToLoad(
- GetProfile(i)->GetBookmarkModel());
- }
- verifier_helper_.reset(
- new BookmarkModelVerifier(GetVerifierBookmarkModel()));
- ui_test_utils::WaitForBookmarkModelToLoad(verifier()->GetBookmarkModel());
- return true;
- }
+ virtual bool SetupClients() WARN_UNUSED_RESULT;
// Used to access the bookmark model within a particular sync profile.
- BookmarkModel* GetBookmarkModel(int index) WARN_UNUSED_RESULT {
- return GetProfile(index)->GetBookmarkModel();
- }
+ BookmarkModel* GetBookmarkModel(int index) WARN_UNUSED_RESULT;
// Used to access the bookmark bar within a particular sync profile.
- const BookmarkNode* GetBookmarkBarNode(int index) WARN_UNUSED_RESULT {
- return GetBookmarkModel(index)->GetBookmarkBarNode();
- }
+ const BookmarkNode* GetBookmarkBarNode(int index) WARN_UNUSED_RESULT;
// Used to access the "other bookmarks" node within a particular sync profile.
- const BookmarkNode* GetOtherNode(int index) WARN_UNUSED_RESULT {
- return GetBookmarkModel(index)->other_node();
- }
+ const BookmarkNode* GetOtherNode(int index) WARN_UNUSED_RESULT;
// Used to access the bookmarks within the verifier sync profile.
- BookmarkModel* GetVerifierBookmarkModel() WARN_UNUSED_RESULT {
- return verifier()->GetBookmarkModel();
- }
+ BookmarkModel* GetVerifierBookmarkModel() WARN_UNUSED_RESULT;
// After calling this method, changes made to a bookmark model will no longer
// be reflected in the verifier model.
- void DisableVerifier() { verifier_helper_->set_use_verifier_model(false); }
+ void DisableVerifier();
// Adds a URL with address |url| and title |title| to the bookmark bar of
// profile |profile|. Returns a pointer to the node that was added.
const BookmarkNode* AddURL(int profile,
const std::wstring& title,
- const GURL& url) WARN_UNUSED_RESULT {
- return verifier_helper_->AddURL(GetBookmarkModel(profile),
- GetBookmarkBarNode(profile), 0, WideToUTF16(title), url);
- }
+ const GURL& url) WARN_UNUSED_RESULT;
// Adds a URL with address |url| and title |title| to the bookmark bar of
// profile |profile| at position |index|. Returns a pointer to the node that
@@ -80,10 +54,7 @@ class LiveBookmarksSyncTest : public LiveSyncTest {
const BookmarkNode* AddURL(int profile,
int index,
const std::wstring& title,
- const GURL& url) WARN_UNUSED_RESULT {
- return verifier_helper_->AddURL(GetBookmarkModel(profile),
- GetBookmarkBarNode(profile), index, WideToUTF16(title), url);
- }
+ const GURL& url) WARN_UNUSED_RESULT;
// Adds a URL with address |url| and title |title| under the node |parent| of
// profile |profile| at position |index|. Returns a pointer to the node that
@@ -92,28 +63,18 @@ class LiveBookmarksSyncTest : public LiveSyncTest {
const BookmarkNode* parent,
int index,
const std::wstring& title,
- const GURL& url) WARN_UNUSED_RESULT {
- EXPECT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent);
- return verifier_helper_->AddURL(GetBookmarkModel(profile), parent, index,
- WideToUTF16(title), url);
- }
+ const GURL& url) WARN_UNUSED_RESULT;
// Adds a group named |title| to the bookmark bar of profile |profile|.
// Returns a pointer to the group that was added.
const BookmarkNode* AddGroup(int profile,
- const std::wstring& title) WARN_UNUSED_RESULT {
- return verifier_helper_->AddGroup(GetBookmarkModel(profile),
- GetBookmarkBarNode(profile), 0, WideToUTF16(title));
- }
+ const std::wstring& title) WARN_UNUSED_RESULT;
// Adds a group named |title| to the bookmark bar of profile |profile| at
// position |index|. Returns a pointer to the group that was added.
const BookmarkNode* AddGroup(int profile,
int index,
- const std::wstring& title) WARN_UNUSED_RESULT {
- return verifier_helper_->AddGroup(GetBookmarkModel(profile),
- GetBookmarkBarNode(profile), index, WideToUTF16(title));
- }
+ const std::wstring& title) WARN_UNUSED_RESULT;
// Adds a group named |title| to the node |parent| in the bookmark model of
// profile |profile| at position |index|. Returns a pointer to the node that
@@ -121,198 +82,85 @@ class LiveBookmarksSyncTest : public LiveSyncTest {
const BookmarkNode* AddGroup(int profile,
const BookmarkNode* parent,
int index,
- const std::wstring& title) WARN_UNUSED_RESULT {
- if (GetBookmarkModel(profile)->GetNodeByID(parent->id()) != parent) {
- LOG(ERROR) << "Node " << parent->GetTitle() << " does not belong to "
- << "Profile " << profile;
- return NULL;
- }
- return verifier_helper_->AddGroup(
- GetBookmarkModel(profile), parent, index, WideToUTF16(title));
- }
+ const std::wstring& title) WARN_UNUSED_RESULT;
// Changes the title of the node |node| in the bookmark model of profile
// |profile| to |new_title|.
void SetTitle(int profile,
const BookmarkNode* node,
- const std::wstring& new_title) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
- << "Node " << node->GetTitle() << " does not belong to "
- << "Profile " << profile;
- verifier_helper_->SetTitle(
- GetBookmarkModel(profile), node, WideToUTF16(new_title));
- }
+ const std::wstring& new_title);
// Sets the favicon of the node |node| (of type BookmarkNode::URL) in the
// bookmark model of profile |profile| using the data in |icon_bytes_vector|.
void SetFavicon(int profile,
const BookmarkNode* node,
- const std::vector<unsigned char>& icon_bytes_vector) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
- << "Node " << node->GetTitle() << " does not belong to "
- << "Profile " << profile;
- ASSERT_EQ(BookmarkNode::URL, node->type())
- << "Node " << node->GetTitle() << " must be a url.";
- verifier_helper_->SetFavicon(
- GetBookmarkModel(profile), node, icon_bytes_vector);
- }
+ const std::vector<unsigned char>& icon_bytes_vector);
// Changes the url of the node |node| in the bookmark model of profile
// |profile| to |new_url|. Returns a pointer to the node with the changed url.
const BookmarkNode* SetURL(int profile,
const BookmarkNode* node,
- const GURL& new_url) WARN_UNUSED_RESULT {
- if (GetBookmarkModel(profile)->GetNodeByID(node->id()) != node) {
- LOG(ERROR) << "Node " << node->GetTitle() << " does not belong to "
- << "Profile " << profile;
- return NULL;
- }
- return verifier_helper_->SetURL(GetBookmarkModel(profile), node, new_url);
- }
+ const GURL& new_url) WARN_UNUSED_RESULT;
// Moves the node |node| in the bookmark model of profile |profile| so it ends
// up under the node |new_parent| at position |index|.
void Move(int profile,
const BookmarkNode* node,
const BookmarkNode* new_parent,
- int index) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(node->id()), node)
- << "Node " << node->GetTitle() << " does not belong to "
- << "Profile " << profile;
- verifier_helper_->Move(
- GetBookmarkModel(profile), node, new_parent, index);
- }
+ int index);
// Removes the node in the bookmark model of profile |profile| under the node
// |parent| at position |index|.
- void Remove(int profile, const BookmarkNode* parent, int index) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
- << "Node " << parent->GetTitle() << " does not belong to "
- << "Profile " << profile;
- verifier_helper_->Remove(GetBookmarkModel(profile), parent, index);
- }
+ void Remove(int profile, const BookmarkNode* parent, int index);
// Sorts the children of the node |parent| in the bookmark model of profile
// |profile|.
- void SortChildren(int profile, const BookmarkNode* parent) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
- << "Node " << parent->GetTitle() << " does not belong to "
- << "Profile " << profile;
- verifier_helper_->SortChildren(GetBookmarkModel(profile), parent);
- }
+ void SortChildren(int profile, const BookmarkNode* parent);
// Reverses the order of the children of the node |parent| in the bookmark
// model of profile |profile|.
- void ReverseChildOrder(int profile, const BookmarkNode* parent) {
- ASSERT_EQ(GetBookmarkModel(profile)->GetNodeByID(parent->id()), parent)
- << "Node " << parent->GetTitle() << " does not belong to "
- << "Profile " << profile;
- verifier_helper_->ReverseChildOrder(GetBookmarkModel(profile), parent);
- }
+ void ReverseChildOrder(int profile, const BookmarkNode* parent);
// Checks if the bookmark model of profile |profile| matches the verifier
// bookmark model. Returns true if they match.
- bool ModelMatchesVerifier(int profile) WARN_UNUSED_RESULT {
- if (verifier_helper_->use_verifier_model() == false) {
- LOG(ERROR) << "Illegal to call ModelMatchesVerifier() after "
- << "DisableVerifier(). Use ModelsMatch() instead.";
- return false;
- }
- return BookmarkModelVerifier::ModelsMatch(
- GetVerifierBookmarkModel(), GetBookmarkModel(profile));
- }
+ bool ModelMatchesVerifier(int profile) WARN_UNUSED_RESULT;
// Checks if the bookmark models of all sync profiles match the verifier
// bookmark model. Returns true if they match.
- bool AllModelsMatchVerifier() WARN_UNUSED_RESULT {
- if (verifier_helper_->use_verifier_model() == false) {
- LOG(ERROR) << "Illegal to call AllModelsMatchVerifier() after "
- << "DisableVerifier(). Use AllModelsMatch() instead.";
- return false;
- }
- for (int i = 0; i < num_clients(); ++i) {
- if (!ModelMatchesVerifier(i)) {
- LOG(ERROR) << "Model " << i << " does not match the verifier.";
- return false;
- }
- }
- return true;
- }
+ bool AllModelsMatchVerifier() WARN_UNUSED_RESULT;
// Checks if the bookmark models of |profile_a| and |profile_b| match each
// other. Returns true if they match.
- bool ModelsMatch(int profile_a, int profile_b) WARN_UNUSED_RESULT {
- return BookmarkModelVerifier::ModelsMatch(
- GetBookmarkModel(profile_a), GetBookmarkModel(profile_b));
- }
+ bool ModelsMatch(int profile_a, int profile_b) WARN_UNUSED_RESULT;
// Checks if the bookmark models of all sync profiles match each other. Does
// not compare them with the verifier bookmark model. Returns true if they
// match.
- bool AllModelsMatch() WARN_UNUSED_RESULT {
- for (int i = 1; i < num_clients(); ++i) {
- if (!ModelsMatch(0, i)) {
- LOG(ERROR) << "Model " << i << " does not match Model 0.";
- return false;
- }
- }
- return true;
- }
+ bool AllModelsMatch() WARN_UNUSED_RESULT;
// Checks if the bookmark model of profile |profile| contains any instances of
// two bookmarks with the same URL under the same parent folder. Returns true
// if even one instance is found.
- bool ContainsDuplicateBookmarks(int profile) {
- return BookmarkModelVerifier::ContainsDuplicateBookmarks(
- GetBookmarkModel(profile));
- }
+ bool ContainsDuplicateBookmarks(int profile);
// Gets the node in the bookmark model of profile |profile| that has the url
// |url|. Note: Only one instance of |url| is assumed to be present.
const BookmarkNode* GetUniqueNodeByURL(int profile,
- const GURL& url) WARN_UNUSED_RESULT {
- std::vector<const BookmarkNode*> nodes;
- GetBookmarkModel(profile)->GetNodesByURL(url, &nodes);
- EXPECT_EQ(1U, nodes.size());
- if (nodes.empty())
- return NULL;
- return nodes[0];
- }
+ const GURL& url) WARN_UNUSED_RESULT;
// Returns the number of bookmarks in bookmark model of profile |profile|
// whose titles match the string |title|.
int CountBookmarksWithTitlesMatching(int profile, const std::wstring& title)
- WARN_UNUSED_RESULT {
- return verifier_helper_->CountNodesWithTitlesMatching(
- GetBookmarkModel(profile), BookmarkNode::URL, WideToUTF16(title));
- }
+ WARN_UNUSED_RESULT;
// Returns the number of bookmark folders in the bookmark model of profile
// |profile| whose titles contain the query string |title|.
- int CountFoldersWithTitlesMatching(int profile,
- const std::wstring& title) WARN_UNUSED_RESULT {
- return verifier_helper_->CountNodesWithTitlesMatching(
- GetBookmarkModel(profile), BookmarkNode::FOLDER, WideToUTF16(title));
- }
+ int CountFoldersWithTitlesMatching(
+ int profile,
+ const std::wstring& title) WARN_UNUSED_RESULT;
// Creates a unique favicon using |seed|.
- static std::vector<unsigned char> CreateFavicon(int seed) {
- const int w = 16;
- const int h = 16;
- SkBitmap bmp;
- bmp.setConfig(SkBitmap::kARGB_8888_Config, w, h);
- bmp.allocPixels();
- uint32_t* src_data = bmp.getAddr32(0, 0);
- for (int i = 0; i < w * h; ++i) {
- src_data[i] = SkPreMultiplyARGB((seed + i) % 255,
- (seed + i) % 250,
- (seed + i) % 245,
- (seed + i) % 240);
- }
- std::vector<unsigned char> favicon;
- gfx::PNGCodec::EncodeBGRASkBitmap(bmp, false, &favicon);
- return favicon;
- }
+ static std::vector<unsigned char> CreateFavicon(int seed);
private:
// Helper object that has the functionality to verify changes made to the
diff --git a/chrome/test/live_sync/live_sessions_sync_test.cc b/chrome/test/live_sync/live_sessions_sync_test.cc
new file mode 100644
index 0000000..f6908f3
--- /dev/null
+++ b/chrome/test/live_sync/live_sessions_sync_test.cc
@@ -0,0 +1,312 @@
+// 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 "chrome/test/live_sync/live_sessions_sync_test.h"
+
+#include "chrome/browser/browser_thread.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sessions/session_service.h"
+#include "chrome/browser/sync/profile_sync_service.h"
+#include "chrome/test/ui_test_utils.h"
+#include "googleurl/src/gurl.h"
+#include "chrome/browser/tab_contents/tab_contents.h"
+#include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h"
+
+TestSessionService::TestSessionService()
+ : SessionServiceTestHelper(),
+ done_saving_(false, false),
+ got_windows_(false, false),
+ profile_(NULL),
+ window_bounds_(0, 1, 2, 3) {}
+
+TestSessionService::TestSessionService(SessionService* service,
+ Profile* profile)
+ : SessionServiceTestHelper(service),
+ done_saving_(false, false),
+ got_windows_(false, false),
+ profile_(profile),
+ window_bounds_(0, 1, 2, 3) {}
+
+void TestSessionService::SetUp() {
+ ASSERT_TRUE(service()) << "SetUp() called without setting SessionService";
+ ASSERT_TRUE(profile_);
+ service()->SetWindowType(window_id_, Browser::TYPE_NORMAL);
+ service()->SetWindowBounds(window_id_, window_bounds_, false);
+}
+
+void TestSessionService::Save() {
+ service()->Save();
+}
+
+std::vector<SessionWindow*>* TestSessionService::ReadWindows() {
+ // The session backend will post the callback as a task to whatever thread
+ // called it. In our case, we don't want the main test thread to have tasks
+ // posted to, so we perform the actual call to session service from the same
+ // thread the work will be done on (backend_thread aka file thread). As a
+ // result, it will directly call back, instead of posting a task, and we can
+ // block on that callback.
+ BrowserThread::PostTask(
+ BrowserThread::FILE,
+ FROM_HERE,
+ NewRunnableMethod(this, &TestSessionService::DoReadWindows));
+
+ // Wait for callback to happen.
+ got_windows_.Wait();
+
+ // By the time we reach here we've received the windows, so return them.
+ return windows_;
+}
+
+
+void TestSessionService::DoReadWindows() {
+ if (!BrowserThread::CurrentlyOn(BrowserThread::FILE)) {
+ LOG(ERROR) << "DoReadWindows called from wrong thread!";
+ windows_ = NULL;
+ got_windows_.Signal();
+ return;
+ }
+ SessionService::SessionCallback* callback =
+ NewCallback(this, &TestSessionService::OnGotSession);
+ service()->GetCurrentSession(&consumer_, callback);
+}
+
+void TestSessionService::OnGotSession(int handle,
+ std::vector<SessionWindow*>* windows) {
+ scoped_ptr<ForeignSession> foreign_session(new ForeignSession());
+ for (size_t w = 0; w < windows->size(); ++w) {
+ const SessionWindow& window = *windows->at(w);
+ scoped_ptr<SessionWindow> new_window(new SessionWindow());
+ for (size_t t = 0; t < window.tabs.size(); ++t) {
+ const SessionTab& tab = *window.tabs.at(t);
+ scoped_ptr<SessionTab> new_tab(new SessionTab());
+ new_tab->navigations.resize(tab.navigations.size());
+ std::copy(tab.navigations.begin(), tab.navigations.end(),
+ new_tab->navigations.begin());
+ new_window->tabs.push_back(new_tab.release());
+ }
+ foreign_session->windows.push_back(new_window.release());
+ }
+ windows_ = &(foreign_session->windows);
+ foreign_sessions_.push_back(foreign_session.release());
+ got_windows_.Signal();
+}
+
+TestSessionService::~TestSessionService() {
+ ReleaseService(); // We don't own this, so don't destroy it.
+}
+
+LiveSessionsSyncTest::LiveSessionsSyncTest(TestType test_type)
+ : LiveSyncTest(test_type),
+ done_closing_(false, false) {}
+
+LiveSessionsSyncTest::~LiveSessionsSyncTest() {}
+
+SessionService* LiveSessionsSyncTest::GetSessionService(int index) {
+ return GetProfile(index)->GetSessionService();
+}
+
+TestSessionService* LiveSessionsSyncTest::GetHelper(int index) {
+ return test_session_services_[index]->get();
+}
+
+Browser* LiveSessionsSyncTest::GetBrowser(int index) {
+ return browsers_[index];
+}
+
+bool LiveSessionsSyncTest::SetupClients() {
+ if (!LiveSyncTest::SetupClients()) {
+ return false;
+ }
+
+ // Go through and make the TestSessionServices and Browsers.
+ for (int i = 0; i < num_clients(); ++i) {
+ scoped_refptr<TestSessionService>* new_tester =
+ new scoped_refptr<TestSessionService>;
+ *new_tester = new TestSessionService(
+ GetSessionService(i), GetProfile(i));
+ test_session_services_.push_back(new_tester);
+ GetHelper(i)->SetUp();
+
+ browsers_.push_back(Browser::Create(GetProfile(i)));
+ }
+
+ return true;
+}
+
+TabContents* LiveSessionsSyncTest::OpenTab(int index, GURL url) {
+ TabContents* tab =
+ GetBrowser(index)->
+ AddSelectedTabWithURL(url, PageTransition::START_PAGE)->tab_contents();
+
+ // Wait for the page to finish loading.
+ ui_test_utils::WaitForNavigation(
+ &GetBrowser(index)->GetSelectedTabContents()->controller());
+
+ return tab;
+}
+
+std::vector<SessionWindow*>* LiveSessionsSyncTest::InitializeNewWindowWithTab(
+ int index, GURL url) {
+ if (!OpenTab(index, url)) {
+ return NULL;
+ }
+ GetHelper(index)->Save();
+ std::vector<SessionWindow*>* windows = GetHelper(index)->ReadWindows();
+ if (windows->size() != 1) {
+ LOG(ERROR) << "InitializeNewWindowWithTab called with open windows!";
+ return NULL;
+ }
+ if (1U != (*windows)[0]->tabs.size())
+ return NULL;
+ SortSessionWindows(windows);
+ return windows;
+}
+
+bool LiveSessionsSyncTest::CheckInitialState(int index) {
+ if (0 != GetNumWindows(index))
+ return false;
+ if (0 != GetNumForeignSessions(index))
+ return false;
+ return true;
+}
+
+int LiveSessionsSyncTest::GetNumWindows(int index) {
+ // We don't own windows.
+ std::vector<SessionWindow*>* windows = GetHelper(index)->ReadWindows();
+ return windows->size();
+}
+
+int LiveSessionsSyncTest::GetNumForeignSessions(int index) {
+ std::vector<const ForeignSession*> sessions;
+ if (!GetProfile(index)->GetProfileSyncService()->
+ GetSessionModelAssociator()->GetAllForeignSessions(&sessions))
+ return 0;
+ return sessions.size();
+}
+
+bool LiveSessionsSyncTest::GetSessionData(
+ int index,
+ std::vector<const ForeignSession*>* sessions) {
+ if (!GetProfile(index)->GetProfileSyncService()->
+ GetSessionModelAssociator()->GetAllForeignSessions(sessions))
+ return false;
+ SortForeignSessions(sessions);
+ return true;
+}
+
+// static
+bool LiveSessionsSyncTest::CompareSessionWindows(SessionWindow* lhs,
+ SessionWindow* rhs) {
+ if (!lhs ||
+ !rhs ||
+ lhs->tabs.size() < 1 ||
+ rhs->tabs.size() < 1 ||
+ lhs->tabs[0]->navigations.size() < 1 ||
+ rhs->tabs[0]->navigations.size() < 1) {
+ // Catchall for uncomparable data.
+ return false;
+ }
+
+ return lhs->tabs[0]->navigations[0].virtual_url() <
+ rhs->tabs[0]->navigations[0].virtual_url();
+}
+
+void LiveSessionsSyncTest::SortSessionWindows(
+ std::vector<SessionWindow*>* windows) {
+ std::sort(windows->begin(), windows->end(),
+ LiveSessionsSyncTest::CompareSessionWindows);
+}
+
+//static
+bool LiveSessionsSyncTest::CompareForeignSessions(
+ const ForeignSession* lhs,
+ const ForeignSession* rhs) {
+ if (!lhs ||
+ !rhs ||
+ lhs->windows.size() < 1 ||
+ rhs->windows.size() < 1) {
+ // Catchall for uncomparable data.
+ return false;
+ }
+
+ return CompareSessionWindows(lhs->windows[0], rhs->windows[0]);
+}
+
+void LiveSessionsSyncTest::SortForeignSessions(
+ std::vector<const ForeignSession*>* sessions) {
+ std::sort(sessions->begin(), sessions->end(),
+ LiveSessionsSyncTest::CompareForeignSessions);
+}
+
+bool LiveSessionsSyncTest::NavigationEquals(const TabNavigation& expected,
+ const TabNavigation& actual) {
+ if (expected.virtual_url() != actual.virtual_url())
+ return false;
+ if (expected.referrer() != actual.referrer())
+ return false;
+ if (expected.title() != actual.title())
+ return false;
+ if (expected.transition() != actual.transition())
+ return false;
+ return true;
+}
+
+bool LiveSessionsSyncTest::WindowsMatch(
+ const std::vector<SessionWindow*> &win1,
+ const std::vector<SessionWindow*> &win2) {
+ SessionTab* client0_tab;
+ SessionTab* client1_tab;
+ if (win1.size() != win2.size())
+ return false;
+ for (size_t i = 0; i < win1.size(); ++i) {
+ if (win1[i]->tabs.size() != win2[i]->tabs.size())
+ return false;
+ for (size_t j = 0; j < win1[i]->tabs.size(); ++j) {
+ client0_tab = win1[i]->tabs[j];
+ client1_tab = win2[i]->tabs[j];
+ for (size_t k = 0; k < client0_tab->navigations.size(); ++k) {
+ if (!NavigationEquals(client0_tab->navigations[k],
+ client1_tab->navigations[k])) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+
+bool LiveSessionsSyncTest::CheckForeignSessionsAgainst(
+ int index,
+ const std::vector<std::vector<SessionWindow*>* >& windows) {
+ std::vector<const ForeignSession*> sessions;
+ if (!GetSessionData(index, &sessions))
+ return false;
+ if ((size_t)(num_clients()-1) != sessions.size())
+ return false;
+
+ int window_index = 0;
+ for (size_t j = 0; j < sessions.size(); ++j, ++window_index) {
+ if (window_index == index)
+ window_index++; // Skip self.
+ if (!WindowsMatch(sessions[j]->windows, *windows[window_index]))
+ return false;
+ }
+
+ return true;
+}
+
+void LiveSessionsSyncTest::CleanUpOnMainThread() {
+ // Close all browsers. We need to do this now, as opposed to letting the
+ // test framework handle it, because we created our own browser for each
+ // sync profile.
+ BrowserList::CloseAllBrowsers();
+ ui_test_utils::RunAllPendingInMessageLoop();
+
+ // All browsers should be closed at this point, else when the framework
+ // calls QuitBrowsers() we could see memory corruption.
+ ASSERT_EQ(0U, BrowserList::size());
+
+ LiveSyncTest::CleanUpOnMainThread();
+}
diff --git a/chrome/test/live_sync/live_sessions_sync_test.h b/chrome/test/live_sync/live_sessions_sync_test.h
index 09939bf..e081ad7 100644
--- a/chrome/test/live_sync/live_sessions_sync_test.h
+++ b/chrome/test/live_sync/live_sessions_sync_test.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -13,111 +13,44 @@
#include "base/scoped_vector.h"
#include "base/ref_counted.h"
#include "base/synchronization/waitable_event.h"
-#include "chrome/browser/browser_window.h"
-#include "chrome/browser/profiles/profile.h"
-#include "chrome/browser/renderer_host/render_view_host_delegate.h"
#include "chrome/browser/sessions/base_session_service.h"
#include "chrome/browser/sessions/session_service_test_helper.h"
-#include "chrome/browser/tab_contents/tab_contents.h"
-#include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h"
+#include "chrome/browser/sessions/session_types.h"
#include "chrome/test/live_sync/live_sync_test.h"
-#include "chrome/test/ui_test_utils.h"
-#include "googleurl/src/gurl.h"
-#include "webkit/glue/window_open_disposition.h"
+
+class GURL;
+class Profile;
+class TabContents;
// Helper for accessing session service internals.
class TestSessionService
: public SessionServiceTestHelper,
public base::RefCountedThreadSafe<TestSessionService> {
public:
- TestSessionService()
- : SessionServiceTestHelper(),
- done_saving_(false, false),
- got_windows_(false, false),
- profile_(NULL),
- window_bounds_(0, 1, 2, 3) {}
- TestSessionService(SessionService* service, Profile* profile)
- : SessionServiceTestHelper(service),
- done_saving_(false, false),
- got_windows_(false, false),
- profile_(profile),
- window_bounds_(0, 1, 2, 3) {}
-
- void SetUp() {
- ASSERT_TRUE(service()) << "SetUp() called without setting SessionService";
- ASSERT_TRUE(profile_);
- service()->SetWindowType(window_id_, Browser::TYPE_NORMAL);
- service()->SetWindowBounds(window_id_, window_bounds_, false);
- }
+ TestSessionService();
+ TestSessionService(SessionService* service, Profile* profile);
+
+ void SetUp();
// Trigger saving the current session commands to file.
- void Save() {
- service()->Save();
- }
+ void Save();
// Synchronously reads the contents of the current session.
- std::vector<SessionWindow*>* ReadWindows() {
- // The session backend will post the callback as a task to whatever thread
- // called it. In our case, we don't want the main test thread to have tasks
- // posted to, so we perform the actual call to session service from the same
- // thread the work will be done on (backend_thread aka file thread). As a
- // result, it will directly call back, instead of posting a task, and we can
- // block on that callback.
- BrowserThread::PostTask(
- BrowserThread::FILE,
- FROM_HERE,
- NewRunnableMethod(this, &TestSessionService::DoReadWindows));
-
- // Wait for callback to happen.
- got_windows_.Wait();
-
- // By the time we reach here we've received the windows, so return them.
- return windows_;
- }
+ std::vector<SessionWindow*>* ReadWindows();
// Makes the actual call to session service.
// Lives on the file thread.
- void DoReadWindows() {
- if (!BrowserThread::CurrentlyOn(BrowserThread::FILE)) {
- LOG(ERROR) << "DoReadWindows called from wrong thread!";
- windows_ = NULL;
- got_windows_.Signal();
- return;
- }
- SessionService::SessionCallback* callback =
- NewCallback(this, &TestSessionService::OnGotSession);
- service()->GetCurrentSession(&consumer_, callback);
- }
+ void DoReadWindows();
// Internal method used in the callback to obtain the current session.
// Lives on and called from backend thread (file_thread).
// We don't own windows so need to make a deep copy.
// In this case, we only copy those values compared against in WindowsMatch
// (number of windows, number of tabs, and navigations within tabs).
- void OnGotSession(int handle, std::vector<SessionWindow*>* windows) {
- scoped_ptr<ForeignSession> foreign_session(new ForeignSession());
- for (size_t w = 0; w < windows->size(); ++w) {
- const SessionWindow& window = *windows->at(w);
- scoped_ptr<SessionWindow> new_window(new SessionWindow());
- for (size_t t = 0; t < window.tabs.size(); ++t) {
- const SessionTab& tab = *window.tabs.at(t);
- scoped_ptr<SessionTab> new_tab(new SessionTab());
- new_tab->navigations.resize(tab.navigations.size());
- std::copy(tab.navigations.begin(), tab.navigations.end(),
- new_tab->navigations.begin());
- new_window->tabs.push_back(new_tab.release());
- }
- foreign_session->windows.push_back(new_window.release());
- }
- windows_ = &(foreign_session->windows);
- foreign_sessions_.push_back(foreign_session.release());
- got_windows_.Signal();
- }
+ void OnGotSession(int handle, std::vector<SessionWindow*>* windows);
private:
- ~TestSessionService() {
- ReleaseService(); // We don't own this, so don't destroy it.
- }
+ virtual ~TestSessionService();
friend class base::RefCountedThreadSafe<TestSessionService>;
@@ -148,177 +81,67 @@ class TestSessionService
class LiveSessionsSyncTest : public LiveSyncTest {
public:
- explicit LiveSessionsSyncTest(TestType test_type)
- : LiveSyncTest(test_type),
- done_closing_(false, false) {}
- virtual ~LiveSessionsSyncTest() {}
+ explicit LiveSessionsSyncTest(TestType test_type);
+ virtual ~LiveSessionsSyncTest();
// Used to access the session service associated with a specific sync profile.
- SessionService* GetSessionService(int index) {
- return GetProfile(index)->GetSessionService();
- }
+ SessionService* GetSessionService(int index);
// Used to access the session service test helper associated with a specific
// sync profile.
- TestSessionService* GetHelper(int index) {
- return test_session_services_[index]->get();
- }
+ TestSessionService* GetHelper(int index);
// Used to access the browser associated with a specific sync profile.
- Browser* GetBrowser(int index) {
- return browsers_[index];
- }
+ Browser* GetBrowser(int index);
// Sets up the TestSessionService helper and the new browser windows.
- bool SetupClients() {
- if (!LiveSyncTest::SetupClients()) {
- return false;
- }
-
- // Go through and make the TestSessionServices and Browsers.
- for (int i = 0; i < num_clients(); ++i) {
- scoped_refptr<TestSessionService>* new_tester =
- new scoped_refptr<TestSessionService>;
- *new_tester = new TestSessionService(
- GetSessionService(i), GetProfile(i));
- test_session_services_.push_back(new_tester);
- GetHelper(i)->SetUp();
-
- browsers_.push_back(Browser::Create(GetProfile(i)));
- }
-
- return true;
- }
+ bool SetupClients();
// Open a single tab and return the TabContents. TabContents must be checked
// to ensure the tab opened successsfully.
- TabContents* OpenTab(int index, GURL url) WARN_UNUSED_RESULT {
- TabContents* tab = GetBrowser(index)->
- AddSelectedTabWithURL(url, PageTransition::START_PAGE)->tab_contents();
-
- // Wait for the page to finish loading.
- ui_test_utils::WaitForNavigation(
- &GetBrowser(index)->GetSelectedTabContents()->controller());
-
- return tab;
- }
+ TabContents* OpenTab(int index, GURL url) WARN_UNUSED_RESULT;
// Creates and verifies the creation of a new window with one tab displaying
// the specified GURL.
// Returns: the SessionWindow associated with the new window.
std::vector<SessionWindow*>* InitializeNewWindowWithTab(int index, GURL url)
- WARN_UNUSED_RESULT {
- if (!OpenTab(index, url)) {
- return NULL;
- }
- GetHelper(index)->Save();
- std::vector<SessionWindow*>* windows = GetHelper(index)->ReadWindows();
- if (windows->size() != 1) {
- LOG(ERROR) << "InitializeNewWindowWithTab called with open windows!";
- return NULL;
- }
- if (1U != (*windows)[0]->tabs.size())
- return NULL;
- SortSessionWindows(windows);
- return windows;
- }
+ WARN_UNUSED_RESULT;
// Checks that window count and foreign session count are 0.
- bool CheckInitialState(int index) WARN_UNUSED_RESULT {
- if (0 != GetNumWindows(index))
- return false;
- if (0 != GetNumForeignSessions(index))
- return false;
- return true;
- }
+ bool CheckInitialState(int index) WARN_UNUSED_RESULT;
// Returns number of open windows for a profile.
- int GetNumWindows(int index) {
- // We don't own windows.
- std::vector<SessionWindow*>* windows = GetHelper(index)->ReadWindows();
- return windows->size();
- }
+ int GetNumWindows(int index);
// Returns number of foreign sessions for a profile.
- int GetNumForeignSessions(int index) {
- std::vector<const ForeignSession*> sessions;
- if (!GetProfile(index)->GetProfileSyncService()->
- GetSessionModelAssociator()->GetAllForeignSessions(&sessions))
- return 0;
- return sessions.size();
- }
+ int GetNumForeignSessions(int index);
// Fills the sessions vector with the model associator's foreign session data.
// Caller owns |sessions|, but not ForeignSession objects within.
bool GetSessionData(int index, std::vector<const ForeignSession*>* sessions)
- WARN_UNUSED_RESULT {
- if (!GetProfile(index)->GetProfileSyncService()->
- GetSessionModelAssociator()->GetAllForeignSessions(sessions))
- return false;
- SortForeignSessions(sessions);
- return true;
- }
+ WARN_UNUSED_RESULT;
// Compare session windows based on their first tab's url.
// Returns true if the virtual url of the lhs is < the rhs.
- static bool CompareSessionWindows(SessionWindow* lhs, SessionWindow* rhs) {
- if (!lhs ||
- !rhs ||
- lhs->tabs.size() < 1 ||
- rhs->tabs.size() < 1 ||
- lhs->tabs[0]->navigations.size() < 1 ||
- rhs->tabs[0]->navigations.size() < 1) {
- // Catchall for uncomparable data.
- return false;
- }
-
- return lhs->tabs[0]->navigations[0].virtual_url() <
- rhs->tabs[0]->navigations[0].virtual_url();
- }
+ static bool CompareSessionWindows(SessionWindow* lhs, SessionWindow* rhs);
// Sort session windows using our custom comparator (first tab url
// comparison).
- void SortSessionWindows(std::vector<SessionWindow*>* windows) {
- std::sort(windows->begin(), windows->end(),
- LiveSessionsSyncTest::CompareSessionWindows);
- }
+ void SortSessionWindows(std::vector<SessionWindow*>* windows);
// Compares a foreign session based on the first session window.
// Returns true based on the comparison of the session windows.
static bool CompareForeignSessions(
const ForeignSession* lhs,
- const ForeignSession* rhs) {
- if (!lhs ||
- !rhs ||
- lhs->windows.size() < 1 ||
- rhs->windows.size() < 1) {
- // Catchall for uncomparable data.
- return false;
- }
-
- return CompareSessionWindows(lhs->windows[0], rhs->windows[0]);
- }
+ const ForeignSession* rhs);
// Sort a foreign session vector using our custom foreign session comparator.
- void SortForeignSessions(std::vector<const ForeignSession*>* sessions) {
- std::sort(sessions->begin(), sessions->end(),
- LiveSessionsSyncTest::CompareForeignSessions);
- }
+ void SortForeignSessions(std::vector<const ForeignSession*>* sessions);
// Compares two tab navigations base on the parameters we sync.
// (Namely, we don't sync state or type mask)
bool NavigationEquals(const TabNavigation& expected,
- const TabNavigation& actual) {
- if (expected.virtual_url() != actual.virtual_url())
- return false;
- if (expected.referrer() != actual.referrer())
- return false;
- if (expected.title() != actual.title())
- return false;
- if (expected.transition() != actual.transition())
- return false;
- return true;
- }
+ const TabNavigation& actual);
// Verifies that two SessionWindows match.
// Returns:
@@ -329,28 +152,7 @@ class LiveSessionsSyncTest : public LiveSyncTest {
// 4. actual tab navigations contents
// - false otherwise.
bool WindowsMatch(const std::vector<SessionWindow*> &win1,
- const std::vector<SessionWindow*> &win2) WARN_UNUSED_RESULT {
- SessionTab* client0_tab;
- SessionTab* client1_tab;
- if (win1.size() != win2.size())
- return false;
- for (size_t i = 0; i < win1.size(); ++i) {
- if (win1[i]->tabs.size() != win2[i]->tabs.size())
- return false;
- for (size_t j = 0; j < win1[i]->tabs.size(); ++j) {
- client0_tab = win1[i]->tabs[j];
- client1_tab = win2[i]->tabs[j];
- for (size_t k = 0; k < client0_tab->navigations.size(); ++k) {
- if (!NavigationEquals(client0_tab->navigations[k],
- client1_tab->navigations[k])) {
- return false;
- }
- }
- }
- }
-
- return true;
- }
+ const std::vector<SessionWindow*> &win2) WARN_UNUSED_RESULT;
// Retrieves the foreign sessions for a particular profile and compares them
// with a reference SessionWindow list.
@@ -358,39 +160,11 @@ class LiveSessionsSyncTest : public LiveSyncTest {
// reference.
bool CheckForeignSessionsAgainst(int index,
const std::vector<std::vector<SessionWindow*>* >& windows)
- WARN_UNUSED_RESULT {
- std::vector<const ForeignSession*> sessions;
- if (!GetSessionData(index, &sessions))
- return false;
- if ((size_t)(num_clients()-1) != sessions.size())
- return false;
-
- int window_index = 0;
- for (size_t j = 0; j < sessions.size(); ++j, ++window_index) {
- if (window_index == index)
- window_index++; // Skip self.
- if (!WindowsMatch(sessions[j]->windows, *windows[window_index]))
- return false;
- }
-
- return true;
- }
+ WARN_UNUSED_RESULT;
protected:
// Clean up our mess.
- virtual void CleanUpOnMainThread() {
- // Close all browsers. We need to do this now, as opposed to letting the
- // test framework handle it, because we created our own browser for each
- // sync profile.
- BrowserList::CloseAllBrowsers();
- ui_test_utils::RunAllPendingInMessageLoop();
-
- // All browsers should be closed at this point, else when the framework
- // calls QuitBrowsers() we could see memory corruption.
- ASSERT_EQ(0U, BrowserList::size());
-
- LiveSyncTest::CleanUpOnMainThread();
- }
+ virtual void CleanUpOnMainThread();
// Vector of our TestSessionService helpers.
ScopedVector<scoped_refptr<TestSessionService> > test_session_services_;
diff --git a/chrome/test/live_sync/live_sync_test.cc b/chrome/test/live_sync/live_sync_test.cc
index 21146e9..e9ac0f3 100644
--- a/chrome/test/live_sync/live_sync_test.cc
+++ b/chrome/test/live_sync/live_sync_test.cc
@@ -20,10 +20,12 @@
#include "chrome/browser/password_manager/encryptor.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/profiles/profile_manager.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/net/url_fetcher.h"
#include "chrome/common/net/url_request_context_getter.h"
+#include "chrome/common/net/test_url_fetcher_factory.h"
#include "chrome/test/testing_browser_process.h"
#include "chrome/test/ui_test_utils.h"
#include "googleurl/src/gurl.h"
@@ -126,6 +128,8 @@ LiveSyncTest::LiveSyncTest(TestType test_type)
}
}
+LiveSyncTest::~LiveSyncTest() {}
+
void LiveSyncTest::SetUp() {
CommandLine* cl = CommandLine::ForCurrentProcess();
if (cl->HasSwitch(switches::kPasswordFileForTest)) {
diff --git a/chrome/test/live_sync/live_sync_test.h b/chrome/test/live_sync/live_sync_test.h
index 21c3cf8..2c6bb5b 100644
--- a/chrome/test/live_sync/live_sync_test.h
+++ b/chrome/test/live_sync/live_sync_test.h
@@ -13,8 +13,6 @@
#include "base/process_util.h"
#include "base/scoped_ptr.h"
#include "base/scoped_vector.h"
-#include "chrome/browser/sync/profile_sync_service_harness.h"
-#include "chrome/common/net/test_url_fetcher_factory.h"
#include "net/base/mock_host_resolver.h"
#include "net/test/test_server.h"
@@ -23,7 +21,9 @@
class CommandLine;
class Profile;
+class ProfileSyncServiceHarness;
class URLRequestContextGetter;
+class FakeURLFetcherFactory;
namespace net {
class ProxyConfig;
@@ -58,7 +58,7 @@ class LiveSyncTest : public InProcessBrowserTest {
// A LiveSyncTest must be associated with a particular test type.
explicit LiveSyncTest(TestType test_type);
- virtual ~LiveSyncTest() {}
+ virtual ~LiveSyncTest();
// Validates command line parameters and creates a local python test server if
// specified.
diff --git a/chrome/test/live_sync/many_client_live_bookmarks_sync_test.cc b/chrome/test/live_sync/many_client_live_bookmarks_sync_test.cc
index eae27fd..4ea96b0 100644
--- a/chrome/test/live_sync/many_client_live_bookmarks_sync_test.cc
+++ b/chrome/test/live_sync/many_client_live_bookmarks_sync_test.cc
@@ -1,10 +1,10 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_bookmarks_sync_test.h"
-
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
+#include "chrome/test/live_sync/live_bookmarks_sync_test.h"
// TODO(rsimha): Enable once http://crbug.com/69604 is fixed.
IN_PROC_BROWSER_TEST_F(ManyClientLiveBookmarksSyncTest, DISABLED_Sanity) {
diff --git a/chrome/test/live_sync/many_client_live_passwords_sync_test.cc b/chrome/test/live_sync/many_client_live_passwords_sync_test.cc
index 7f7b0a6..e4e54bd 100644
--- a/chrome/test/live_sync/many_client_live_passwords_sync_test.cc
+++ b/chrome/test/live_sync/many_client_live_passwords_sync_test.cc
@@ -1,8 +1,10 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/utf_string_conversions.h"
#include "chrome/browser/password_manager/password_form_data.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_passwords_sync_test.h"
using webkit_glue::PasswordForm;
diff --git a/chrome/test/live_sync/many_client_live_preferences_sync_test.cc b/chrome/test/live_sync/many_client_live_preferences_sync_test.cc
index dd3daad..db132f4 100644
--- a/chrome/test/live_sync/many_client_live_preferences_sync_test.cc
+++ b/chrome/test/live_sync/many_client_live_preferences_sync_test.cc
@@ -1,7 +1,8 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/pref_names.h"
#include "chrome/test/live_sync/live_preferences_sync_test.h"
diff --git a/chrome/test/live_sync/multiple_client_live_passwords_sync_test.cc b/chrome/test/live_sync/multiple_client_live_passwords_sync_test.cc
index 0b23e35..bc50048 100644
--- a/chrome/test/live_sync/multiple_client_live_passwords_sync_test.cc
+++ b/chrome/test/live_sync/multiple_client_live_passwords_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/stringprintf.h"
+#include "base/utf_string_conversions.h"
#include "chrome/browser/password_manager/password_form_data.h"
#include "chrome/test/live_sync/live_passwords_sync_test.h"
diff --git a/chrome/test/live_sync/multiple_client_live_preferences_sync_test.cc b/chrome/test/live_sync/multiple_client_live_preferences_sync_test.cc
index 45adf2c..d14c36a 100644
--- a/chrome/test/live_sync/multiple_client_live_preferences_sync_test.cc
+++ b/chrome/test/live_sync/multiple_client_live_preferences_sync_test.cc
@@ -1,10 +1,11 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/scoped_ptr.h"
#include "base/string_util.h"
#include "chrome/browser/prefs/scoped_pref_update.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/pref_names.h"
#include "chrome/test/live_sync/live_preferences_sync_test.h"
diff --git a/chrome/test/live_sync/multiple_client_live_sessions_sync_test.cc b/chrome/test/live_sync/multiple_client_live_sessions_sync_test.cc
index f5e8e1e..5183b0b 100644
--- a/chrome/test/live_sync/multiple_client_live_sessions_sync_test.cc
+++ b/chrome/test/live_sync/multiple_client_live_sessions_sync_test.cc
@@ -1,8 +1,10 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/stringprintf.h"
+#include "chrome/browser/sessions/session_service.h"
+#include "chrome/browser/sync/profile_sync_service.h"
#include "chrome/test/live_sync/live_sessions_sync_test.h"
IN_PROC_BROWSER_TEST_F(MultipleClientLiveSessionsSyncTest, AllChanged) {
diff --git a/chrome/test/live_sync/single_client_live_bookmarks_sync_test.cc b/chrome/test/live_sync/single_client_live_bookmarks_sync_test.cc
index 33c0b50..75cb8e4 100644
--- a/chrome/test/live_sync/single_client_live_bookmarks_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_bookmarks_sync_test.cc
@@ -1,10 +1,10 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_bookmarks_sync_test.h"
-
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
+#include "chrome/test/live_sync/live_bookmarks_sync_test.h"
IN_PROC_BROWSER_TEST_F(SingleClientLiveBookmarksSyncTest, OfflineToOnline) {
ASSERT_TRUE(SetupSync()) << "SetupSync() failed.";
diff --git a/chrome/test/live_sync/single_client_live_extensions_sync_test.cc b/chrome/test/live_sync/single_client_live_extensions_sync_test.cc
index 512337f..801ea6a 100644
--- a/chrome/test/live_sync/single_client_live_extensions_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_extensions_sync_test.cc
@@ -1,12 +1,12 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_extensions_sync_test.h"
-
#include "base/basictypes.h"
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/extensions/extension.h"
+#include "chrome/test/live_sync/live_extensions_sync_test.h"
class SingleClientLiveExtensionsSyncTest : public LiveExtensionsSyncTest {
public:
diff --git a/chrome/test/live_sync/single_client_live_passwords_sync_test.cc b/chrome/test/live_sync/single_client_live_passwords_sync_test.cc
index ffeacd8..400eb1b6 100644
--- a/chrome/test/live_sync/single_client_live_passwords_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_passwords_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/browser/password_manager/password_form_data.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_passwords_sync_test.h"
using webkit_glue::PasswordForm;
diff --git a/chrome/test/live_sync/single_client_live_preferences_sync_test.cc b/chrome/test/live_sync/single_client_live_preferences_sync_test.cc
index 6782f04..6333ac9 100644
--- a/chrome/test/live_sync/single_client_live_preferences_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_preferences_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/common/pref_names.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_preferences_sync_test.h"
IN_PROC_BROWSER_TEST_F(SingleClientLivePreferencesSyncTest, Sanity) {
diff --git a/chrome/test/live_sync/single_client_live_sessions_sync_test.cc b/chrome/test/live_sync/single_client_live_sessions_sync_test.cc
index 446dbd7..02de47d 100644
--- a/chrome/test/live_sync/single_client_live_sessions_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_sessions_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/scoped_vector.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_sessions_sync_test.h"
IN_PROC_BROWSER_TEST_F(SingleClientLiveSessionsSyncTest, Sanity) {
diff --git a/chrome/test/live_sync/single_client_live_themes_sync_test.cc b/chrome/test/live_sync/single_client_live_themes_sync_test.cc
index ea45c60..c901947 100644
--- a/chrome/test/live_sync/single_client_live_themes_sync_test.cc
+++ b/chrome/test/live_sync/single_client_live_themes_sync_test.cc
@@ -1,12 +1,12 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_themes_sync_test.h"
-
#include "base/basictypes.h"
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/extensions/extension.h"
+#include "chrome/test/live_sync/live_themes_sync_test.h"
class SingleClientLiveThemesSyncTest : public LiveThemesSyncTest {
public:
diff --git a/chrome/test/live_sync/two_client_live_autofill_sync_test.cc b/chrome/test/live_sync/two_client_live_autofill_sync_test.cc
index 6a9a55e..263eaef 100644
--- a/chrome/test/live_sync/two_client_live_autofill_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_autofill_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/utf_string_conversions.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_autofill_sync_test.h"
IN_PROC_BROWSER_TEST_F(TwoClientLiveAutofillSyncTest, WebDataServiceSanity) {
diff --git a/chrome/test/live_sync/two_client_live_bookmarks_sync_test.cc b/chrome/test/live_sync/two_client_live_bookmarks_sync_test.cc
index 7255c9f..4af52a1 100644
--- a/chrome/test/live_sync/two_client_live_bookmarks_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_bookmarks_sync_test.cc
@@ -1,12 +1,12 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_bookmarks_sync_test.h"
-
#include "base/rand_util.h"
#include "base/stringprintf.h"
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
+#include "chrome/test/live_sync/live_bookmarks_sync_test.h"
const std::string kGenericURL = "http://www.host.ext:1234/path/filename";
const std::wstring kGenericURLTitle = L"URL Title";
diff --git a/chrome/test/live_sync/two_client_live_passwords_sync_test.cc b/chrome/test/live_sync/two_client_live_passwords_sync_test.cc
index 6e77859..e308104 100644
--- a/chrome/test/live_sync/two_client_live_passwords_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_passwords_sync_test.cc
@@ -1,8 +1,10 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "base/utf_string_conversions.h"
#include "chrome/browser/password_manager/password_form_data.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/browser/sync/sessions/session_state.h"
#include "chrome/test/live_sync/live_passwords_sync_test.h"
diff --git a/chrome/test/live_sync/two_client_live_preferences_sync_test.cc b/chrome/test/live_sync/two_client_live_preferences_sync_test.cc
index d0f65a1..aa1e319 100644
--- a/chrome/test/live_sync/two_client_live_preferences_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_preferences_sync_test.cc
@@ -1,8 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/browser/prefs/scoped_pref_update.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/browser/translate/translate_prefs.h"
#include "chrome/common/pref_names.h"
#include "chrome/test/live_sync/live_preferences_sync_test.h"
diff --git a/chrome/test/live_sync/two_client_live_sessions_sync_test.cc b/chrome/test/live_sync/two_client_live_sessions_sync_test.cc
index e493e8e..7294c07 100644
--- a/chrome/test/live_sync/two_client_live_sessions_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_sessions_sync_test.cc
@@ -1,7 +1,9 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/browser/sessions/session_service.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/test/live_sync/live_sessions_sync_test.h"
// @TODO(zea): Test each individual session command we care about separately.
diff --git a/chrome/test/live_sync/two_client_live_themes_sync_test.cc b/chrome/test/live_sync/two_client_live_themes_sync_test.cc
index 18c5d19..29ba596 100644
--- a/chrome/test/live_sync/two_client_live_themes_sync_test.cc
+++ b/chrome/test/live_sync/two_client_live_themes_sync_test.cc
@@ -1,12 +1,12 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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 "chrome/test/live_sync/live_themes_sync_test.h"
-
#include "base/basictypes.h"
#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service_harness.h"
#include "chrome/common/extensions/extension.h"
+#include "chrome/test/live_sync/live_themes_sync_test.h"
class TwoClientLiveThemesSyncTest : public LiveThemesSyncTest {
public:
diff --git a/chrome/test/sync/engine/test_directory_setter_upper.cc b/chrome/test/sync/engine/test_directory_setter_upper.cc
index 9777b32..a0e4431 100644
--- a/chrome/test/sync/engine/test_directory_setter_upper.cc
+++ b/chrome/test/sync/engine/test_directory_setter_upper.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// 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.
@@ -125,6 +125,8 @@ MockDirectorySetterUpper::MockDirectorySetterUpper()
: directory_(new MockDirectory(name())) {
}
+MockDirectorySetterUpper::~MockDirectorySetterUpper() {}
+
void MockDirectorySetterUpper::SetUp() {
reset_directory_manager(new Manager(FilePath(), directory_.get()));
}
diff --git a/chrome/test/sync/engine/test_directory_setter_upper.h b/chrome/test/sync/engine/test_directory_setter_upper.h
index fc5eb6f..00847ee 100644
--- a/chrome/test/sync/engine/test_directory_setter_upper.h
+++ b/chrome/test/sync/engine/test_directory_setter_upper.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// 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.
//
@@ -121,6 +121,7 @@ class MockDirectorySetterUpper : public TestDirectorySetterUpper {
};
MockDirectorySetterUpper();
+ virtual ~MockDirectorySetterUpper();
virtual void SetUp();
virtual void TearDown();
diff --git a/chrome/test/webdriver/automation.cc b/chrome/test/webdriver/automation.cc
index e0cd968..e0afa4d 100644
--- a/chrome/test/webdriver/automation.cc
+++ b/chrome/test/webdriver/automation.cc
@@ -8,11 +8,17 @@
#include "base/logging.h"
#include "base/utf_string_conversions.h"
#include "chrome/common/chrome_switches.h"
+#include "chrome/test/automation/browser_proxy.h"
+#include "chrome/test/automation/tab_proxy.h"
#include "chrome/test/test_launcher_utils.h"
#include "googleurl/src/gurl.h"
namespace webdriver {
+Automation::Automation() {}
+
+Automation::~Automation() {}
+
void Automation::Init(bool* success) {
*success = false;
diff --git a/chrome/test/webdriver/automation.h b/chrome/test/webdriver/automation.h
index 4bf8758..10ab4a1 100644
--- a/chrome/test/webdriver/automation.h
+++ b/chrome/test/webdriver/automation.h
@@ -10,8 +10,6 @@
#include "base/task.h"
#include "base/ref_counted.h"
#include "base/scoped_temp_dir.h"
-#include "chrome/test/automation/browser_proxy.h"
-#include "chrome/test/automation/tab_proxy.h"
#include "chrome/test/ui/ui_test.h"
namespace webdriver {
@@ -22,7 +20,8 @@ namespace webdriver {
// http://code.google.com/p/chromium/issues/detail?id=56865
class Automation : private UITestBase {
public:
- Automation() {}
+ Automation();
+ virtual ~Automation();
// Creates a browser.
void Init(bool* success);
diff --git a/chrome/test/webdriver/commands/command.cc b/chrome/test/webdriver/commands/command.cc
index 3cf81bd..142c947 100644
--- a/chrome/test/webdriver/commands/command.cc
+++ b/chrome/test/webdriver/commands/command.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -17,6 +17,29 @@ const char* const Response::kStackTrace = "stackTrace";
const char* const Response::kFileName = "fileName";
const char* const Response::kLineNumber = "lineNumber";
+Command::Command(const std::vector<std::string>& path_segments,
+ const DictionaryValue* const parameters)
+ : path_segments_(path_segments),
+ parameters_(parameters) {}
+
+Command::~Command() {}
+
+bool Command::DoesDelete() {
+ return false;
+}
+
+bool Command::DoesGet() {
+ return false;
+}
+
+bool Command::DoesPost() {
+ return false;
+}
+
+bool Command::Init(Response* const response) {
+ return true;
+}
+
bool Command::GetStringParameter(const std::string& key,
string16* out) const {
return parameters_.get() != NULL && parameters_->GetString(key, out);
diff --git a/chrome/test/webdriver/commands/command.h b/chrome/test/webdriver/commands/command.h
index 6d06033..ccb95b8 100644
--- a/chrome/test/webdriver/commands/command.h
+++ b/chrome/test/webdriver/commands/command.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -24,21 +24,19 @@ namespace webdriver {
// http://code.google.com/p/selenium/wiki/JsonWireProtocol
class Command {
public:
- inline Command(const std::vector<std::string>& path_segments,
- const DictionaryValue* const parameters)
- : path_segments_(path_segments),
- parameters_(parameters) {}
- virtual ~Command() {}
+ Command(const std::vector<std::string>& path_segments,
+ const DictionaryValue* const parameters);
+ virtual ~Command();
// Indicates which HTTP methods this command URL responds to.
- virtual bool DoesDelete() { return false; }
- virtual bool DoesGet() { return false; }
- virtual bool DoesPost() { return false; }
+ virtual bool DoesDelete();
+ virtual bool DoesGet();
+ virtual bool DoesPost();
// Initializes this command for execution. If initialization fails, will
// return |false| and populate the |response| with the necessary information
// to return to the client.
- virtual bool Init(Response* const response) { return true; }
+ virtual bool Init(Response* const response);
// Executes the corresponding variant of this command URL.
// Always called after |Init()| and called from the Execute function.
diff --git a/chrome/test/webdriver/commands/find_element_commands.cc b/chrome/test/webdriver/commands/find_element_commands.cc
index 94d82c8..16f2454 100644
--- a/chrome/test/webdriver/commands/find_element_commands.cc
+++ b/chrome/test/webdriver/commands/find_element_commands.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -17,6 +17,15 @@
namespace webdriver {
+FindElementCommand::FindElementCommand(
+ const std::vector<std::string>& path_segments,
+ const DictionaryValue* const parameters,
+ const bool find_one_element)
+ : WebDriverCommand(path_segments, parameters),
+ find_one_element_(find_one_element) {}
+
+FindElementCommand::~FindElementCommand() {}
+
bool FindElementCommand::Init(Response* const response) {
if (!WebDriverCommand::Init(response)) {
SET_WEBDRIVER_ERROR(response, "Failure on Init for find element",
@@ -49,6 +58,10 @@ bool FindElementCommand::Init(Response* const response) {
return true;
}
+bool FindElementCommand::DoesPost() {
+ return true;
+}
+
void FindElementCommand::ExecutePost(Response* const response) {
scoped_ptr<ListValue> args(new ListValue());
DictionaryValue* locator = new DictionaryValue();
@@ -108,5 +121,9 @@ void FindElementCommand::ExecutePost(Response* const response) {
response->set_status(error);
}
+bool FindElementCommand::RequiresValidTab() {
+ return false;
+}
+
} // namespace webdriver
diff --git a/chrome/test/webdriver/commands/find_element_commands.h b/chrome/test/webdriver/commands/find_element_commands.h
index cc45d10..b9a6250 100644
--- a/chrome/test/webdriver/commands/find_element_commands.h
+++ b/chrome/test/webdriver/commands/find_element_commands.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -19,18 +19,16 @@ class FindElementCommand : public WebDriverCommand {
public:
FindElementCommand(const std::vector<std::string>& path_segments,
const DictionaryValue* const parameters,
- const bool find_one_element)
- : WebDriverCommand(path_segments, parameters),
- find_one_element_(find_one_element) {}
- virtual ~FindElementCommand() {}
+ const bool find_one_element);
+ virtual ~FindElementCommand();
virtual bool Init(Response* const response);
- virtual bool DoesPost() { return true; }
+ virtual bool DoesPost();
virtual void ExecutePost(Response* const response);
private:
- virtual bool RequiresValidTab() { return false; }
+ virtual bool RequiresValidTab();
const bool find_one_element_;
std::string root_element_id_;
std::string use_;
diff --git a/chrome/test/webdriver/keymap.cc b/chrome/test/webdriver/keymap.cc
index e1c3fec..c3080d7 100644
--- a/chrome/test/webdriver/keymap.cc
+++ b/chrome/test/webdriver/keymap.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -118,6 +118,8 @@ KeyMap::KeyMap() {
shifted_keys_[L')'] = ui::VKEY_0;
}
+KeyMap::~KeyMap() {}
+
ui::KeyboardCode KeyMap::Get(const wchar_t& key) const {
std::map<wchar_t, ui::KeyboardCode>::const_iterator it;
it = keys_.find(key);
diff --git a/chrome/test/webdriver/keymap.h b/chrome/test/webdriver/keymap.h
index fab2bcc..3b98d54 100644
--- a/chrome/test/webdriver/keymap.h
+++ b/chrome/test/webdriver/keymap.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -16,6 +16,7 @@ namespace webdriver {
class KeyMap {
public:
KeyMap();
+ ~KeyMap();
ui::KeyboardCode Get(const wchar_t& key) const;
bool Press(const scoped_refptr<WindowProxy>& window,
diff --git a/chrome/test/webdriver/session.cc b/chrome/test/webdriver/session.cc
index 6c1b026e..00de26c 100644
--- a/chrome/test/webdriver/session.cc
+++ b/chrome/test/webdriver/session.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -34,6 +34,8 @@ Session::Session(const std::string& id)
current_frame_xpath_("") {
}
+Session::~Session() {}
+
bool Session::Init() {
if (!thread_.Start()) {
LOG(ERROR) << "Cannot start session thread";
diff --git a/chrome/test/webdriver/session.h b/chrome/test/webdriver/session.h
index e716e19..8bc5cd5 100644
--- a/chrome/test/webdriver/session.h
+++ b/chrome/test/webdriver/session.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -11,6 +11,9 @@
#include "chrome/test/webdriver/automation.h"
#include "chrome/test/webdriver/error_codes.h"
+class ListValue;
+class Value;
+
namespace base {
class WaitableEvent;
}
@@ -25,6 +28,7 @@ namespace webdriver {
class Session {
public:
explicit Session(const std::string& id);
+ ~Session();
// Creates a browser.
bool Init();
diff --git a/chrome/test/webdriver/session_manager.cc b/chrome/test/webdriver/session_manager.cc
index 0064737..30adf9e 100644
--- a/chrome/test/webdriver/session_manager.cc
+++ b/chrome/test/webdriver/session_manager.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -177,6 +177,10 @@ Session* SessionManager::GetSession(const std::string& id) const {
return it->second;
}
+SessionManager::SessionManager() : addr_(""), port_(""), count_(0) {}
+
+SessionManager::~SessionManager() {}
+
// static
SessionManager* SessionManager::GetInstance() {
return Singleton<SessionManager>::get();
diff --git a/chrome/test/webdriver/session_manager.h b/chrome/test/webdriver/session_manager.h
index c4f8729..959ff84 100644
--- a/chrome/test/webdriver/session_manager.h
+++ b/chrome/test/webdriver/session_manager.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -34,7 +34,8 @@ class SessionManager {
Session* GetSession(const std::string& id) const;
private:
- SessionManager() : addr_(""), port_(""), count_(0) {}
+ SessionManager();
+ ~SessionManager();
friend struct DefaultSingletonTraits<SessionManager>;
std::string GenerateSessionID();
std::string IPLookup(const std::string& nic);
diff --git a/webkit/mocks/mock_webframe.cc b/webkit/mocks/mock_webframe.cc
new file mode 100644
index 0000000..cf382c3
--- /dev/null
+++ b/webkit/mocks/mock_webframe.cc
@@ -0,0 +1,393 @@
+// 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 "webkit/mocks/mock_webframe.h"
+
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLRequest.h"
+
+namespace webkit_glue {
+
+MockWebFrame::MockWebFrame() {}
+
+MockWebFrame::~MockWebFrame() {}
+
+WebString MockWebFrame::name() const {
+ return WebString();
+}
+
+void MockWebFrame::setName(const WebString&) {}
+
+long long MockWebFrame::identifier() const {
+ return 0;
+}
+
+WebURL MockWebFrame::url() const {
+ return WebURL();
+}
+
+WebURL MockWebFrame::favIconURL() const {
+ return WebURL();
+}
+
+WebURL MockWebFrame::openSearchDescriptionURL() const {
+ return WebURL();
+}
+
+WebString MockWebFrame::encoding() const {
+ return WebString();
+}
+
+void MockWebFrame::setCanHaveScrollbars(bool) {}
+
+WebSize MockWebFrame::scrollOffset() const {
+ return WebSize(0,0);
+}
+
+WebSize MockWebFrame::contentsSize() const {
+ return WebSize();
+}
+
+int MockWebFrame::contentsPreferredWidth() const {
+ return 0;
+}
+
+int MockWebFrame::documentElementScrollHeight() const {
+ return 0;
+}
+
+bool MockWebFrame::hasVisibleContent() const {
+ return false;
+}
+
+WebView* MockWebFrame::view() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::opener() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::parent() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::top() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::firstChild() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::lastChild() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::nextSibling() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::previousSibling() const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::traverseNext(bool wrap) const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::traversePrevious(bool wrap) const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::findChildByName(const WebString& name) const {
+ return NULL;
+}
+
+WebFrame* MockWebFrame::findChildByExpression(const WebString& xpath) const {
+ return NULL;
+}
+
+WebDocument MockWebFrame::document() const {
+ return WebDocument();
+}
+
+void MockWebFrame::forms(WebVector<WebFormElement>&) const {}
+
+WebAnimationController* MockWebFrame::animationController() {
+ return NULL;
+}
+
+WebPerformance MockWebFrame::performance() const {
+ return WebPerformance();
+}
+
+WebSecurityOrigin MockWebFrame::securityOrigin() const {
+ return WebSecurityOrigin();
+}
+
+void MockWebFrame::grantUniversalAccess() {}
+
+NPObject* MockWebFrame::windowObject() const {
+ return NULL;
+}
+
+void MockWebFrame::bindToWindowObject(const WebString& name, NPObject*) {}
+
+void MockWebFrame::executeScript(const WebScriptSource&) {}
+
+void MockWebFrame::executeScriptInIsolatedWorld(
+ int worldId, const WebScriptSource* sources, unsigned numSources,
+ int extensionGroup) {}
+
+void MockWebFrame::addMessageToConsole(const WebConsoleMessage&) {}
+
+void MockWebFrame::collectGarbage() {}
+
+#if WEBKIT_USING_V8
+v8::Handle<v8::Value> MockWebFrame::executeScriptAndReturnValue(
+ const WebScriptSource&) {
+ return v8::Handle<v8::Value>();
+}
+
+v8::Local<v8::Context> MockWebFrame::mainWorldScriptContext() const {
+ return v8::Local<v8::Context>();
+}
+#endif
+
+
+bool MockWebFrame::insertStyleText(const WebString& styleText,
+ const WebString& elementId) {
+ return false;
+}
+
+void MockWebFrame::reload(bool ignoreCache) {}
+
+void MockWebFrame::loadRequest(const WebURLRequest&) {}
+
+void MockWebFrame::loadHistoryItem(const WebHistoryItem&) {}
+
+void MockWebFrame::loadData(const WebData& data,
+ const WebString& mimeType,
+ const WebString& textEncoding,
+ const WebURL& baseURL,
+ const WebURL& unreachableURL,
+ bool replace) {}
+
+void MockWebFrame::loadHTMLString(const WebData& html,
+ const WebURL& baseURL,
+ const WebURL& unreachableURL,
+ bool replace) {}
+
+bool MockWebFrame::isLoading() const {
+ return false;
+}
+
+void MockWebFrame::stopLoading() {}
+
+WebKit::WebDataSource* MockWebFrame::provisionalDataSource() const {
+ return NULL;
+}
+
+WebKit::WebDataSource* MockWebFrame::dataSource() const {
+ return NULL;
+}
+
+WebHistoryItem MockWebFrame::previousHistoryItem() const {
+ return WebHistoryItem();
+}
+
+WebHistoryItem MockWebFrame::currentHistoryItem() const {
+ return WebHistoryItem();
+}
+
+void MockWebFrame::enableViewSourceMode(bool) {}
+
+bool MockWebFrame::isViewSourceModeEnabled() const {
+ return false;
+}
+
+WebURLLoader* MockWebFrame::createAssociatedURLLoader() {
+ return NULL;
+}
+
+void MockWebFrame::commitDocumentData(const char* data, size_t length) {}
+
+unsigned MockWebFrame::unloadListenerCount() const {
+ return 0;
+}
+
+bool MockWebFrame::isProcessingUserGesture() const {
+ return false;
+}
+
+bool MockWebFrame::willSuppressOpenerInNewFrame() const {
+ return false;
+}
+
+void MockWebFrame::replaceSelection(const WebString& text) {}
+
+void MockWebFrame::insertText(const WebString& text) {}
+
+void MockWebFrame::setMarkedText(const WebString& text,
+ unsigned location,
+ unsigned length) {}
+
+void MockWebFrame::unmarkText() {}
+
+bool MockWebFrame::hasMarkedText() const {
+ return false;
+}
+
+WebRange MockWebFrame::markedRange() const {
+ return WebRange();
+}
+
+bool MockWebFrame::firstRectForCharacterRange(unsigned location,
+ unsigned length,
+ WebRect&) const {
+ return false;
+}
+
+bool MockWebFrame::executeCommand(const WebString&) {
+ return false;
+}
+
+bool MockWebFrame::executeCommand(const WebString&, const WebString& value) {
+ return false;
+}
+
+bool MockWebFrame::isCommandEnabled(const WebString&) const {
+ return false;
+}
+
+void MockWebFrame::enableContinuousSpellChecking(bool) {}
+
+bool MockWebFrame::isContinuousSpellCheckingEnabled() const {
+ return false;
+}
+
+bool MockWebFrame::hasSelection() const {
+ return false;
+}
+
+WebRange MockWebFrame::selectionRange() const {
+ return WebRange();
+}
+
+WebString MockWebFrame::selectionAsText() const {
+ return WebString();
+}
+
+WebString MockWebFrame::selectionAsMarkup() const {
+ return WebString();
+}
+
+bool MockWebFrame::selectWordAroundCaret() {
+ return false;
+}
+
+int MockWebFrame::printBegin(const WebSize& pageSize,
+ const WebNode& constrainToNode,
+ int printerDPI,
+ bool* useBrowserOverlays) {
+ return 0;
+}
+
+float MockWebFrame::getPrintPageShrink(int page) {
+ return 0;
+}
+
+float MockWebFrame::printPage(int pageToPrint, WebCanvas*) {
+ return 0;
+}
+
+void MockWebFrame::printEnd() {}
+
+bool MockWebFrame::isPageBoxVisible(int pageIndex) {
+ return false;
+}
+
+void MockWebFrame::pageSizeAndMarginsInPixels(int pageIndex,
+ WebSize& pageSize,
+ int& marginTop,
+ int& marginRight,
+ int& marginBottom,
+ int& marginLeft) {}
+
+bool MockWebFrame::find(int identifier,
+ const WebString& searchText,
+ const WebFindOptions& options,
+ bool wrapWithinFrame,
+ WebRect* selectionRect) {
+ return false;
+}
+
+void MockWebFrame::stopFinding(bool clearSelection) {}
+
+void MockWebFrame::scopeStringMatches(int identifier,
+ const WebString& searchText,
+ const WebFindOptions& options,
+ bool reset) {}
+
+void MockWebFrame::cancelPendingScopingEffort() {}
+
+void MockWebFrame::increaseMatchCount(int count, int identifier) {}
+
+void MockWebFrame::resetMatchCount() {}
+
+bool MockWebFrame::registerPasswordListener(
+ WebInputElement,
+ WebPasswordAutocompleteListener*) {
+ return false;
+}
+
+void MockWebFrame::notifiyPasswordListenerOfAutocomplete(
+ const WebInputElement&) {}
+
+WebString MockWebFrame::contentAsText(size_t maxChars) const {
+ return WebString();
+}
+
+WebString MockWebFrame::contentAsMarkup() const {
+ return WebString();
+}
+
+WebString MockWebFrame::renderTreeAsText() const {
+ return WebString();
+}
+
+WebString MockWebFrame::counterValueForElementById(const WebString& id) const {
+ return WebString();
+}
+
+WebString MockWebFrame::markerTextForListItem(const WebElement&) const {
+ return WebString();
+}
+
+int MockWebFrame::pageNumberForElementById(const WebString& id,
+ float pageWidthInPixels,
+ float pageHeightInPixels) const {
+ return 0;
+}
+
+WebRect MockWebFrame::selectionBoundsRect() const {
+ return WebRect();
+}
+
+bool MockWebFrame::selectionStartHasSpellingMarkerFor(int from,
+ int length) const {
+ return false;
+}
+
+bool MockWebFrame::pauseSVGAnimation(const WebString& animationId,
+ double time,
+ const WebString& elementId) {
+ return false;
+}
+
+WebString MockWebFrame::layerTreeAsText() const {
+ return WebString();
+}
+
+} // namespace webkit_glue
diff --git a/webkit/mocks/mock_webframe.h b/webkit/mocks/mock_webframe.h
index bf65c5c..e49029d 100644
--- a/webkit/mocks/mock_webframe.h
+++ b/webkit/mocks/mock_webframe.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -48,11 +48,8 @@ namespace webkit_glue {
class MockWebFrame : public WebKit::WebFrame {
public:
- MockWebFrame() {
- }
-
- virtual ~MockWebFrame() {
- }
+ MockWebFrame();
+ virtual ~MockWebFrame();
MOCK_METHOD2(setReferrerForRequest, void(WebURLRequest&, const WebURL&));
MOCK_METHOD1(dispatchWillSendRequest, void(WebURLRequest&));
@@ -65,286 +62,148 @@ class MockWebFrame : public WebKit::WebFrame {
return NULL;
}
- virtual WebString name() const {
- return WebString();
- }
- virtual void setName(const WebString&) {}
- virtual long long identifier() const {
- return 0;
- }
- virtual WebURL url() const {
- return WebURL();
- }
- virtual WebURL favIconURL() const {
- return WebURL();
- }
- virtual WebURL openSearchDescriptionURL() const {
- return WebURL();
- }
- virtual WebString encoding() const {
- return WebString();
- }
- virtual void setCanHaveScrollbars(bool) {}
- virtual WebSize scrollOffset() const {
- return WebSize(0,0);
- }
- virtual WebSize contentsSize() const {
- return WebSize();
- }
- virtual int contentsPreferredWidth() const {
- return 0;
- }
- virtual int documentElementScrollHeight() const {
- return 0;
- }
- virtual bool hasVisibleContent() const {
- return false;
- }
- virtual WebView* view() const {
- return NULL;
- }
- virtual WebFrame* opener() const {
- return NULL;
- }
- virtual WebFrame* parent() const {
- return NULL;
- }
- virtual WebFrame* top() const {
- return NULL;
- }
- virtual WebFrame* firstChild() const {
- return NULL;
- }
- virtual WebFrame* lastChild() const {
- return NULL;
- }
- virtual WebFrame* nextSibling() const {
- return NULL;
- }
- virtual WebFrame* previousSibling() const {
- return NULL;
- }
- virtual WebFrame* traverseNext(bool wrap) const {
- return NULL;
- }
- virtual WebFrame* traversePrevious(bool wrap) const {
- return NULL;
- }
- virtual WebFrame* findChildByName(const WebString& name) const {
- return NULL;
- }
- virtual WebFrame* findChildByExpression(const WebString& xpath) const {
- return NULL;
- }
- virtual WebDocument document() const {
- return WebDocument();
- }
- virtual void forms(WebVector<WebFormElement>&) const {}
- virtual WebAnimationController* animationController() {
- return NULL;
- }
- virtual WebPerformance performance() const {
- return WebPerformance();
- }
- virtual WebSecurityOrigin securityOrigin() const {
- return WebSecurityOrigin();
- }
- virtual void grantUniversalAccess() {}
- virtual NPObject* windowObject() const {
- return NULL;
- }
- virtual void bindToWindowObject(const WebString& name, NPObject*) {}
- virtual void executeScript(const WebScriptSource&) {}
+ virtual WebString name() const;
+ virtual void setName(const WebString&);
+ virtual long long identifier() const;
+ virtual WebURL url() const;
+ virtual WebURL favIconURL() const;
+ virtual WebURL openSearchDescriptionURL() const;
+ virtual WebString encoding() const;
+ virtual void setCanHaveScrollbars(bool);
+ virtual WebSize scrollOffset() const;
+ virtual WebSize contentsSize() const;
+ virtual int contentsPreferredWidth() const;
+ virtual int documentElementScrollHeight() const;
+ virtual bool hasVisibleContent() const;
+ virtual WebView* view() const;
+ virtual WebFrame* opener() const;
+ virtual WebFrame* parent() const;
+ virtual WebFrame* top() const;
+ virtual WebFrame* firstChild() const;
+ virtual WebFrame* lastChild() const;
+ virtual WebFrame* nextSibling() const;
+ virtual WebFrame* previousSibling() const;
+ virtual WebFrame* traverseNext(bool wrap) const;
+ virtual WebFrame* traversePrevious(bool wrap) const;
+ virtual WebFrame* findChildByName(const WebString& name) const;
+ virtual WebFrame* findChildByExpression(const WebString& xpath) const;
+ virtual WebDocument document() const;
+ virtual void forms(WebVector<WebFormElement>&) const;
+ virtual WebAnimationController* animationController();
+ virtual WebPerformance performance() const;
+ virtual WebSecurityOrigin securityOrigin() const;
+ virtual void grantUniversalAccess();
+ virtual NPObject* windowObject() const;
+ virtual void bindToWindowObject(const WebString& name, NPObject*);
+ virtual void executeScript(const WebScriptSource&);
virtual void executeScriptInIsolatedWorld(
int worldId, const WebScriptSource* sources, unsigned numSources,
- int extensionGroup) {}
- virtual void addMessageToConsole(const WebConsoleMessage&) {}
- virtual void collectGarbage() {}
+ int extensionGroup);
+ virtual void addMessageToConsole(const WebConsoleMessage&);
+ virtual void collectGarbage();
#if WEBKIT_USING_V8
virtual v8::Handle<v8::Value> executeScriptAndReturnValue(
- const WebScriptSource&) {
- return v8::Handle<v8::Value>();
- }
- virtual v8::Local<v8::Context> mainWorldScriptContext() const {
- return v8::Local<v8::Context>();
- }
+ const WebScriptSource&);
+ virtual v8::Local<v8::Context> mainWorldScriptContext() const;
#endif
virtual bool insertStyleText(const WebString& styleText,
- const WebString& elementId) {
- return false;
- }
- virtual void reload(bool ignoreCache = false) {}
- virtual void loadRequest(const WebURLRequest&) {}
- virtual void loadHistoryItem(const WebHistoryItem&) {}
+ const WebString& elementId);
+ virtual void reload(bool ignoreCache = false);
+ virtual void loadRequest(const WebURLRequest&);
+ virtual void loadHistoryItem(const WebHistoryItem&);
virtual void loadData(const WebData& data,
const WebString& mimeType,
const WebString& textEncoding,
const WebURL& baseURL,
const WebURL& unreachableURL = WebURL(),
- bool replace = false) {}
+ bool replace = false);
virtual void loadHTMLString(const WebData& html,
const WebURL& baseURL,
const WebURL& unreachableURL = WebURL(),
- bool replace = false) {}
- virtual bool isLoading() const {
- return false;
- }
- virtual void stopLoading() {}
- virtual WebKit::WebDataSource* provisionalDataSource() const {
- return NULL;
- }
- virtual WebKit::WebDataSource* dataSource() const {
- return NULL;
- }
- virtual WebHistoryItem previousHistoryItem() const {
- return WebHistoryItem();
- }
- virtual WebHistoryItem currentHistoryItem() const {
- return WebHistoryItem();
- }
- virtual void enableViewSourceMode(bool) {}
- virtual bool isViewSourceModeEnabled() const {
- return false;
- }
+ bool replace = false);
+ virtual bool isLoading() const;
+ virtual void stopLoading();
+ virtual WebKit::WebDataSource* provisionalDataSource() const;
+ virtual WebKit::WebDataSource* dataSource() const;
+ virtual WebHistoryItem previousHistoryItem() const;
+ virtual WebHistoryItem currentHistoryItem() const;
+ virtual void enableViewSourceMode(bool);
+ virtual bool isViewSourceModeEnabled() const;
// The next two methods were mocked above.
// virtual void setReferrerForRequest(WebURLRequest&, const WebURL&) {}
// virtual void dispatchWillSendRequest(WebURLRequest&) {}
- virtual WebURLLoader* createAssociatedURLLoader() {
- return NULL;
- }
- virtual void commitDocumentData(const char* data, size_t length) {}
- virtual unsigned unloadListenerCount() const {
- return 0;
- }
- virtual bool isProcessingUserGesture() const {
- return false;
- }
- virtual bool willSuppressOpenerInNewFrame() const {
- return false;
- }
- virtual void replaceSelection(const WebString& text) {}
- virtual void insertText(const WebString& text) {}
+ virtual WebURLLoader* createAssociatedURLLoader();
+ virtual void commitDocumentData(const char* data, size_t length);
+ virtual unsigned unloadListenerCount() const;
+ virtual bool isProcessingUserGesture() const;
+ virtual bool willSuppressOpenerInNewFrame() const;
+ virtual void replaceSelection(const WebString& text);
+ virtual void insertText(const WebString& text);
virtual void setMarkedText(const WebString& text,
unsigned location,
- unsigned length) {}
- virtual void unmarkText() {}
- virtual bool hasMarkedText() const {
- return false;
- }
- virtual WebRange markedRange() const {
- return WebRange();
- }
+ unsigned length);
+ virtual void unmarkText();
+ virtual bool hasMarkedText() const;
+ virtual WebRange markedRange() const;
virtual bool firstRectForCharacterRange(unsigned location,
unsigned length,
- WebRect&) const {
- return false;
- }
- virtual bool executeCommand(const WebString&) {
- return false;
- }
- virtual bool executeCommand(const WebString&, const WebString& value) {
- return false;
- }
- virtual bool isCommandEnabled(const WebString&) const {
- return false;
- }
- virtual void enableContinuousSpellChecking(bool) {}
- virtual bool isContinuousSpellCheckingEnabled() const {
- return false;
- }
- virtual bool hasSelection() const {
- return false;
- }
- virtual WebRange selectionRange() const {
- return WebRange();
- }
- virtual WebString selectionAsText() const {
- return WebString();
- }
- virtual WebString selectionAsMarkup() const {
- return WebString();
- }
- virtual bool selectWordAroundCaret() {
- return false;
- }
+ WebRect&) const;
+ virtual bool executeCommand(const WebString&);
+ virtual bool executeCommand(const WebString&, const WebString& value);
+ virtual bool isCommandEnabled(const WebString&) const;
+ virtual void enableContinuousSpellChecking(bool);
+ virtual bool isContinuousSpellCheckingEnabled() const;
+ virtual bool hasSelection() const;
+ virtual WebRange selectionRange() const;
+ virtual WebString selectionAsText() const;
+ virtual WebString selectionAsMarkup() const;
+ virtual bool selectWordAroundCaret();
virtual int printBegin(const WebSize& pageSize,
const WebNode& constrainToNode,
int printerDPI = 72,
- bool* useBrowserOverlays = 0) {
- return 0;
- }
- virtual float getPrintPageShrink(int page) {
- return 0;
- }
- virtual float printPage(int pageToPrint, WebCanvas*) {
- return 0;
- }
- virtual void printEnd() {}
- virtual bool isPageBoxVisible(int pageIndex) {
- return false;
- }
+ bool* useBrowserOverlays = 0);
+ virtual float getPrintPageShrink(int page);
+ virtual float printPage(int pageToPrint, WebCanvas*);
+ virtual void printEnd();
+ virtual bool isPageBoxVisible(int pageIndex);
virtual void pageSizeAndMarginsInPixels(int pageIndex,
WebSize& pageSize,
int& marginTop,
int& marginRight,
int& marginBottom,
- int& marginLeft) {}
+ int& marginLeft);
virtual bool find(int identifier,
const WebString& searchText,
const WebFindOptions& options,
bool wrapWithinFrame,
- WebRect* selectionRect) {
- return false;
- }
- virtual void stopFinding(bool clearSelection) {}
+ WebRect* selectionRect);
+ virtual void stopFinding(bool clearSelection);
virtual void scopeStringMatches(int identifier,
const WebString& searchText,
const WebFindOptions& options,
- bool reset) {}
- virtual void cancelPendingScopingEffort() {}
- virtual void increaseMatchCount(int count, int identifier) {}
- virtual void resetMatchCount() {}
+ bool reset);
+ virtual void cancelPendingScopingEffort();
+ virtual void increaseMatchCount(int count, int identifier);
+ virtual void resetMatchCount();
virtual bool registerPasswordListener(
WebInputElement,
- WebPasswordAutocompleteListener*) {
- return false;
- }
+ WebPasswordAutocompleteListener*);
virtual void notifiyPasswordListenerOfAutocomplete(
- const WebInputElement&) {}
- virtual WebString contentAsText(size_t maxChars) const {
- return WebString();
- }
- virtual WebString contentAsMarkup() const {
- return WebString();
- }
- virtual WebString renderTreeAsText() const {
- return WebString();
- }
- virtual WebString counterValueForElementById(const WebString& id) const {
- return WebString();
- }
- virtual WebString markerTextForListItem(const WebElement&) const {
- return WebString();
- }
+ const WebInputElement&);
+ virtual WebString contentAsText(size_t maxChars) const;
+ virtual WebString contentAsMarkup() const;
+ virtual WebString renderTreeAsText() const;
+ virtual WebString counterValueForElementById(const WebString& id) const;
+ virtual WebString markerTextForListItem(const WebElement&) const;
virtual int pageNumberForElementById(const WebString& id,
float pageWidthInPixels,
- float pageHeightInPixels) const {
- return 0;
- }
- virtual WebRect selectionBoundsRect() const {
- return WebRect();
- }
- virtual bool selectionStartHasSpellingMarkerFor(int from, int length) const {
- return false;
- }
+ float pageHeightInPixels) const;
+ virtual WebRect selectionBoundsRect() const;
+ virtual bool selectionStartHasSpellingMarkerFor(int from, int length) const;
virtual bool pauseSVGAnimation(const WebString& animationId,
double time,
- const WebString& elementId) {
- return false;
- }
- virtual WebString layerTreeAsText() const {
- return WebString();
- }
+ const WebString& elementId);
+ virtual WebString layerTreeAsText() const;
private:
DISALLOW_COPY_AND_ASSIGN(MockWebFrame);
diff --git a/webkit/mocks/mock_weburlloader.cc b/webkit/mocks/mock_weburlloader.cc
new file mode 100644
index 0000000..7610c19
--- /dev/null
+++ b/webkit/mocks/mock_weburlloader.cc
@@ -0,0 +1,18 @@
+// 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 "webkit/mocks/mock_weburlloader.h"
+
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebData.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLError.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLResponse.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebURLRequest.h"
+
+namespace webkit_glue {
+
+MockWebURLLoader::MockWebURLLoader() {}
+
+MockWebURLLoader::~MockWebURLLoader() {}
+
+} // namespace webkit_glue
diff --git a/webkit/mocks/mock_weburlloader.h b/webkit/mocks/mock_weburlloader.h
index 7253faa..68ff9a2 100644
--- a/webkit/mocks/mock_weburlloader.h
+++ b/webkit/mocks/mock_weburlloader.h
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// 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.
@@ -12,11 +12,8 @@ namespace webkit_glue {
class MockWebURLLoader : public WebKit::WebURLLoader {
public:
- MockWebURLLoader() {
- }
-
- virtual ~MockWebURLLoader() {
- }
+ MockWebURLLoader();
+ virtual ~MockWebURLLoader();
MOCK_METHOD4(loadSynchronously, void(const WebKit::WebURLRequest& request,
WebKit::WebURLResponse& response,
diff --git a/webkit/tools/test_shell/test_shell.gypi b/webkit/tools/test_shell/test_shell.gypi
index 6a2d336..159fc68 100644
--- a/webkit/tools/test_shell/test_shell.gypi
+++ b/webkit/tools/test_shell/test_shell.gypi
@@ -403,7 +403,9 @@
'../../glue/webpasswordautocompletelistener_unittest.cc',
'../../glue/webview_unittest.cc',
'../../mocks/mock_resource_loader_bridge.h',
+ '../../mocks/mock_webframe.cc',
'../../mocks/mock_webframe.h',
+ '../../mocks/mock_weburlloader.cc',
'../../mocks/mock_weburlloader.h',
'../../plugins/npapi/plugin_group_unittest.cc',
'../../plugins/npapi/plugin_lib_unittest.cc',