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 #import "chrome/browser/ui/cocoa/one_click_signin_bubble_controller.h" | 5 #import "chrome/browser/ui/cocoa/one_click_signin_bubble_controller.h" |
| 6 | 6 |
| 7 #import <Cocoa/Cocoa.h> | 7 #import <Cocoa/Cocoa.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
| 11 #import "base/memory/scoped_nsobject.h" | 11 #import "base/memory/scoped_nsobject.h" |
| 12 #include "base/memory/weak_ptr.h" | 12 #include "base/memory/weak_ptr.h" |
| 13 #import "chrome/browser/ui/cocoa/browser_window_cocoa.h" | 13 #import "chrome/browser/ui/cocoa/browser_window_cocoa.h" |
| 14 #include "chrome/browser/ui/cocoa/cocoa_profile_test.h" | 14 #include "chrome/browser/ui/cocoa/cocoa_profile_test.h" |
| 15 #include "chrome/browser/ui/sync/one_click_signin_sync_starter.h" | |
| 15 #include "testing/gmock/include/gmock/gmock.h" | 16 #include "testing/gmock/include/gmock/gmock.h" |
| 16 #include "testing/gtest/include/gtest/gtest.h" | 17 #include "testing/gtest/include/gtest/gtest.h" |
| 17 #import "testing/gtest_mac.h" | 18 #import "testing/gtest_mac.h" |
| 18 | 19 |
| 20 using testing::_; | |
|
Peter Kasting
2012/05/24 22:25:18
Nit: Just explicitly-qualify the one usage
Roger Tawa OOO till Jul 10th
2012/05/25 16:04:08
Done.
| |
| 21 | |
| 19 namespace { | 22 namespace { |
| 20 | 23 |
| 21 class OneClickSigninBubbleControllerTest : public CocoaProfileTest { | 24 class OneClickSigninBubbleControllerTest : public CocoaProfileTest { |
| 22 public: | 25 public: |
| 23 OneClickSigninBubbleControllerTest() | 26 OneClickSigninBubbleControllerTest() |
| 24 : weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), | 27 : weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), |
| 25 learn_more_callback_( | 28 start_sync_callback_( |
| 26 base::Bind(&OneClickSigninBubbleControllerTest::OnLearnMore, | 29 base::Bind(&OneClickSigninBubbleControllerTest::OnStartSync, |
| 27 weak_ptr_factory_.GetWeakPtr())), | |
| 28 advanced_callback_( | |
| 29 base::Bind(&OneClickSigninBubbleControllerTest::OnAdvanced, | |
| 30 weak_ptr_factory_.GetWeakPtr())) {} | 30 weak_ptr_factory_.GetWeakPtr())) {} |
| 31 | 31 |
| 32 virtual void SetUp() { | 32 virtual void SetUp() { |
| 33 CocoaProfileTest::SetUp(); | 33 CocoaProfileTest::SetUp(); |
| 34 BrowserWindowCocoa* browser_window = | 34 BrowserWindowCocoa* browser_window = |
| 35 static_cast<BrowserWindowCocoa*>(CreateBrowserWindow()); | 35 static_cast<BrowserWindowCocoa*>(CreateBrowserWindow()); |
| 36 controller_.reset( | 36 controller_.reset( |
| 37 [[OneClickSigninBubbleController alloc] | 37 [[OneClickSigninBubbleController alloc] |
| 38 initWithBrowserWindowController:browser_window->cocoa_controller() | 38 initWithBrowserWindowController:browser_window->cocoa_controller() |
| 39 learnMoreCallback:learn_more_callback_ | 39 start_sync_callback:start_sync_callback_]); |
| 40 advancedCallback:advanced_callback_]); | |
| 41 } | 40 } |
| 42 | 41 |
| 43 virtual void TearDown() { | 42 virtual void TearDown() { |
| 44 controller_.reset(); | 43 controller_.reset(); |
| 45 CocoaProfileTest::TearDown(); | 44 CocoaProfileTest::TearDown(); |
| 46 } | 45 } |
| 47 | 46 |
| 48 MOCK_METHOD0(OnLearnMore, void()); | 47 MOCK_METHOD1(OnStartSync, void(OneClickSigninSyncStarter::StartSyncMode)); |
| 49 MOCK_METHOD0(OnAdvanced, void()); | |
| 50 | 48 |
| 51 protected: | 49 protected: |
| 52 base::WeakPtrFactory<OneClickSigninBubbleControllerTest> weak_ptr_factory_; | 50 base::WeakPtrFactory<OneClickSigninBubbleControllerTest> weak_ptr_factory_; |
| 53 base::Closure learn_more_callback_; | 51 BrowserWindow::StartSyncCallback start_sync_callback_; |
| 54 base::Closure advanced_callback_; | |
| 55 scoped_nsobject<OneClickSigninBubbleController> controller_; | 52 scoped_nsobject<OneClickSigninBubbleController> controller_; |
| 56 }; | 53 }; |
| 57 | 54 |
| 58 // Test that the dialog loads from its nib properly. | 55 // Test that the dialog loads from its nib properly. |
| 59 TEST_F(OneClickSigninBubbleControllerTest, NibLoad) { | 56 TEST_F(OneClickSigninBubbleControllerTest, NibLoad) { |
| 60 EXPECT_CALL(*this, OnLearnMore()).Times(0); | 57 EXPECT_CALL(*this, OnStartSync(_)).Times(0); |
| 61 EXPECT_CALL(*this, OnAdvanced()).Times(0); | |
| 62 | 58 |
| 63 // Force nib load. | 59 // Force nib load. |
| 64 [controller_ window]; | 60 [controller_ window]; |
| 65 EXPECT_NSEQ(@"OneClickSigninBubble", [controller_ windowNibName]); | 61 EXPECT_NSEQ(@"OneClickSigninBubble", [controller_ windowNibName]); |
| 66 } | 62 } |
| 67 | 63 |
| 68 // Test that the dialog doesn't call any callback if the OK button is | 64 // Test that the dialog calls the callback if the OK button is clicked. |
| 69 // clicked. | |
| 70 TEST_F(OneClickSigninBubbleControllerTest, ShowAndOK) { | 65 TEST_F(OneClickSigninBubbleControllerTest, ShowAndOK) { |
| 71 EXPECT_CALL(*this, OnLearnMore()).Times(0); | 66 EXPECT_CALL(*this, |
| 72 EXPECT_CALL(*this, OnAdvanced()).Times(0); | 67 OnStartSync( |
|
Peter Kasting
2012/05/24 22:25:18
Nit: Weird indenting; how about:
EXPECT_CALL(*t
Roger Tawa OOO till Jul 10th
2012/05/25 16:04:08
That leaves the second line beyond 80 chars. The
Peter Kasting
2012/05/25 16:58:06
No it doesn't:
1234567890123456789012345678901234
Roger Tawa OOO till Jul 10th
2012/05/25 18:49:51
Done.
| |
| 68 OneClickSigninSyncStarter::SYNC_WITH_DEFAULT_SETTINGS)). | |
| 69 Times(1); | |
| 73 | 70 |
| 74 [controller_ showWindow:nil]; | 71 [controller_ showWindow:nil]; |
| 75 [controller_.release() ok:nil]; | 72 [controller_.release() ok:nil]; |
| 76 } | 73 } |
| 77 | 74 |
| 78 // Test that the learn more callback is run if its corresponding | 75 // TODO(akalin): Test that the dialog doesn't calls the callback if the Undo |
|
Peter Kasting
2012/05/24 22:25:18
Nit: calls -> call
Roger Tawa OOO till Jul 10th
2012/05/25 16:04:08
Done.
| |
| 79 // button is clicked. | 76 // button is clicked. |
| 80 TEST_F(OneClickSigninBubbleControllerTest, ShowAndClickLearnMore) { | |
| 81 EXPECT_CALL(*this, OnLearnMore()).Times(1); | |
| 82 EXPECT_CALL(*this, OnAdvanced()).Times(0); | |
| 83 | |
| 84 [controller_ showWindow:nil]; | |
| 85 [controller_ onClickLearnMoreLink:nil]; | |
| 86 [controller_.release() ok:nil]; | |
| 87 } | |
| 88 | 77 |
| 89 // Test that the advanced callback is run if its corresponding button | 78 // Test that the advanced callback is run if its corresponding button |
| 90 // is clicked. | 79 // is clicked. |
| 91 TEST_F(OneClickSigninBubbleControllerTest, ShowAndClickAdvanced) { | 80 TEST_F(OneClickSigninBubbleControllerTest, ShowAndClickAdvanced) { |
| 92 EXPECT_CALL(*this, OnLearnMore()).Times(0); | 81 EXPECT_CALL(*this, |
| 93 EXPECT_CALL(*this, OnAdvanced()).Times(1); | 82 OnStartSync( |
| 83 OneClickSigninSyncStarter::CONFIGURE_SYNC_FIRST)). | |
| 84 Times(1); | |
| 94 | 85 |
| 95 [controller_ showWindow:nil]; | 86 [controller_ showWindow:nil]; |
| 96 [controller_ onClickAdvancedLink:nil]; | 87 [controller_.release() onClickAdvancedLink:nil]; |
| 97 [controller_.release() ok:nil]; | |
| 98 } | |
| 99 | |
| 100 // Test that the callbacks can be run multiple times. | |
| 101 TEST_F(OneClickSigninBubbleControllerTest, ShowAndClickMultiple) { | |
| 102 EXPECT_CALL(*this, OnLearnMore()).Times(3); | |
| 103 EXPECT_CALL(*this, OnAdvanced()).Times(4); | |
| 104 | |
| 105 [controller_ showWindow:nil]; | |
| 106 for (int i = 0; i < 3; ++i) { | |
| 107 [controller_ onClickLearnMoreLink:nil]; | |
| 108 [controller_ onClickAdvancedLink:nil]; | |
| 109 } | |
| 110 [controller_ onClickAdvancedLink:nil]; | |
| 111 [controller_.release() ok:nil]; | |
| 112 } | 88 } |
| 113 | 89 |
| 114 } // namespace | 90 } // namespace |
| OLD | NEW |