Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(724)

Side by Side Diff: extensions/renderer/module_system_test.h

Issue 375243002: Move ModuleSystemTest and the tests that use it into extensions/. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698