OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "base/memory/scoped_ptr.h" | 5 #include "base/memory/scoped_ptr.h" |
6 #include "base/values.h" | 6 #include "base/values.h" |
7 #include "chrome/renderer/extensions/activity_log_converter_strategy.h" | 7 #include "chrome/renderer/extensions/activity_log_converter_strategy.h" |
8 #include "chrome/renderer/extensions/scoped_persistent.h" | 8 #include "chrome/renderer/extensions/scoped_persistent.h" |
9 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
10 #include "v8/include/v8.h" | 10 #include "v8/include/v8.h" |
11 | 11 |
12 using content::V8ValueConverter; | 12 using content::V8ValueConverter; |
13 | 13 |
14 namespace extensions { | 14 namespace extensions { |
15 | 15 |
16 class ActivityLogConverterStrategyTest : public testing::Test { | 16 class ActivityLogConverterStrategyTest : public testing::Test { |
17 public: | 17 public: |
18 ActivityLogConverterStrategyTest() | 18 ActivityLogConverterStrategyTest() |
19 : isolate_(v8::Isolate::GetCurrent()) | 19 : isolate_(v8::Isolate::GetCurrent()) |
20 , handle_scope_(isolate_) | 20 , handle_scope_(isolate_) |
21 , context_(v8::Context::New(isolate_)) | 21 , context_(v8::Context::New(isolate_)) |
22 , context_scope_(context_.get()) { | 22 , context_scope_(context_.NewHandle(isolate_)) { |
23 } | 23 } |
24 | 24 |
25 protected: | 25 protected: |
26 virtual void SetUp() { | 26 virtual void SetUp() { |
27 converter_.reset(V8ValueConverter::create()); | 27 converter_.reset(V8ValueConverter::create()); |
28 strategy_.reset(new ActivityLogConverterStrategy()); | 28 strategy_.reset(new ActivityLogConverterStrategy()); |
29 converter_->SetFunctionAllowed(true); | 29 converter_->SetFunctionAllowed(true); |
30 converter_->SetStrategy(strategy_.get()); | 30 converter_->SetStrategy(strategy_.get()); |
31 } | 31 } |
32 | 32 |
33 testing::AssertionResult VerifyNull(v8::Local<v8::Value> v8_value) { | 33 testing::AssertionResult VerifyNull(v8::Local<v8::Value> v8_value) { |
34 scoped_ptr<base::Value> value( | 34 scoped_ptr<base::Value> value( |
35 converter_->FromV8Value(v8_value, context_.get())); | 35 converter_->FromV8Value(v8_value, |
36 context_.NewHandle(v8::Isolate::GetCurrent()))); | |
Jeffrey Yasskin
2013/09/09 17:45:07
Could you add a method "context()" or "context_han
marja
2013/09/09 18:16:18
Done (though, I noticed there is also isolate_ so
| |
36 if (value->IsType(base::Value::TYPE_NULL)) | 37 if (value->IsType(base::Value::TYPE_NULL)) |
37 return testing::AssertionSuccess(); | 38 return testing::AssertionSuccess(); |
38 return testing::AssertionFailure(); | 39 return testing::AssertionFailure(); |
39 } | 40 } |
40 | 41 |
41 testing::AssertionResult VerifyBoolean(v8::Local<v8::Value> v8_value, | 42 testing::AssertionResult VerifyBoolean(v8::Local<v8::Value> v8_value, |
42 bool expected) { | 43 bool expected) { |
43 bool out; | 44 bool out; |
44 scoped_ptr<base::Value> value( | 45 scoped_ptr<base::Value> value( |
45 converter_->FromV8Value(v8_value, context_.get())); | 46 converter_->FromV8Value(v8_value, |
47 context_.NewHandle(v8::Isolate::GetCurrent()))); | |
46 if (value->IsType(base::Value::TYPE_BOOLEAN) | 48 if (value->IsType(base::Value::TYPE_BOOLEAN) |
47 && value->GetAsBoolean(&out) | 49 && value->GetAsBoolean(&out) |
48 && out == expected) | 50 && out == expected) |
49 return testing::AssertionSuccess(); | 51 return testing::AssertionSuccess(); |
50 return testing::AssertionFailure(); | 52 return testing::AssertionFailure(); |
51 } | 53 } |
52 | 54 |
53 testing::AssertionResult VerifyInteger(v8::Local<v8::Value> v8_value, | 55 testing::AssertionResult VerifyInteger(v8::Local<v8::Value> v8_value, |
54 int expected) { | 56 int expected) { |
55 int out; | 57 int out; |
56 scoped_ptr<base::Value> value( | 58 scoped_ptr<base::Value> value( |
57 converter_->FromV8Value(v8_value, context_.get())); | 59 converter_->FromV8Value(v8_value, |
60 context_.NewHandle(v8::Isolate::GetCurrent()))); | |
58 if (value->IsType(base::Value::TYPE_INTEGER) | 61 if (value->IsType(base::Value::TYPE_INTEGER) |
59 && value->GetAsInteger(&out) | 62 && value->GetAsInteger(&out) |
60 && out == expected) | 63 && out == expected) |
61 return testing::AssertionSuccess(); | 64 return testing::AssertionSuccess(); |
62 return testing::AssertionFailure(); | 65 return testing::AssertionFailure(); |
63 } | 66 } |
64 | 67 |
65 testing::AssertionResult VerifyDouble(v8::Local<v8::Value> v8_value, | 68 testing::AssertionResult VerifyDouble(v8::Local<v8::Value> v8_value, |
66 double expected) { | 69 double expected) { |
67 double out; | 70 double out; |
68 scoped_ptr<base::Value> value( | 71 scoped_ptr<base::Value> value( |
69 converter_->FromV8Value(v8_value, context_.get())); | 72 converter_->FromV8Value(v8_value, |
73 context_.NewHandle(v8::Isolate::GetCurrent()))); | |
70 if (value->IsType(base::Value::TYPE_DOUBLE) | 74 if (value->IsType(base::Value::TYPE_DOUBLE) |
71 && value->GetAsDouble(&out) | 75 && value->GetAsDouble(&out) |
72 && out == expected) | 76 && out == expected) |
73 return testing::AssertionSuccess(); | 77 return testing::AssertionSuccess(); |
74 return testing::AssertionFailure(); | 78 return testing::AssertionFailure(); |
75 } | 79 } |
76 | 80 |
77 testing::AssertionResult VerifyString(v8::Local<v8::Value> v8_value, | 81 testing::AssertionResult VerifyString(v8::Local<v8::Value> v8_value, |
78 const std::string& expected) { | 82 const std::string& expected) { |
79 std::string out; | 83 std::string out; |
80 scoped_ptr<base::Value> value( | 84 scoped_ptr<base::Value> value( |
81 converter_->FromV8Value(v8_value, context_.get())); | 85 converter_->FromV8Value(v8_value, |
86 context_.NewHandle(v8::Isolate::GetCurrent()))); | |
82 if (value->IsType(base::Value::TYPE_STRING) | 87 if (value->IsType(base::Value::TYPE_STRING) |
83 && value->GetAsString(&out) | 88 && value->GetAsString(&out) |
84 && out == expected) | 89 && out == expected) |
85 return testing::AssertionSuccess(); | 90 return testing::AssertionSuccess(); |
86 return testing::AssertionFailure(); | 91 return testing::AssertionFailure(); |
87 } | 92 } |
88 | 93 |
89 v8::Isolate* isolate_; | 94 v8::Isolate* isolate_; |
90 v8::HandleScope handle_scope_; | 95 v8::HandleScope handle_scope_; |
91 ScopedPersistent<v8::Context> context_; | 96 ScopedPersistent<v8::Context> context_; |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
148 "[Array]")); | 153 "[Array]")); |
149 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("empty_list")), | 154 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("empty_list")), |
150 "[Array]")); | 155 "[Array]")); |
151 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("function")), | 156 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("function")), |
152 "[Function]")); | 157 "[Function]")); |
153 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("named_function")), | 158 EXPECT_TRUE(VerifyString(v8_object->Get(v8::String::New("named_function")), |
154 "[Function foo()]")); | 159 "[Function foo()]")); |
155 } | 160 } |
156 | 161 |
157 } // namespace extensions | 162 } // namespace extensions |
158 | |
OLD | NEW |