Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "base/command_line.h" | 5 #include "base/command_line.h" |
| 6 #include "base/mac/scoped_nsobject.h" | 6 #include "base/mac/scoped_nsobject.h" |
| 7 #include "base/strings/sys_string_conversions.h" | 7 #include "base/strings/sys_string_conversions.h" |
| 8 #include "base/strings/utf_string_conversions.h" | 8 #include "base/strings/utf_string_conversions.h" |
| 9 #include "chrome/app/chrome_command_ids.h" | 9 #include "chrome/app/chrome_command_ids.h" |
| 10 #include "chrome/browser/sync/glue/device_info.h" | 10 #include "chrome/browser/sync/glue/device_info.h" |
| 11 #include "chrome/browser/sync/glue/local_device_info_provider_mock.h" | |
| 11 #include "chrome/browser/sync/profile_sync_service_factory.h" | 12 #include "chrome/browser/sync/profile_sync_service_factory.h" |
| 12 #include "chrome/browser/sync/sessions/sessions_sync_manager.h" | 13 #include "chrome/browser/sync/sessions/sessions_sync_manager.h" |
| 13 #include "chrome/browser/ui/cocoa/cocoa_profile_test.h" | 14 #include "chrome/browser/ui/cocoa/cocoa_profile_test.h" |
| 14 #include "chrome/browser/ui/cocoa/run_loop_testing.h" | 15 #include "chrome/browser/ui/cocoa/run_loop_testing.h" |
| 15 #import "chrome/browser/ui/cocoa/toolbar/toolbar_controller.h" | 16 #import "chrome/browser/ui/cocoa/toolbar/toolbar_controller.h" |
| 16 #import "chrome/browser/ui/cocoa/view_resizer_pong.h" | 17 #import "chrome/browser/ui/cocoa/view_resizer_pong.h" |
| 17 #import "chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.h" | 18 #import "chrome/browser/ui/cocoa/wrench_menu/wrench_menu_controller.h" |
| 18 #include "chrome/browser/ui/toolbar/recent_tabs_builder_test_helper.h" | 19 #include "chrome/browser/ui/toolbar/recent_tabs_builder_test_helper.h" |
| 19 #include "chrome/browser/ui/toolbar/recent_tabs_sub_menu_model.h" | 20 #include "chrome/browser/ui/toolbar/recent_tabs_sub_menu_model.h" |
| 20 #include "chrome/browser/ui/toolbar/wrench_menu_model.h" | 21 #include "chrome/browser/ui/toolbar/wrench_menu_model.h" |
| (...skipping 29 matching lines...) Expand all Loading... | |
| 50 | 51 |
| 51 class DummyRouter : public browser_sync::LocalSessionEventRouter { | 52 class DummyRouter : public browser_sync::LocalSessionEventRouter { |
| 52 public: | 53 public: |
| 53 virtual ~DummyRouter() {} | 54 virtual ~DummyRouter() {} |
| 54 virtual void StartRoutingTo( | 55 virtual void StartRoutingTo( |
| 55 browser_sync::LocalSessionEventHandler* handler) OVERRIDE {} | 56 browser_sync::LocalSessionEventHandler* handler) OVERRIDE {} |
| 56 virtual void Stop() OVERRIDE {} | 57 virtual void Stop() OVERRIDE {} |
| 57 }; | 58 }; |
| 58 | 59 |
| 59 class WrenchMenuControllerTest | 60 class WrenchMenuControllerTest |
| 60 : public CocoaProfileTest, | 61 : public CocoaProfileTest { |
| 61 public browser_sync::SessionsSyncManager::SyncInternalApiDelegate { | |
| 62 public: | 62 public: |
| 63 WrenchMenuControllerTest() { | |
| 64 local_device_.reset(new browser_sync::LocalDeviceInfoProviderMock( | |
|
sky
2014/07/14 19:33:34
nit: make part of member initialize list.
stanisc
2014/07/14 22:49:05
Done.
| |
| 65 "WrenchMenuControllerTest", | |
| 66 "Test Machine", | |
| 67 "Chromium 10k", | |
| 68 "Chrome 10k", | |
| 69 sync_pb::SyncEnums_DeviceType_TYPE_LINUX)); | |
| 70 } | |
| 71 virtual ~WrenchMenuControllerTest() {} | |
| 72 | |
| 63 virtual void SetUp() OVERRIDE { | 73 virtual void SetUp() OVERRIDE { |
| 64 CocoaProfileTest::SetUp(); | 74 CocoaProfileTest::SetUp(); |
| 65 ASSERT_TRUE(browser()); | 75 ASSERT_TRUE(browser()); |
| 66 | 76 |
| 67 controller_.reset([[WrenchMenuController alloc] initWithBrowser:browser()]); | 77 controller_.reset([[WrenchMenuController alloc] initWithBrowser:browser()]); |
| 68 fake_model_.reset(new MockWrenchMenuModel); | 78 fake_model_.reset(new MockWrenchMenuModel); |
| 69 | 79 |
| 70 manager_.reset(new browser_sync::SessionsSyncManager( | 80 manager_.reset(new browser_sync::SessionsSyncManager( |
| 71 profile(), | 81 profile(), |
| 72 this, | 82 local_device_.get(), |
| 73 scoped_ptr<browser_sync::LocalSessionEventRouter>( | 83 scoped_ptr<browser_sync::LocalSessionEventRouter>( |
| 74 new DummyRouter()))); | 84 new DummyRouter()))); |
| 75 manager_->MergeDataAndStartSyncing( | 85 manager_->MergeDataAndStartSyncing( |
| 76 syncer::SESSIONS, | 86 syncer::SESSIONS, |
| 77 syncer::SyncDataList(), | 87 syncer::SyncDataList(), |
| 78 scoped_ptr<syncer::SyncChangeProcessor>( | 88 scoped_ptr<syncer::SyncChangeProcessor>( |
| 79 new syncer::FakeSyncChangeProcessor), | 89 new syncer::FakeSyncChangeProcessor), |
| 80 scoped_ptr<syncer::SyncErrorFactory>( | 90 scoped_ptr<syncer::SyncErrorFactory>( |
| 81 new syncer::SyncErrorFactoryMock)); | 91 new syncer::SyncErrorFactoryMock)); |
| 82 } | 92 } |
| 83 | 93 |
| 84 virtual scoped_ptr<browser_sync::DeviceInfo> GetLocalDeviceInfo() | |
| 85 const OVERRIDE { | |
| 86 return scoped_ptr<browser_sync::DeviceInfo>( | |
| 87 new browser_sync::DeviceInfo(GetLocalSyncCacheGUID(), | |
| 88 "Test Machine", | |
| 89 "Chromium 10k", | |
| 90 "Chrome 10k", | |
| 91 sync_pb::SyncEnums_DeviceType_TYPE_LINUX)); | |
| 92 } | |
| 93 | |
| 94 virtual std::string GetLocalSyncCacheGUID() const OVERRIDE { | |
| 95 return "WrenchMenuControllerTest"; | |
| 96 } | |
| 97 | |
| 98 void RegisterRecentTabs(RecentTabsBuilderTestHelper* helper) { | 94 void RegisterRecentTabs(RecentTabsBuilderTestHelper* helper) { |
| 99 helper->ExportToSessionsSyncManager(manager_.get()); | 95 helper->ExportToSessionsSyncManager(manager_.get()); |
| 100 } | 96 } |
| 101 | 97 |
| 102 browser_sync::OpenTabsUIDelegate* GetOpenTabsDelegate() { | 98 browser_sync::OpenTabsUIDelegate* GetOpenTabsDelegate() { |
| 103 return manager_.get(); | 99 return manager_.get(); |
| 104 } | 100 } |
| 105 | 101 |
| 106 virtual void TearDown() OVERRIDE { | 102 virtual void TearDown() OVERRIDE { |
| 107 fake_model_.reset(); | 103 fake_model_.reset(); |
| 108 controller_.reset(); | 104 controller_.reset(); |
| 109 manager_.reset(); | 105 manager_.reset(); |
| 110 CocoaProfileTest::TearDown(); | 106 CocoaProfileTest::TearDown(); |
| 111 } | 107 } |
| 112 | 108 |
| 113 WrenchMenuController* controller() { | 109 WrenchMenuController* controller() { |
| 114 return controller_.get(); | 110 return controller_.get(); |
| 115 } | 111 } |
| 116 | 112 |
| 117 base::scoped_nsobject<WrenchMenuController> controller_; | 113 base::scoped_nsobject<WrenchMenuController> controller_; |
| 118 | 114 |
| 119 scoped_ptr<MockWrenchMenuModel> fake_model_; | 115 scoped_ptr<MockWrenchMenuModel> fake_model_; |
| 120 | 116 |
| 121 private: | 117 private: |
| 122 scoped_ptr<browser_sync::SessionsSyncManager> manager_; | 118 scoped_ptr<browser_sync::SessionsSyncManager> manager_; |
| 119 scoped_ptr<browser_sync::LocalDeviceInfoProviderMock> local_device_; | |
| 123 }; | 120 }; |
| 124 | 121 |
| 125 TEST_F(WrenchMenuControllerTest, Initialized) { | 122 TEST_F(WrenchMenuControllerTest, Initialized) { |
| 126 EXPECT_TRUE([controller() menu]); | 123 EXPECT_TRUE([controller() menu]); |
| 127 EXPECT_GE([[controller() menu] numberOfItems], 5); | 124 EXPECT_GE([[controller() menu] numberOfItems], 5); |
| 128 } | 125 } |
| 129 | 126 |
| 130 TEST_F(WrenchMenuControllerTest, DispatchSimple) { | 127 TEST_F(WrenchMenuControllerTest, DispatchSimple) { |
| 131 base::scoped_nsobject<NSButton> button([[NSButton alloc] init]); | 128 base::scoped_nsobject<NSButton> button([[NSButton alloc] init]); |
| 132 [button setTag:IDC_ZOOM_PLUS]; | 129 [button setTag:IDC_ZOOM_PLUS]; |
| (...skipping 101 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 234 } | 231 } |
| 235 | 232 |
| 236 // Verify that |RecentTabsMenuModelDelegate| is deleted before the model | 233 // Verify that |RecentTabsMenuModelDelegate| is deleted before the model |
| 237 // it's observing. | 234 // it's observing. |
| 238 TEST_F(WrenchMenuControllerTest, RecentTabDeleteOrder) { | 235 TEST_F(WrenchMenuControllerTest, RecentTabDeleteOrder) { |
| 239 [controller_ menuNeedsUpdate:[controller_ menu]]; | 236 [controller_ menuNeedsUpdate:[controller_ menu]]; |
| 240 // If the delete order is wrong then the test will crash on exit. | 237 // If the delete order is wrong then the test will crash on exit. |
| 241 } | 238 } |
| 242 | 239 |
| 243 } // namespace | 240 } // namespace |
| OLD | NEW |