summaryrefslogtreecommitdiffstats
path: root/chrome/browser/extensions/extension_shelf_model_unittest.cc
blob: d4add7da3827829a27a785319189e85dab7fc871 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// Copyright (c) 2009 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 "chrome/browser/browser.h"
#include "chrome/browser/extensions/extension_host.h"
#include "chrome/browser/extensions/extension_shelf_model.h"
#include "chrome/browser/extensions/extensions_service.h"
#include "chrome/browser/extensions/test_extension_loader.h"
#include "chrome/browser/profile.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/extensions/extension_error_reporter.h"
#include "chrome/test/in_process_browser_test.h"

namespace {

// The extension we're using as our test case.
const char* kExtensionId = "behllobkkfkfnphdnhnkndlbkcpglgmj";

};  // namespace


// An InProcessBrowserTest for testing the ExtensionShelfModel.
// TODO(erikkay) It's unfortunate that this needs to be an in-proc browser test.
// It would be nice to refactor things so that ExtensionShelfModel,
// ExtensionHost and ExtensionsService could run without so much of the browser
// in place.
class ExtensionShelfModelTest : public InProcessBrowserTest,
                                public ExtensionShelfModelObserver {
 public:
  virtual void SetUp() {
    // Initialize the error reporter here, or BrowserMain will create it with
    // the wrong MessageLoop.
    ExtensionErrorReporter::Init(false);
    inserted_count_ = 0;
    removed_count_ = 0;
    moved_count_ = 0;

    InProcessBrowserTest::SetUp();
  }

  virtual void SetUpCommandLine(CommandLine* command_line) {
    command_line->AppendSwitch(switches::kEnableExtensions);
  }

  virtual Browser* CreateBrowser(Profile* profile) {
    Browser* b = InProcessBrowserTest::CreateBrowser(profile);
    model_ = new ExtensionShelfModel(b);
    model_->AddObserver(this);
    return b;
  }

  virtual void ToolstripInsertedAt(ExtensionHost* toolstrip, int index) {
    inserted_count_++;
  }

  virtual void ToolstripRemovingAt(ExtensionHost* toolstrip, int index) {
    removed_count_++;
  }

  virtual void ToolstripMoved(ExtensionHost* toolstrip,
                              int from_index,
                              int to_index) {
    moved_count_++;
  }

 protected:
  ExtensionShelfModel* model_;

  int inserted_count_;
  int removed_count_;
  int moved_count_;
};

// TODO(erikkay): http://crbug.com/15291 disabled because fails on build-bot.
IN_PROC_BROWSER_TEST_F(ExtensionShelfModelTest, DISABLED_Basic) {
  // Get the path to our extension.
  FilePath path;
  ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &path));
  path = path.AppendASCII("extensions").
      AppendASCII("good").AppendASCII(kExtensionId).AppendASCII("1.0.0.0");
  ASSERT_TRUE(file_util::DirectoryExists(path));  // sanity check

  // Wait for the extension to load and grab a pointer to it.
  TestExtensionLoader loader(browser()->profile());
  Extension* extension = loader.Load(kExtensionId, path);
  ASSERT_TRUE(extension);

  // extension1 has two toolstrips
  EXPECT_EQ(inserted_count_, 2);
  ExtensionHost* one = model_->ToolstripAt(0);
  ExtensionHost* two = model_->ToolstripAt(1);
  EXPECT_EQ(one->GetURL().path(), "/toolstrip1.html");
  EXPECT_EQ(two->GetURL().path(), "/toolstrip2.html");

  model_->MoveToolstripAt(0, 1);
  EXPECT_EQ(two, model_->ToolstripAt(0));
  EXPECT_EQ(one, model_->ToolstripAt(1));
  EXPECT_EQ(moved_count_, 1);

  model_->RemoveToolstripAt(0);
  EXPECT_EQ(one, model_->ToolstripAt(0));
  EXPECT_EQ(1, model_->count());
  EXPECT_EQ(removed_count_, 1);

  // Tear down |model_| manually here rather than in the destructor or with
  // a scoped_ptr.  InProcessBrowserTest doesn't give us a chance to clean
  // up before the browser and all of its services have been shut down,
  // and |model_| depends on these existing.
  model_->RemoveObserver(this);
  delete model_;
  model_ = NULL;
}