Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(55)

Side by Side Diff: chrome/browser/ui/views/bookmarks/bookmark_bar_view_unittest.cc

Issue 12386088: Add a shortcut to open the Apps page from the bookmark bar. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebased and answered sky's comments. Created 7 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/ui/views/bookmarks/bookmark_bar_view.h"
6
7 #include "base/prefs/pref_service.h"
8 #include "chrome/browser/profiles/profile.h"
9 #include "chrome/browser/search_engines/template_url_service.h"
10 #include "chrome/browser/search_engines/template_url_service_factory.h"
11 #include "chrome/browser/ui/search/search.h"
12 #include "chrome/common/pref_names.h"
13 #include "chrome/common/url_constants.h"
14 #include "chrome/test/base/browser_with_test_window_test.h"
15 #include "ui/views/controls/button/text_button.h"
16
17 typedef BrowserWithTestWindowTest BookmarkBarViewTest;
18
19 // Verify that the apps shortcut is never visible without instant extended.
20 TEST_F(BookmarkBarViewTest, NoAppsShortcutWithoutInstantExtended) {
21 profile()->CreateBookmarkModel(true);
22 profile()->BlockUntilBookmarkModelLoaded();
23 BookmarkBarView bookmark_bar_view(browser(), NULL);
24 bookmark_bar_view.set_owned_by_client();
25 EXPECT_FALSE(bookmark_bar_view.apps_page_shortcut_->visible());
26 browser()->profile()->GetPrefs()->SetBoolean(
27 prefs::kShowAppsShortcutInBookmarkBar, true);
28 EXPECT_FALSE(bookmark_bar_view.apps_page_shortcut_->visible());
29 }
30
31 class BookmarkBarViewInstantExtendedTest : public BrowserWithTestWindowTest {
32 public:
33 BookmarkBarViewInstantExtendedTest() {
34 chrome::search::EnableInstantExtendedAPIForTesting();
35 }
36
37 protected:
38 virtual TestingProfile* CreateProfile() OVERRIDE {
39 TestingProfile* profile = BrowserWithTestWindowTest::CreateProfile();
40 // TemplateURLService is normally NULL during testing. Instant extended
41 // needs this service so set a custom factory function.
42 TemplateURLServiceFactory::GetInstance()->SetTestingFactory(
43 profile, &BookmarkBarViewInstantExtendedTest::CreateTemplateURLService);
44 return profile;
45 }
46
47 private:
48 static ProfileKeyedService* CreateTemplateURLService(Profile* profile) {
49 return new TemplateURLService(profile);
50 }
51
52 DISALLOW_COPY_AND_ASSIGN(BookmarkBarViewInstantExtendedTest);
53 };
54
55 // Verify that in instant extended mode the visibility of the apps shortcut
56 // button properly follows the pref value.
57 TEST_F(BookmarkBarViewInstantExtendedTest, AppsShortcutVisibility) {
58 profile()->CreateBookmarkModel(true);
59 profile()->BlockUntilBookmarkModelLoaded();
60 BookmarkBarView bookmark_bar_view(browser(), NULL);
61 bookmark_bar_view.set_owned_by_client();
62 browser()->profile()->GetPrefs()->SetBoolean(
63 prefs::kShowAppsShortcutInBookmarkBar, false);
64 EXPECT_FALSE(bookmark_bar_view.apps_page_shortcut_->visible());
65 browser()->profile()->GetPrefs()->SetBoolean(
66 prefs::kShowAppsShortcutInBookmarkBar, true);
67 EXPECT_TRUE(bookmark_bar_view.apps_page_shortcut_->visible());
68 // Make sure we can also properly transition from true to false.
69 browser()->profile()->GetPrefs()->SetBoolean(
70 prefs::kShowAppsShortcutInBookmarkBar, false);
71 EXPECT_FALSE(bookmark_bar_view.apps_page_shortcut_->visible());
72 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698