| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2017 eyeo GmbH | 3 * Copyright (C) 2006-2017 eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 58 ASSERT_TRUE(value.IsBool()); | 58 ASSERT_TRUE(value.IsBool()); |
| 59 ASSERT_TRUE(value.AsBool()); | 59 ASSERT_TRUE(value.AsBool()); |
| 60 | 60 |
| 61 value = jsEngine->NewObject(); | 61 value = jsEngine->NewObject(); |
| 62 ASSERT_TRUE(value.IsObject()); | 62 ASSERT_TRUE(value.IsObject()); |
| 63 ASSERT_EQ(0u, value.GetOwnPropertyNames().size()); | 63 ASSERT_EQ(0u, value.GetOwnPropertyNames().size()); |
| 64 } | 64 } |
| 65 | 65 |
| 66 namespace { | 66 namespace { |
| 67 | 67 |
| 68 bool IsSame(const AdblockPlus::JsEnginePtr& jsEngine, | 68 bool IsSame(AdblockPlus::JsEngine& jsEngine, |
|
sergei
2017/04/20 12:45:08
Can be just `JsEngine&` (without pointer).
hub
2017/04/20 13:01:46
ok
| |
| 69 const AdblockPlus::JsValue& v1, const AdblockPlus::JsValue& v2) | 69 const AdblockPlus::JsValue& v1, const AdblockPlus::JsValue& v2) |
| 70 { | 70 { |
| 71 AdblockPlus::JsValueList params; | 71 AdblockPlus::JsValueList params; |
| 72 params.push_back(v1); | 72 params.push_back(v1); |
| 73 params.push_back(v2); | 73 params.push_back(v2); |
| 74 return jsEngine->Evaluate("f = function(a, b) { return a == b };")->Call(par ams).AsBool(); | 74 return jsEngine.Evaluate("f = function(a, b) { return a == b };")->Call(para ms).AsBool(); |
| 75 } | 75 } |
| 76 | 76 |
| 77 } | 77 } |
| 78 | 78 |
| 79 TEST_F(JsEngineTest, ValueCopy) | 79 TEST_F(JsEngineTest, ValueCopy) |
| 80 { | 80 { |
| 81 { | 81 { |
| 82 auto value = jsEngine->NewValue("foo"); | 82 auto value = jsEngine->NewValue("foo"); |
| 83 ASSERT_TRUE(value.IsString()); | 83 ASSERT_TRUE(value.IsString()); |
| 84 ASSERT_EQ("foo", value.AsString()); | 84 ASSERT_EQ("foo", value.AsString()); |
| 85 | 85 |
| 86 AdblockPlus::JsValue value2(value); | 86 AdblockPlus::JsValue value2(value); |
| 87 ASSERT_TRUE(value2.IsString()); | 87 ASSERT_TRUE(value2.IsString()); |
| 88 ASSERT_EQ("foo", value2.AsString()); | 88 ASSERT_EQ("foo", value2.AsString()); |
| 89 | 89 |
| 90 ASSERT_TRUE(IsSame(jsEngine, value, value2)); | 90 ASSERT_TRUE(IsSame(*jsEngine, value, value2)); |
|
sergei
2017/04/20 12:45:08
I think we should rather try to use EXPECT_ when i
hub
2017/04/20 13:01:46
I used ASSERT_ for consistency. EXPECT_ is fine to
| |
| 91 } | 91 } |
| 92 { | 92 { |
| 93 auto value = jsEngine->NewValue(12345678901234); | 93 auto value = jsEngine->NewValue(12345678901234); |
| 94 ASSERT_TRUE(value.IsNumber()); | 94 ASSERT_TRUE(value.IsNumber()); |
| 95 ASSERT_EQ(12345678901234, value.AsInt()); | 95 ASSERT_EQ(12345678901234, value.AsInt()); |
| 96 | 96 |
| 97 AdblockPlus::JsValue value2(value); | 97 AdblockPlus::JsValue value2(value); |
| 98 ASSERT_TRUE(value2.IsNumber()); | 98 ASSERT_TRUE(value2.IsNumber()); |
| 99 ASSERT_EQ(12345678901234, value2.AsInt()); | 99 ASSERT_EQ(12345678901234, value2.AsInt()); |
| 100 | 100 |
| 101 ASSERT_TRUE(IsSame(jsEngine, value, value2)); | 101 ASSERT_TRUE(IsSame(*jsEngine, value, value2)); |
| 102 } | 102 } |
| 103 { | 103 { |
| 104 auto value = jsEngine->NewValue(true); | 104 auto value = jsEngine->NewValue(true); |
| 105 ASSERT_TRUE(value.IsBool()); | 105 ASSERT_TRUE(value.IsBool()); |
| 106 ASSERT_TRUE(value.AsBool()); | 106 ASSERT_TRUE(value.AsBool()); |
| 107 | 107 |
| 108 AdblockPlus::JsValue value2(value); | 108 AdblockPlus::JsValue value2(value); |
| 109 ASSERT_TRUE(value2.IsBool()); | 109 ASSERT_TRUE(value2.IsBool()); |
| 110 ASSERT_TRUE(value2.AsBool()); | 110 ASSERT_TRUE(value2.AsBool()); |
| 111 | 111 |
| 112 ASSERT_TRUE(IsSame(jsEngine, value, value2)); | 112 ASSERT_TRUE(IsSame(*jsEngine, value, value2)); |
| 113 } | 113 } |
| 114 { | 114 { |
| 115 auto value = jsEngine->NewObject(); | 115 auto value = jsEngine->NewObject(); |
| 116 ASSERT_TRUE(value.IsObject()); | 116 ASSERT_TRUE(value.IsObject()); |
| 117 ASSERT_EQ(0u, value.GetOwnPropertyNames().size()); | 117 ASSERT_EQ(0u, value.GetOwnPropertyNames().size()); |
| 118 | 118 |
| 119 AdblockPlus::JsValue value2(value); | 119 AdblockPlus::JsValue value2(value); |
| 120 ASSERT_TRUE(value2.IsObject()); | 120 ASSERT_TRUE(value2.IsObject()); |
| 121 ASSERT_EQ(0u, value2.GetOwnPropertyNames().size()); | 121 ASSERT_EQ(0u, value2.GetOwnPropertyNames().size()); |
| 122 | 122 |
| 123 ASSERT_TRUE(IsSame(jsEngine, value, value2)); | 123 ASSERT_TRUE(IsSame(*jsEngine, value, value2)); |
| 124 } | 124 } |
| 125 } | 125 } |
| 126 | 126 |
| 127 TEST_F(JsEngineTest, EventCallbacks) | 127 TEST_F(JsEngineTest, EventCallbacks) |
| 128 { | 128 { |
| 129 bool callbackCalled = false; | 129 bool callbackCalled = false; |
| 130 AdblockPlus::JsValueList callbackParams; | 130 AdblockPlus::JsValueList callbackParams; |
| 131 auto Callback = [&callbackCalled, & callbackParams]( | 131 auto Callback = [&callbackCalled, & callbackParams]( |
| 132 const AdblockPlus::JsValueList& params) | 132 const AdblockPlus::JsValueList& params) |
| 133 { | 133 { |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 187 | 187 |
| 188 TEST(NewJsEngineTest, GlobalPropertyTest) | 188 TEST(NewJsEngineTest, GlobalPropertyTest) |
| 189 { | 189 { |
| 190 AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); | 190 AdblockPlus::JsEnginePtr jsEngine(AdblockPlus::JsEngine::New()); |
| 191 jsEngine->SetGlobalProperty("foo", jsEngine->NewValue("bar")); | 191 jsEngine->SetGlobalProperty("foo", jsEngine->NewValue("bar")); |
| 192 AdblockPlus::JsValuePtr foo = jsEngine->Evaluate("foo"); | 192 AdblockPlus::JsValuePtr foo = jsEngine->Evaluate("foo"); |
| 193 ASSERT_TRUE(foo->IsString()); | 193 ASSERT_TRUE(foo->IsString()); |
| 194 ASSERT_EQ(foo->AsString(), "bar"); | 194 ASSERT_EQ(foo->AsString(), "bar"); |
| 195 } | 195 } |
| 196 | 196 |
| LEFT | RIGHT |