OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #ifndef CHROME_TEST_BASE_MODULE_SYSTEM_TEST_H_ | 5 #ifndef EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_ |
6 #define CHROME_TEST_BASE_MODULE_SYSTEM_TEST_H_ | 6 #define EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_ |
7 | 7 |
8 #include "chrome/renderer/extensions/chrome_v8_context.h" | |
9 #include "extensions/renderer/module_system.h" | 8 #include "extensions/renderer/module_system.h" |
10 #include "extensions/renderer/scoped_persistent.h" | 9 #include "extensions/renderer/scoped_persistent.h" |
10 #include "extensions/renderer/script_context.h" | |
11 #include "gin/public/context_holder.h" | 11 #include "gin/public/context_holder.h" |
12 #include "gin/public/isolate_holder.h" | 12 #include "gin/public/isolate_holder.h" |
13 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
14 #include "v8/include/v8.h" | 14 #include "v8/include/v8.h" |
15 | 15 |
not at google - send to devlin
2014/07/10 15:22:56
can we move this file into the extensions namespac
Sam McNally
2014/07/11 00:01:17
Done.
| |
16 class ModuleSystemTestEnvironment { | 16 class ModuleSystemTestEnvironment { |
17 public: | 17 public: |
18 class AssertNatives; | 18 class AssertNatives; |
19 class StringSourceMap; | 19 class StringSourceMap; |
20 | 20 |
21 explicit ModuleSystemTestEnvironment(gin::IsolateHolder* isolate_holder); | 21 explicit ModuleSystemTestEnvironment(gin::IsolateHolder* isolate_holder); |
22 ~ModuleSystemTestEnvironment(); | 22 ~ModuleSystemTestEnvironment(); |
23 | 23 |
24 // Register a named JS module in the module system. | 24 // Register a named JS module in the module system. |
25 void RegisterModule(const std::string& name, const std::string& code); | 25 void RegisterModule(const std::string& name, const std::string& code); |
(...skipping 15 matching lines...) Expand all Loading... | |
41 v8::Handle<v8::Object> CreateGlobal(const std::string& name); | 41 v8::Handle<v8::Object> CreateGlobal(const std::string& name); |
42 | 42 |
43 void ShutdownGin(); | 43 void ShutdownGin(); |
44 | 44 |
45 void ShutdownModuleSystem(); | 45 void ShutdownModuleSystem(); |
46 | 46 |
47 extensions::ModuleSystem* module_system() { | 47 extensions::ModuleSystem* module_system() { |
48 return context_->module_system(); | 48 return context_->module_system(); |
49 } | 49 } |
50 | 50 |
51 extensions::ChromeV8Context* context() { return context_.get(); } | 51 extensions::ScriptContext* context() { return context_.get(); } |
52 | 52 |
53 v8::Isolate* isolate() { return isolate_holder_->isolate(); } | 53 v8::Isolate* isolate() { return isolate_holder_->isolate(); } |
54 | 54 |
55 AssertNatives* assert_natives() { return assert_natives_; } | 55 AssertNatives* assert_natives() { return assert_natives_; } |
56 | 56 |
57 private: | 57 private: |
58 gin::IsolateHolder* isolate_holder_; | 58 gin::IsolateHolder* isolate_holder_; |
59 scoped_ptr<gin::ContextHolder> context_holder_; | 59 scoped_ptr<gin::ContextHolder> context_holder_; |
60 v8::HandleScope handle_scope_; | 60 v8::HandleScope handle_scope_; |
61 scoped_ptr<extensions::ChromeV8Context> context_; | 61 scoped_ptr<extensions::ScriptContext> context_; |
62 AssertNatives* assert_natives_; | 62 AssertNatives* assert_natives_; |
63 scoped_ptr<StringSourceMap> source_map_; | 63 scoped_ptr<StringSourceMap> source_map_; |
64 | 64 |
65 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTestEnvironment); | 65 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTestEnvironment); |
66 }; | 66 }; |
67 | 67 |
68 // Test fixture for testing JS that makes use of the module system. | 68 // Test fixture for testing JS that makes use of the module system. |
69 // | 69 // |
70 // Typically tests will look like: | 70 // Typically tests will look like: |
71 // | 71 // |
72 // TEST_F(MyModuleSystemTest, TestStuff) { | 72 // TEST_F(MyModuleSystemTest, TestStuff) { |
73 // ModuleSystem::NativesEnabledScope natives_enabled(module_system_.get()); | 73 // ModuleSystem::NativesEnabledScope natives_enabled(module_system_.get()); |
74 // RegisterModule("test", "requireNative('assert').AssertTrue(true);"); | 74 // RegisterModule("test", "requireNative('assert').AssertTrue(true);"); |
75 // module_system_->Require("test"); | 75 // module_system_->Require("test"); |
76 // } | 76 // } |
77 // | 77 // |
78 // By default a test will fail if no method in the native module 'assert' is | 78 // By default a test will fail if no method in the native module 'assert' is |
79 // called. This behaviour can be overridden by calling ExpectNoAssertionsMade(). | 79 // called. This behaviour can be overridden by calling ExpectNoAssertionsMade(). |
80 // | |
81 // TODO(kalman): move this back into chrome/renderer/extensions. | |
not at google - send to devlin
2014/07/10 15:22:56
thanks :)
| |
82 class ModuleSystemTest : public testing::Test { | 80 class ModuleSystemTest : public testing::Test { |
83 public: | 81 public: |
84 ModuleSystemTest(); | 82 ModuleSystemTest(); |
85 virtual ~ModuleSystemTest(); | 83 virtual ~ModuleSystemTest(); |
86 | 84 |
87 virtual void TearDown() OVERRIDE; | 85 virtual void TearDown() OVERRIDE; |
88 | 86 |
89 protected: | 87 protected: |
90 ModuleSystemTestEnvironment* env() { return env_.get(); } | 88 ModuleSystemTestEnvironment* env() { return env_.get(); } |
91 | 89 |
92 scoped_ptr<ModuleSystemTestEnvironment> CreateEnvironment(); | 90 scoped_ptr<ModuleSystemTestEnvironment> CreateEnvironment(); |
93 | 91 |
94 // Make the test fail if any asserts are called. By default a test will fail | 92 // Make the test fail if any asserts are called. By default a test will fail |
95 // if no asserts are called. | 93 // if no asserts are called. |
96 void ExpectNoAssertionsMade(); | 94 void ExpectNoAssertionsMade(); |
97 | 95 |
98 // Runs promises that have been resolved. Resolved promises will not run | 96 // Runs promises that have been resolved. Resolved promises will not run |
99 // until this is called. | 97 // until this is called. |
100 void RunResolvedPromises(); | 98 void RunResolvedPromises(); |
101 | 99 |
102 private: | 100 private: |
103 gin::IsolateHolder isolate_holder_; | 101 gin::IsolateHolder isolate_holder_; |
104 scoped_ptr<ModuleSystemTestEnvironment> env_; | 102 scoped_ptr<ModuleSystemTestEnvironment> env_; |
105 bool should_assertions_be_made_; | 103 bool should_assertions_be_made_; |
106 | 104 |
107 private: | 105 private: |
108 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTest); | 106 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTest); |
109 }; | 107 }; |
110 | 108 |
111 #endif // CHROME_TEST_BASE_MODULE_SYSTEM_TEST_H_ | 109 #endif // EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_ |
OLD | NEW |