// 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.
#ifndef CHROME_BROWSER_UI_COCOA_BROWSER_TEST_HELPER_H_
#define CHROME_BROWSER_UI_COCOA_BROWSER_TEST_HELPER_H_
#pragma once
#include "chrome/browser/ui/browser.h"
#include "chrome/test/testing_profile.h"
#include "content/browser/browser_thread.h"
// Base class which contains a valid Browser*. Lots of boilerplate to
// recycle between unit test classes.
//
// This class creates fake UI, file, and IO threads because many objects that
// are attached to the TestingProfile (and other objects) have traits that limit
// their destruction to certain threads. For example, the net::URLRequestContext
// can only be deleted on the IO thread; without this fake IO thread, the object
// would never be deleted and would report as a leak under Valgrind. Note that
// these are fake threads and they all share the same MessageLoop.
//
// TODO(jrg): move up a level (chrome/browser/ui/cocoa -->
// chrome/browser), and use in non-Mac unit tests such as
// back_forward_menu_model_unittest.cc,
// navigation_controller_unittest.cc, ..
class BrowserTestHelper {
public:
BrowserTestHelper();
virtual ~BrowserTestHelper();
virtual TestingProfile* profile() const;
Browser* browser() const { return browser_.get(); }
// Creates the browser window. To close this window call |CloseBrowserWindow|.
// Do NOT call close directly on the window.
BrowserWindow* CreateBrowserWindow();
// Closes the window for this browser. This must only be called after
// CreateBrowserWindow().
void CloseBrowserWindow();
private:
scoped_ptr<TestingProfile> profile_;
scoped_ptr<Browser> browser_;
MessageLoopForUI message_loop_;
BrowserThread ui_thread_;
scoped_ptr<BrowserThread> file_thread_;
scoped_ptr<BrowserThread> io_thread_;
};
#endif // CHROME_BROWSER_UI_COCOA_BROWSER_TEST_HELPER_H_