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 "gin/modules/module_registry.h" | 5 #include "gin/modules/module_registry.h" |
6 | 6 |
| 7 #include "base/bind.h" |
7 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
8 #include "gin/modules/module_registry_observer.h" | 9 #include "gin/modules/module_registry_observer.h" |
9 #include "gin/modules/module_runner_delegate.h" | 10 #include "gin/modules/module_runner_delegate.h" |
10 #include "gin/public/context_holder.h" | 11 #include "gin/public/context_holder.h" |
11 #include "gin/public/isolate_holder.h" | 12 #include "gin/public/isolate_holder.h" |
12 #include "gin/shell_runner.h" | 13 #include "gin/shell_runner.h" |
13 #include "gin/test/v8_test.h" | 14 #include "gin/test/v8_test.h" |
14 #include "v8/include/v8.h" | 15 #include "v8/include/v8.h" |
15 | 16 |
16 namespace gin { | 17 namespace gin { |
(...skipping 30 matching lines...) Expand all Loading... |
47 const std::vector<std::string>& dependencies() const { return dependencies_; } | 48 const std::vector<std::string>& dependencies() const { return dependencies_; } |
48 | 49 |
49 private: | 50 private: |
50 int did_add_count_; | 51 int did_add_count_; |
51 std::string id_; | 52 std::string id_; |
52 std::vector<std::string> dependencies_; | 53 std::vector<std::string> dependencies_; |
53 | 54 |
54 DISALLOW_COPY_AND_ASSIGN(ModuleRegistryObserverImpl); | 55 DISALLOW_COPY_AND_ASSIGN(ModuleRegistryObserverImpl); |
55 }; | 56 }; |
56 | 57 |
| 58 void NestedCallback(v8::Handle<v8::Value> value) { |
| 59 FAIL() << "Should not be called"; |
| 60 } |
| 61 |
| 62 void OnModuleLoaded(TestHelper* helper, |
| 63 v8::Isolate* isolate, |
| 64 int64_t* counter, |
| 65 v8::Handle<v8::Value> value) { |
| 66 ASSERT_TRUE(value->IsNumber()); |
| 67 v8::Handle<v8::Integer> int_value = v8::Handle<v8::Integer>::Cast(value); |
| 68 *counter += int_value->Value(); |
| 69 ModuleRegistry::From(helper->runner->GetContextHolder()->context()) |
| 70 ->LoadModule(isolate, "two", base::Bind(NestedCallback)); |
| 71 } |
| 72 |
57 } // namespace | 73 } // namespace |
58 | 74 |
59 typedef V8Test ModuleRegistryTest; | 75 typedef V8Test ModuleRegistryTest; |
60 | 76 |
61 // Verifies ModuleRegistry is not available after ContextHolder has been | 77 // Verifies ModuleRegistry is not available after ContextHolder has been |
62 // deleted. | 78 // deleted. |
63 TEST_F(ModuleRegistryTest, DestroyedWithContext) { | 79 TEST_F(ModuleRegistryTest, DestroyedWithContext) { |
64 v8::Isolate::Scope isolate_scope(instance_->isolate()); | 80 v8::Isolate::Scope isolate_scope(instance_->isolate()); |
65 v8::HandleScope handle_scope(instance_->isolate()); | 81 v8::HandleScope handle_scope(instance_->isolate()); |
66 v8::Handle<v8::Context> context = v8::Context::New( | 82 v8::Handle<v8::Context> context = v8::Context::New( |
(...skipping 22 matching lines...) Expand all Loading... |
89 helper.runner->Run(source, "script"); | 105 helper.runner->Run(source, "script"); |
90 ModuleRegistry::From(helper.runner->GetContextHolder()->context())-> | 106 ModuleRegistry::From(helper.runner->GetContextHolder()->context())-> |
91 RemoveObserver(&observer); | 107 RemoveObserver(&observer); |
92 EXPECT_EQ(1, observer.did_add_count()); | 108 EXPECT_EQ(1, observer.did_add_count()); |
93 EXPECT_EQ("id", observer.id()); | 109 EXPECT_EQ("id", observer.id()); |
94 ASSERT_EQ(2u, observer.dependencies().size()); | 110 ASSERT_EQ(2u, observer.dependencies().size()); |
95 EXPECT_EQ("dep1", observer.dependencies()[0]); | 111 EXPECT_EQ("dep1", observer.dependencies()[0]); |
96 EXPECT_EQ("dep2", observer.dependencies()[1]); | 112 EXPECT_EQ("dep2", observer.dependencies()[1]); |
97 } | 113 } |
98 | 114 |
| 115 // Verifies that multiple LoadModule calls for the same module are handled |
| 116 // correctly. |
| 117 TEST_F(ModuleRegistryTest, LoadModuleTest) { |
| 118 TestHelper helper(instance_->isolate()); |
| 119 int64_t counter = 0; |
| 120 std::string source = |
| 121 "define('one', [], function() {" |
| 122 " return 1;" |
| 123 "});"; |
| 124 |
| 125 ModuleRegistry::LoadModuleCallback callback = |
| 126 base::Bind(OnModuleLoaded, &helper, instance_->isolate(), &counter); |
| 127 for (int i = 0; i < 3; i++) { |
| 128 ModuleRegistry::From(helper.runner->GetContextHolder()->context()) |
| 129 ->LoadModule(instance_->isolate(), "one", callback); |
| 130 } |
| 131 EXPECT_EQ(0, counter); |
| 132 helper.runner->Run(source, "script"); |
| 133 EXPECT_EQ(3, counter); |
| 134 } |
| 135 |
99 } // namespace gin | 136 } // namespace gin |
OLD | NEW |