| Index: chrome/browser/cocoa/view_id_util_browsertest.cc
 | 
| diff --git a/chrome/browser/cocoa/view_id_util_browsertest.cc b/chrome/browser/cocoa/view_id_util_browsertest.cc
 | 
| new file mode 100644
 | 
| index 0000000000000000000000000000000000000000..4f6a00979fed953e3f66403ddf26684e063fb8c8
 | 
| --- /dev/null
 | 
| +++ b/chrome/browser/cocoa/view_id_util_browsertest.cc
 | 
| @@ -0,0 +1,89 @@
 | 
| +// Copyright (c) 2010 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/logging.h"
 | 
| +#include "base/utf_string_conversions.h"
 | 
| +#include "chrome/browser/bookmarks/bookmark_model.h"
 | 
| +#include "chrome/browser/browser.h"
 | 
| +#include "chrome/browser/browser_window.h"
 | 
| +#include "chrome/browser/cocoa/view_id_util.h"
 | 
| +#include "chrome/browser/download/download_shelf.h"
 | 
| +#include "chrome/browser/pref_service.h"
 | 
| +#include "chrome/common/pref_names.h"
 | 
| +#include "chrome/common/url_constants.h"
 | 
| +#include "chrome/test/in_process_browser_test.h"
 | 
| +#include "chrome/test/ui_test_utils.h"
 | 
| +
 | 
| +// Basic sanity check of ViewID use on the mac.
 | 
| +class ViewIDTest : public InProcessBrowserTest {
 | 
| + public:
 | 
| +  ViewIDTest() : root_window_(nil) {}
 | 
| +
 | 
| +  void CheckViewID(ViewID view_id, bool should_have) {
 | 
| +    if (!root_window_)
 | 
| +      root_window_ = browser()->window()->GetNativeHandle();
 | 
| +
 | 
| +    ASSERT_TRUE(root_window_);
 | 
| +    NSView* view = view_id_util::GetView(root_window_, view_id);
 | 
| +    EXPECT_EQ(should_have, !!view) << " Failed id=" << view_id;
 | 
| +  }
 | 
| +
 | 
| + private:
 | 
| +  NSWindow* root_window_;
 | 
| +};
 | 
| +
 | 
| +IN_PROC_BROWSER_TEST_F(ViewIDTest, Basic) {
 | 
| +  // Make sure FindBar is created to test
 | 
| +  // VIEW_ID_FIND_IN_PAGE_TEXT_FIELD and VIEW_ID_FIND_IN_PAGE.
 | 
| +  browser()->ShowFindBar();
 | 
| +
 | 
| +  // Make sure docked devtools is created to test VIEW_ID_DEV_TOOLS_DOCKED
 | 
| +  browser()->profile()->GetPrefs()->SetBoolean(prefs::kDevToolsOpenDocked,
 | 
| +                                               true);
 | 
| +  browser()->ToggleDevToolsWindow(false);
 | 
| +
 | 
| +  // Make sure download shelf is created to test VIEW_ID_DOWNLOAD_SHELF
 | 
| +  browser()->window()->GetDownloadShelf()->Show();
 | 
| +
 | 
| +  // Create a bookmark to test VIEW_ID_BOOKMARK_BAR_ELEMENT
 | 
| +  BookmarkModel* bookmark_model = browser()->profile()->GetBookmarkModel();
 | 
| +  if (bookmark_model) {
 | 
| +    if (!bookmark_model->IsLoaded())
 | 
| +      ui_test_utils::WaitForBookmarkModelToLoad(bookmark_model);
 | 
| +
 | 
| +    bookmark_model->SetURLStarred(GURL(chrome::kAboutBlankURL),
 | 
| +                                  UTF8ToUTF16("about"), true);
 | 
| +  }
 | 
| +
 | 
| +  for (int i = VIEW_ID_TOOLBAR; i < VIEW_ID_PREDEFINED_COUNT; ++i) {
 | 
| +    // Extension shelf is being removed, http://crbug.com/30178.
 | 
| +    if (i == VIEW_ID_DEV_EXTENSION_SHELF)
 | 
| +      continue;
 | 
| +
 | 
| +    // Mac implementation does not support following ids yet.
 | 
| +    if (i == VIEW_ID_STAR_BUTTON ||
 | 
| +        i == VIEW_ID_PAGE_MENU ||
 | 
| +        i == VIEW_ID_AUTOCOMPLETE ||
 | 
| +        i == VIEW_ID_CONTENTS_SPLIT ||
 | 
| +        i == VIEW_ID_INFO_BAR_CONTAINER) {
 | 
| +      continue;
 | 
| +    }
 | 
| +
 | 
| +    CheckViewID(static_cast<ViewID>(i), true);
 | 
| +  }
 | 
| +
 | 
| +  CheckViewID(VIEW_ID_TAB_STRIP, true);
 | 
| +  CheckViewID(VIEW_ID_PREDEFINED_COUNT, false);
 | 
| +}
 | 
| +
 | 
| +IN_PROC_BROWSER_TEST_F(ViewIDTest, Tab) {
 | 
| +  CheckViewID(VIEW_ID_TAB_0, true);
 | 
| +  CheckViewID(VIEW_ID_TAB_1, false);
 | 
| +
 | 
| +  browser()->OpenURL(GURL(chrome::kAboutBlankURL), GURL(),
 | 
| +                     NEW_BACKGROUND_TAB, PageTransition::TYPED);
 | 
| +
 | 
| +  CheckViewID(VIEW_ID_TAB_0, true);
 | 
| +  CheckViewID(VIEW_ID_TAB_1, true);
 | 
| +}
 | 
| 
 |