Index: test/JsValue.cpp |
=================================================================== |
--- a/test/JsValue.cpp |
+++ b/test/JsValue.cpp |
@@ -1,15 +1,15 @@ |
#include <AdblockPlus.h> |
#include <gtest/gtest.h> |
TEST(JsValueTest, UndefinedValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("undefined"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("undefined"); |
ASSERT_TRUE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_FALSE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -20,18 +20,18 @@ TEST(JsValueTest, UndefinedValue) |
ASSERT_ANY_THROW(value->SetProperty("foo", false)); |
ASSERT_ANY_THROW(value->GetClassName()); |
ASSERT_ANY_THROW(value->GetOwnPropertyNames()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, NullValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("null"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("null"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_TRUE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_FALSE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -42,18 +42,18 @@ TEST(JsValueTest, NullValue) |
ASSERT_ANY_THROW(value->SetProperty("foo", false)); |
ASSERT_ANY_THROW(value->GetClassName()); |
ASSERT_ANY_THROW(value->GetOwnPropertyNames()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, StringValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("'123'"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("'123'"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_TRUE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_FALSE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -65,18 +65,18 @@ TEST(JsValueTest, StringValue) |
ASSERT_ANY_THROW(value->SetProperty("foo", false)); |
ASSERT_ANY_THROW(value->GetClassName()); |
ASSERT_ANY_THROW(value->GetOwnPropertyNames()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, IntValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("123"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("123"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_TRUE(value->IsNumber()); |
ASSERT_FALSE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -88,18 +88,18 @@ TEST(JsValueTest, IntValue) |
ASSERT_ANY_THROW(value->SetProperty("foo", false)); |
ASSERT_ANY_THROW(value->GetClassName()); |
ASSERT_ANY_THROW(value->GetOwnPropertyNames()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, BoolValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("true"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("true"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_TRUE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_FALSE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -110,51 +110,51 @@ TEST(JsValueTest, BoolValue) |
ASSERT_ANY_THROW(value->SetProperty("foo", false)); |
ASSERT_ANY_THROW(value->GetClassName()); |
ASSERT_ANY_THROW(value->GetOwnPropertyNames()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, ObjectValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
const std::string source("\ |
function Foo() {\ |
this.x = 2;\ |
this.toString = function() {return 'foo';};\ |
this.valueOf = function() {return 123;};\ |
};\ |
new Foo()"); |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate(source); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate(source); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_TRUE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
ASSERT_EQ("foo", value->AsString()); |
ASSERT_EQ(123, value->AsInt()); |
ASSERT_TRUE(value->AsBool()); |
ASSERT_ANY_THROW(value->AsList()); |
ASSERT_EQ(2, value->GetProperty("x")->AsInt()); |
value->SetProperty("x", 12); |
ASSERT_EQ(12, value->GetProperty("x")->AsInt()); |
- value->SetProperty("x", jsEngine.NewValue(15)); |
+ value->SetProperty("x", jsEngine->NewValue(15)); |
ASSERT_EQ(15, value->GetProperty("x")->AsInt()); |
ASSERT_EQ("Foo", value->GetClassName()); |
ASSERT_EQ(3u, value->GetOwnPropertyNames().size()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, ArrayValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("[5,8,12]"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("[5,8,12]"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_TRUE(value->IsObject()); |
ASSERT_TRUE(value->IsArray()); |
ASSERT_FALSE(value->IsFunction()); |
@@ -164,42 +164,42 @@ TEST(JsValueTest, ArrayValue) |
ASSERT_EQ(8, value->AsList()[1]->AsInt()); |
ASSERT_EQ(3, value->GetProperty("length")->AsInt()); |
ASSERT_EQ("Array", value->GetClassName()); |
ASSERT_ANY_THROW(value->Call()); |
} |
TEST(JsValueTest, FunctionValue) |
{ |
- AdblockPlus::JsEngine jsEngine; |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate("(function(foo, bar) {return this.x + '/' + foo + '/' + bar;})"); |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate("(function(foo, bar) {return this.x + '/' + foo + '/' + bar;})"); |
ASSERT_FALSE(value->IsUndefined()); |
ASSERT_FALSE(value->IsNull()); |
ASSERT_FALSE(value->IsString()); |
ASSERT_FALSE(value->IsBool()); |
ASSERT_FALSE(value->IsNumber()); |
ASSERT_TRUE(value->IsObject()); |
ASSERT_FALSE(value->IsArray()); |
ASSERT_TRUE(value->IsFunction()); |
ASSERT_TRUE(value->AsBool()); |
ASSERT_ANY_THROW(value->AsList()); |
ASSERT_EQ(2, value->GetProperty("length")->AsInt()); |
- AdblockPlus::JsValuePtr thisPtr = jsEngine.Evaluate("({x:2})"); |
+ AdblockPlus::JsValuePtr thisPtr = jsEngine->Evaluate("({x:2})"); |
AdblockPlus::JsValueList params; |
- params.push_back(jsEngine.NewValue(5)); |
- params.push_back(jsEngine.NewValue("xyz")); |
+ params.push_back(jsEngine->NewValue(5)); |
+ params.push_back(jsEngine->NewValue("xyz")); |
ASSERT_EQ("2/5/xyz", value->Call(params, thisPtr)->AsString()); |
} |
TEST(JsValueTest, ThrowingCoversion) |
{ |
- AdblockPlus::JsEngine jsEngine; |
+ AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
const std::string source("\ |
function Foo() {\ |
this.toString = function() {throw 'test1';};\ |
this.valueOf = function() {throw 'test2';};\ |
};\ |
new Foo()"); |
- AdblockPlus::JsValuePtr value = jsEngine.Evaluate(source); |
+ AdblockPlus::JsValuePtr value = jsEngine->Evaluate(source); |
ASSERT_EQ("", value->AsString()); |
ASSERT_EQ(0, value->AsInt()); |
} |