Home | History | Annotate | Download | only in cocoa
      1 // Copyright (c) 2011 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 #ifndef CHROME_BROWSER_UI_COCOA_PROFILE_TEST_H_
      6 #define CHROME_BROWSER_UI_COCOA_PROFILE_TEST_H_
      7 
      8 #include "base/memory/scoped_ptr.h"
      9 #import "chrome/browser/ui/cocoa/cocoa_test_helper.h"
     10 #include "chrome/test/base/testing_profile_manager.h"
     11 
     12 namespace content {
     13 class TestBrowserThreadBundle;
     14 }
     15 
     16 class Browser;
     17 class TestingProfile;
     18 
     19 // Base class which contains a valid Browser*.  Lots of boilerplate to
     20 // recycle between unit test classes.
     21 //
     22 // This class creates fake UI, file, and IO threads because many objects that
     23 // are attached to the TestingProfile (and other objects) have traits that limit
     24 // their destruction to certain threads. For example, the net::URLRequestContext
     25 // can only be deleted on the IO thread; without this fake IO thread, the object
     26 // would never be deleted and would report as a leak under Valgrind. Note that
     27 // these are fake threads and they all share the same MessageLoop.
     28 //
     29 // TODO(jrg): move up a level (chrome/browser/ui/cocoa -->
     30 // chrome/browser), and use in non-Mac unit tests such as
     31 // back_forward_menu_model_unittest.cc,
     32 // navigation_controller_unittest.cc, ..
     33 class CocoaProfileTest : public CocoaTest {
     34  public:
     35   CocoaProfileTest();
     36   virtual ~CocoaProfileTest();
     37 
     38   // This constructs a a Browser and a TestingProfile. It is guaranteed to
     39   // succeed, else it will ASSERT and cause the test to fail. Subclasses that
     40   // do work in SetUp should ASSERT that either browser() or profile() are
     41   // non-NULL before proceeding after the call to super (this).
     42   virtual void SetUp() OVERRIDE;
     43 
     44   virtual void TearDown() OVERRIDE;
     45 
     46   TestingProfileManager* testing_profile_manager() {
     47     return &profile_manager_;
     48   }
     49   TestingProfile* profile() { return profile_; }
     50   Browser* browser() { return browser_.get(); }
     51 
     52   // Closes the window for this browser. This will automatically be called as
     53   // part of TearDown() if it's not been done already.
     54   void CloseBrowserWindow();
     55 
     56  protected:
     57   // Overridden by test subclasses to create their own browser, e.g. with a
     58   // test window.
     59   virtual Browser* CreateBrowser();
     60 
     61  private:
     62   TestingProfileManager profile_manager_;
     63   TestingProfile* profile_;  // Weak; owned by profile_manager_.
     64   scoped_ptr<Browser> browser_;
     65 
     66   scoped_ptr<content::TestBrowserThreadBundle> thread_bundle_;
     67 };
     68 
     69 #endif  // CHROME_BROWSER_UI_COCOA_PROFILE_TEST_H_
     70