OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "extensions/browser/mojo/keep_alive_impl.h" | 5 #include "extensions/browser/mojo/keep_alive_impl.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 public: | 21 public: |
22 KeepAliveTest() | 22 KeepAliveTest() |
23 : notification_service_(content::NotificationService::Create()) {} | 23 : notification_service_(content::NotificationService::Create()) {} |
24 ~KeepAliveTest() override {} | 24 ~KeepAliveTest() override {} |
25 | 25 |
26 void SetUp() override { | 26 void SetUp() override { |
27 ExtensionsTest::SetUp(); | 27 ExtensionsTest::SetUp(); |
28 message_loop_.reset(new base::MessageLoop); | 28 message_loop_.reset(new base::MessageLoop); |
29 extension_ = | 29 extension_ = |
30 ExtensionBuilder() | 30 ExtensionBuilder() |
31 .SetManifest(std::move( | 31 .SetManifest( |
32 DictionaryBuilder() | 32 DictionaryBuilder() |
33 .Set("name", "app") | 33 .Set("name", "app") |
34 .Set("version", "1") | 34 .Set("version", "1") |
35 .Set("manifest_version", 2) | 35 .Set("manifest_version", 2) |
36 .Set("app", | 36 .Set("app", DictionaryBuilder() |
37 std::move(DictionaryBuilder().Set( | 37 .Set("background", |
38 "background", | 38 DictionaryBuilder() |
39 std::move(DictionaryBuilder().Set( | 39 .Set("scripts", |
40 "scripts", std::move(ListBuilder().Append( | 40 ListBuilder() |
41 "background.js"))))))))) | 41 .Append("background.js") |
| 42 .Build()) |
| 43 .Build()) |
| 44 .Build()) |
| 45 .Build()) |
42 .SetID("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa") | 46 .SetID("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa") |
43 .Build(); | 47 .Build(); |
44 } | 48 } |
45 | 49 |
46 void TearDown() override { | 50 void TearDown() override { |
47 message_loop_.reset(); | 51 message_loop_.reset(); |
48 ExtensionsTest::TearDown(); | 52 ExtensionsTest::TearDown(); |
49 } | 53 } |
50 | 54 |
51 void WaitUntilLazyKeepAliveChanges() { | 55 void WaitUntilLazyKeepAliveChanges() { |
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
103 EXPECT_EQ(0, GetKeepAliveCount()); | 107 EXPECT_EQ(0, GetKeepAliveCount()); |
104 } | 108 } |
105 | 109 |
106 TEST_F(KeepAliveTest, UnloadExtension) { | 110 TEST_F(KeepAliveTest, UnloadExtension) { |
107 mojo::InterfacePtr<KeepAlive> keep_alive; | 111 mojo::InterfacePtr<KeepAlive> keep_alive; |
108 CreateKeepAlive(mojo::GetProxy(&keep_alive)); | 112 CreateKeepAlive(mojo::GetProxy(&keep_alive)); |
109 EXPECT_EQ(1, GetKeepAliveCount()); | 113 EXPECT_EQ(1, GetKeepAliveCount()); |
110 | 114 |
111 scoped_refptr<const Extension> other_extension = | 115 scoped_refptr<const Extension> other_extension = |
112 ExtensionBuilder() | 116 ExtensionBuilder() |
113 .SetManifest(std::move( | 117 .SetManifest( |
114 DictionaryBuilder() | 118 DictionaryBuilder() |
115 .Set("name", "app") | 119 .Set("name", "app") |
116 .Set("version", "1") | 120 .Set("version", "1") |
117 .Set("manifest_version", 2) | 121 .Set("manifest_version", 2) |
118 .Set("app", std::move(DictionaryBuilder().Set( | 122 .Set("app", |
119 "background", | 123 DictionaryBuilder() |
120 std::move(DictionaryBuilder().Set( | 124 .Set("background", |
121 "scripts", std::move(ListBuilder().Append( | 125 DictionaryBuilder() |
122 "background.js"))))))))) | 126 .Set("scripts", ListBuilder() |
| 127 .Append("background.js") |
| 128 .Build()) |
| 129 .Build()) |
| 130 .Build()) |
| 131 .Build()) |
123 .SetID("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb") | 132 .SetID("bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb") |
124 .Build(); | 133 .Build(); |
125 | 134 |
126 ExtensionRegistry::Get(browser_context()) | 135 ExtensionRegistry::Get(browser_context()) |
127 ->TriggerOnUnloaded(other_extension.get(), | 136 ->TriggerOnUnloaded(other_extension.get(), |
128 UnloadedExtensionInfo::REASON_DISABLE); | 137 UnloadedExtensionInfo::REASON_DISABLE); |
129 EXPECT_EQ(1, GetKeepAliveCount()); | 138 EXPECT_EQ(1, GetKeepAliveCount()); |
130 | 139 |
131 ExtensionRegistry::Get(browser_context()) | 140 ExtensionRegistry::Get(browser_context()) |
132 ->TriggerOnUnloaded(extension(), UnloadedExtensionInfo::REASON_DISABLE); | 141 ->TriggerOnUnloaded(extension(), UnloadedExtensionInfo::REASON_DISABLE); |
(...skipping 18 matching lines...) Expand all Loading... |
151 // ProcessManager and so the keep-alive count should remain unchanged. | 160 // ProcessManager and so the keep-alive count should remain unchanged. |
152 EXPECT_EQ(1, GetKeepAliveCount()); | 161 EXPECT_EQ(1, GetKeepAliveCount()); |
153 | 162 |
154 // Wait for |keep_alive| to disconnect. | 163 // Wait for |keep_alive| to disconnect. |
155 base::RunLoop run_loop; | 164 base::RunLoop run_loop; |
156 keep_alive.set_connection_error_handler(run_loop.QuitClosure()); | 165 keep_alive.set_connection_error_handler(run_loop.QuitClosure()); |
157 run_loop.Run(); | 166 run_loop.Run(); |
158 } | 167 } |
159 | 168 |
160 } // namespace extensions | 169 } // namespace extensions |
OLD | NEW |