Adding Peter Thatcher to the owners file.
[chromium-blink-merge.git] / extensions / renderer / module_system_test.h
blob1b75696300572313567d750b0aea29c09de38ac2
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
3 // found in the LICENSE file.
5 #ifndef EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_
6 #define EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_
8 #include "extensions/renderer/module_system.h"
9 #include "extensions/renderer/script_context.h"
10 #include "gin/public/context_holder.h"
11 #include "testing/gtest/include/gtest/gtest.h"
12 #include "v8/include/v8.h"
14 namespace extensions {
16 class ModuleSystemTestEnvironment {
17 public:
18 class AssertNatives;
19 class StringSourceMap;
21 explicit ModuleSystemTestEnvironment(v8::Isolate* isolate);
22 ~ModuleSystemTestEnvironment();
24 // Register a named JS module in the module system.
25 void RegisterModule(const std::string& name, const std::string& code);
27 // Register a named JS module with source retrieved from a ResourceBundle.
28 void RegisterModule(const std::string& name, int resource_id);
30 // Register a named JS module in the module system and tell the module system
31 // to use it to handle any requireNative() calls for native modules with that
32 // name.
33 void OverrideNativeHandler(const std::string& name, const std::string& code);
35 // Registers |file_name| from chrome/test/data/extensions as a module name
36 // |module_name|.
37 void RegisterTestFile(const std::string& module_name,
38 const std::string& file_name);
40 // Create an empty object in the global scope with name |name|.
41 v8::Handle<v8::Object> CreateGlobal(const std::string& name);
43 void ShutdownGin();
45 void ShutdownModuleSystem();
47 ModuleSystem* module_system() { return context_->module_system(); }
49 ScriptContext* context() { return context_.get(); }
51 v8::Isolate* isolate() { return isolate_; }
53 AssertNatives* assert_natives() { return assert_natives_; }
55 private:
56 v8::Isolate* isolate_;
57 scoped_ptr<gin::ContextHolder> context_holder_;
58 v8::HandleScope handle_scope_;
59 scoped_ptr<ScriptContext> context_;
60 AssertNatives* assert_natives_;
61 scoped_ptr<StringSourceMap> source_map_;
63 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTestEnvironment);
66 // Test fixture for testing JS that makes use of the module system.
68 // Typically tests will look like:
70 // TEST_F(MyModuleSystemTest, TestStuff) {
71 // ModuleSystem::NativesEnabledScope natives_enabled(module_system_.get());
72 // RegisterModule("test", "requireNative('assert').AssertTrue(true);");
73 // module_system_->Require("test");
74 // }
76 // By default a test will fail if no method in the native module 'assert' is
77 // called. This behaviour can be overridden by calling ExpectNoAssertionsMade().
78 class ModuleSystemTest : public testing::Test {
79 public:
80 ModuleSystemTest();
81 ~ModuleSystemTest() override;
83 void SetUp() override;
84 void TearDown() override;
86 protected:
87 ModuleSystemTestEnvironment* env() { return env_.get(); }
89 scoped_ptr<ModuleSystemTestEnvironment> CreateEnvironment();
91 // Make the test fail if any asserts are called. By default a test will fail
92 // if no asserts are called.
93 void ExpectNoAssertionsMade();
95 // Runs promises that have been resolved. Resolved promises will not run
96 // until this is called.
97 void RunResolvedPromises();
99 private:
100 v8::Isolate* isolate_;
101 scoped_ptr<ModuleSystemTestEnvironment> env_;
102 bool should_assertions_be_made_;
104 private:
105 DISALLOW_COPY_AND_ASSIGN(ModuleSystemTest);
108 } // namespace extensions
110 #endif // EXTENSIONS_RENDERER_MODULE_SYSTEM_TEST_H_