Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Unified Diff: test/JsValue.cpp

Issue 29417624: Issue 5034 - Part 4: JsEngine::Evaluate() return a JsValue (Closed) Base URL: https://hg.adblockplus.org/libadblockplus/
Patch Set: Created April 19, 2017, 6:18 p.m.
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: test/JsValue.cpp
===================================================================
--- a/test/JsValue.cpp
+++ b/test/JsValue.cpp
@@ -21,205 +21,205 @@
{
class JsValueTest : public BaseJsTest
{
};
}
TEST_F(JsValueTest, UndefinedValue)
{
- 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());
- ASSERT_EQ("undefined", value->AsString());
- ASSERT_FALSE(value->AsBool());
- ASSERT_ANY_THROW(value->AsList());
- ASSERT_ANY_THROW(value->GetProperty("foo"));
- ASSERT_ANY_THROW(value->SetProperty("foo", false));
- ASSERT_ANY_THROW(value->GetClass());
- ASSERT_ANY_THROW(value->GetOwnPropertyNames());
- ASSERT_ANY_THROW(value->Call());
+ auto 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());
+ ASSERT_EQ("undefined", value.AsString());
+ ASSERT_FALSE(value.AsBool());
+ ASSERT_ANY_THROW(value.AsList());
+ ASSERT_ANY_THROW(value.GetProperty("foo"));
+ ASSERT_ANY_THROW(value.SetProperty("foo", false));
+ ASSERT_ANY_THROW(value.GetClass());
+ ASSERT_ANY_THROW(value.GetOwnPropertyNames());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, NullValue)
{
- 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());
- ASSERT_EQ("null", value->AsString());
- ASSERT_FALSE(value->AsBool());
- ASSERT_ANY_THROW(value->AsList());
- ASSERT_ANY_THROW(value->GetProperty("foo"));
- ASSERT_ANY_THROW(value->SetProperty("foo", false));
- ASSERT_ANY_THROW(value->GetClass());
- ASSERT_ANY_THROW(value->GetOwnPropertyNames());
- ASSERT_ANY_THROW(value->Call());
+ auto 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());
+ ASSERT_EQ("null", value.AsString());
+ ASSERT_FALSE(value.AsBool());
+ ASSERT_ANY_THROW(value.AsList());
+ ASSERT_ANY_THROW(value.GetProperty("foo"));
+ ASSERT_ANY_THROW(value.SetProperty("foo", false));
+ ASSERT_ANY_THROW(value.GetClass());
+ ASSERT_ANY_THROW(value.GetOwnPropertyNames());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, StringValue)
{
- 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());
- ASSERT_EQ("123", value->AsString());
- ASSERT_EQ(123, value->AsInt());
- ASSERT_TRUE(value->AsBool());
- ASSERT_ANY_THROW(value->AsList());
- ASSERT_ANY_THROW(value->GetProperty("foo"));
- ASSERT_ANY_THROW(value->SetProperty("foo", false));
- ASSERT_ANY_THROW(value->GetClass());
- ASSERT_ANY_THROW(value->GetOwnPropertyNames());
- ASSERT_ANY_THROW(value->Call());
+ auto 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());
+ ASSERT_EQ("123", value.AsString());
+ ASSERT_EQ(123, value.AsInt());
+ ASSERT_TRUE(value.AsBool());
+ ASSERT_ANY_THROW(value.AsList());
+ ASSERT_ANY_THROW(value.GetProperty("foo"));
+ ASSERT_ANY_THROW(value.SetProperty("foo", false));
+ ASSERT_ANY_THROW(value.GetClass());
+ ASSERT_ANY_THROW(value.GetOwnPropertyNames());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, IntValue)
{
- AdblockPlus::JsValuePtr value = jsEngine->Evaluate("12345678901234");
- 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());
- ASSERT_EQ("12345678901234", value->AsString());
- ASSERT_EQ(12345678901234, value->AsInt());
- ASSERT_TRUE(value->AsBool());
- ASSERT_ANY_THROW(value->AsList());
- ASSERT_ANY_THROW(value->GetProperty("foo"));
- ASSERT_ANY_THROW(value->SetProperty("foo", false));
- ASSERT_ANY_THROW(value->GetClass());
- ASSERT_ANY_THROW(value->GetOwnPropertyNames());
- ASSERT_ANY_THROW(value->Call());
+ auto value = jsEngine->Evaluate("12345678901234");
+ 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());
+ ASSERT_EQ("12345678901234", value.AsString());
+ ASSERT_EQ(12345678901234, value.AsInt());
+ ASSERT_TRUE(value.AsBool());
+ ASSERT_ANY_THROW(value.AsList());
+ ASSERT_ANY_THROW(value.GetProperty("foo"));
+ ASSERT_ANY_THROW(value.SetProperty("foo", false));
+ ASSERT_ANY_THROW(value.GetClass());
+ ASSERT_ANY_THROW(value.GetOwnPropertyNames());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, BoolValue)
{
- 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());
- ASSERT_EQ("true", value->AsString());
- ASSERT_TRUE(value->AsBool());
- ASSERT_ANY_THROW(value->AsList());
- ASSERT_ANY_THROW(value->GetProperty("foo"));
- ASSERT_ANY_THROW(value->SetProperty("foo", false));
- ASSERT_ANY_THROW(value->GetClass());
- ASSERT_ANY_THROW(value->GetOwnPropertyNames());
- ASSERT_ANY_THROW(value->Call());
+ auto 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());
+ ASSERT_EQ("true", value.AsString());
+ ASSERT_TRUE(value.AsBool());
+ ASSERT_ANY_THROW(value.AsList());
+ ASSERT_ANY_THROW(value.GetProperty("foo"));
+ ASSERT_ANY_THROW(value.SetProperty("foo", false));
+ ASSERT_ANY_THROW(value.GetClass());
+ ASSERT_ANY_THROW(value.GetOwnPropertyNames());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, ObjectValue)
{
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);
- 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));
- ASSERT_EQ(15, value->GetProperty("x").AsInt());
- ASSERT_EQ("Foo", value->GetClass());
- ASSERT_EQ(3u, value->GetOwnPropertyNames().size());
- ASSERT_ANY_THROW(value->Call());
+ auto 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));
+ ASSERT_EQ(15, value.GetProperty("x").AsInt());
+ ASSERT_EQ("Foo", value.GetClass());
+ ASSERT_EQ(3u, value.GetOwnPropertyNames().size());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, ArrayValue)
{
- 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());
- ASSERT_EQ("5,8,12", value->AsString());
- ASSERT_TRUE(value->AsBool());
- ASSERT_EQ(3u, value->AsList().size());
- ASSERT_EQ(8, value->AsList()[1].AsInt());
- ASSERT_EQ(3, value->GetProperty("length").AsInt());
- ASSERT_EQ("Array", value->GetClass());
- ASSERT_ANY_THROW(value->Call());
+ auto 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());
+ ASSERT_EQ("5,8,12", value.AsString());
+ ASSERT_TRUE(value.AsBool());
+ ASSERT_EQ(3u, value.AsList().size());
+ ASSERT_EQ(8, value.AsList()[1].AsInt());
+ ASSERT_EQ(3, value.GetProperty("length").AsInt());
+ ASSERT_EQ("Array", value.GetClass());
+ ASSERT_ANY_THROW(value.Call());
}
TEST_F(JsValueTest, FunctionValue)
{
- 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());
+ auto 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})");
+ auto thisPtr = jsEngine->Evaluate("({x:2})");
AdblockPlus::JsValueList params;
params.push_back(jsEngine->NewValue(5));
params.push_back(jsEngine->NewValue("xyz"));
- ASSERT_EQ("2/5/xyz", value->Call(params, thisPtr).AsString());
+ ASSERT_EQ("2/5/xyz", value.Call(params, thisPtr).AsString());
}
TEST_F(JsValueTest, JsValueCallSingleArg)
{
auto func = jsEngine->Evaluate("(function(arg) {return arg * 2;})");
- EXPECT_EQ(10, func->Call(jsEngine->NewValue(5)).AsInt());
+ EXPECT_EQ(10, func.Call(jsEngine->NewValue(5)).AsInt());
}
TEST_F(JsValueTest, ThrowingCoversion)
{
const std::string source("\
function Foo() {\
this.toString = function() {throw 'test1';};\
this.valueOf = function() {throw 'test2';};\
};\
new Foo()");
- AdblockPlus::JsValuePtr value = jsEngine->Evaluate(source);
- ASSERT_EQ("", value->AsString());
- ASSERT_EQ(0, value->AsInt());
+ auto value = jsEngine->Evaluate(source);
+ ASSERT_EQ("", value.AsString());
+ ASSERT_EQ(0, value.AsInt());
}
« include/AdblockPlus/JsValue.h ('K') | « test/JsEngine.cpp ('k') | test/UpdateCheck.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld