OLD | NEW |
| (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/extensions/extension_process_manager.h" | |
6 | |
7 #include "chrome/browser/extensions/browser_action_test_util.h" | |
8 #include "chrome/browser/extensions/extension_browsertest.h" | |
9 #include "chrome/browser/extensions/extension_service.h" | |
10 #include "chrome/browser/extensions/extension_system.h" | |
11 #include "chrome/test/base/in_process_browser_test.h" | |
12 #include "content/public/browser/notification_service.h" | |
13 #include "content/public/test/test_utils.h" | |
14 | |
15 using extensions::Extension; | |
16 using extensions::ExtensionSystem; | |
17 | |
18 // Exists as a browser test because ExtensionHosts are hard to create without | |
19 // a real browser. | |
20 typedef ExtensionBrowserTest ExtensionProcessManagerBrowserTest; | |
21 | |
22 // Test that basic extension loading creates the appropriate ExtensionHosts | |
23 // and background pages. | |
24 IN_PROC_BROWSER_TEST_F(ExtensionProcessManagerBrowserTest, | |
25 ExtensionHostCreation) { | |
26 ExtensionProcessManager* pm = | |
27 ExtensionSystem::Get(profile())->process_manager(); | |
28 | |
29 // We start with no background hosts. | |
30 ASSERT_EQ(0u, pm->background_hosts().size()); | |
31 ASSERT_EQ(0u, pm->GetAllViews().size()); | |
32 | |
33 // Load an extension with a background page. | |
34 scoped_refptr<const Extension> extension = | |
35 LoadExtension(test_data_dir_.AppendASCII("api_test") | |
36 .AppendASCII("browser_action") | |
37 .AppendASCII("none")); | |
38 ASSERT_TRUE(extension.get()); | |
39 | |
40 // Process manager gains a background host. | |
41 EXPECT_EQ(1u, pm->background_hosts().size()); | |
42 EXPECT_EQ(1u, pm->GetAllViews().size()); | |
43 EXPECT_TRUE(pm->GetBackgroundHostForExtension(extension->id())); | |
44 EXPECT_TRUE(pm->GetSiteInstanceForURL(extension->url())); | |
45 EXPECT_EQ(1u, pm->GetRenderViewHostsForExtension(extension->id()).size()); | |
46 EXPECT_FALSE(pm->IsBackgroundHostClosing(extension->id())); | |
47 EXPECT_EQ(0, pm->GetLazyKeepaliveCount(extension.get())); | |
48 | |
49 // Unload the extension. | |
50 UnloadExtension(extension->id()); | |
51 | |
52 // Background host disappears. | |
53 EXPECT_EQ(0u, pm->background_hosts().size()); | |
54 EXPECT_EQ(0u, pm->GetAllViews().size()); | |
55 EXPECT_FALSE(pm->GetBackgroundHostForExtension(extension->id())); | |
56 EXPECT_TRUE(pm->GetSiteInstanceForURL(extension->url())); | |
57 EXPECT_EQ(0u, pm->GetRenderViewHostsForExtension(extension->id()).size()); | |
58 EXPECT_FALSE(pm->IsBackgroundHostClosing(extension->id())); | |
59 EXPECT_EQ(0, pm->GetLazyKeepaliveCount(extension.get())); | |
60 } | |
61 | |
62 // Test that loading an extension with a browser action does not create a | |
63 // background page and that clicking on the action creates the appropriate | |
64 // ExtensionHost. | |
65 // Disabled due to flake, see http://crbug.com/315242 | |
66 IN_PROC_BROWSER_TEST_F(ExtensionProcessManagerBrowserTest, | |
67 DISABLED_PopupHostCreation) { | |
68 ExtensionProcessManager* pm = | |
69 ExtensionSystem::Get(profile())->process_manager(); | |
70 | |
71 // Load an extension with the ability to open a popup but no background | |
72 // page. | |
73 scoped_refptr<const Extension> popup = | |
74 LoadExtension(test_data_dir_.AppendASCII("api_test") | |
75 .AppendASCII("browser_action") | |
76 .AppendASCII("popup")); | |
77 ASSERT_TRUE(popup); | |
78 | |
79 // No background host was added. | |
80 EXPECT_EQ(0u, pm->background_hosts().size()); | |
81 EXPECT_EQ(0u, pm->GetAllViews().size()); | |
82 EXPECT_FALSE(pm->GetBackgroundHostForExtension(popup->id())); | |
83 EXPECT_EQ(0u, pm->GetRenderViewHostsForExtension(popup->id()).size()); | |
84 EXPECT_TRUE(pm->GetSiteInstanceForURL(popup->url())); | |
85 EXPECT_FALSE(pm->IsBackgroundHostClosing(popup->id())); | |
86 EXPECT_EQ(0, pm->GetLazyKeepaliveCount(popup.get())); | |
87 | |
88 // Simulate clicking on the action to open a popup. | |
89 BrowserActionTestUtil test_util(browser()); | |
90 content::WindowedNotificationObserver frame_observer( | |
91 content::NOTIFICATION_LOAD_COMPLETED_MAIN_FRAME, | |
92 content::NotificationService::AllSources()); | |
93 // Open popup in the first extension. | |
94 test_util.Press(0); | |
95 frame_observer.Wait(); | |
96 ASSERT_TRUE(test_util.HasPopup()); | |
97 | |
98 // We now have a view, but still no background hosts. | |
99 EXPECT_EQ(0u, pm->background_hosts().size()); | |
100 EXPECT_EQ(1u, pm->GetAllViews().size()); | |
101 EXPECT_FALSE(pm->GetBackgroundHostForExtension(popup->id())); | |
102 EXPECT_EQ(1u, pm->GetRenderViewHostsForExtension(popup->id()).size()); | |
103 EXPECT_TRUE(pm->GetSiteInstanceForURL(popup->url())); | |
104 EXPECT_FALSE(pm->IsBackgroundHostClosing(popup->id())); | |
105 EXPECT_EQ(0, pm->GetLazyKeepaliveCount(popup.get())); | |
106 } | |
OLD | NEW |