summaryrefslogtreecommitdiff
path: root/fxjs/cfxjs_engine_embeddertest.cpp
diff options
context:
space:
mode:
authorTom Sepez <tsepez@chromium.org>2018-02-09 19:08:59 +0000
committerChromium commit bot <commit-bot@chromium.org>2018-02-09 19:08:59 +0000
commitb7c7df6a979d16d926814f601246234bf65adbc2 (patch)
treec25ce661a438bb14ff7bca5e288a0fe6bdab28b9 /fxjs/cfxjs_engine_embeddertest.cpp
parent3f8ee5e6b4e42fc77b4716b23ccd00840e24e250 (diff)
downloadpdfium-b7c7df6a979d16d926814f601246234bf65adbc2.tar.xz
Rename fxjs_v8.{h,cpp} to cfxjs_engine.{h,cpp}
Place the template map definitions entirely in .cpp file. Change-Id: I2643f1b99f5582b69aa985857c4aa6f9b5ab57c8 Reviewed-on: https://pdfium-review.googlesource.com/26150 Commit-Queue: Tom Sepez <tsepez@chromium.org> Reviewed-by: dsinclair <dsinclair@chromium.org>
Diffstat (limited to 'fxjs/cfxjs_engine_embeddertest.cpp')
-rw-r--r--fxjs/cfxjs_engine_embeddertest.cpp99
1 files changed, 99 insertions, 0 deletions
diff --git a/fxjs/cfxjs_engine_embeddertest.cpp b/fxjs/cfxjs_engine_embeddertest.cpp
new file mode 100644
index 0000000000..f25bfbe060
--- /dev/null
+++ b/fxjs/cfxjs_engine_embeddertest.cpp
@@ -0,0 +1,99 @@
+// Copyright 2015 PDFium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "fxjs/cfxjs_engine.h"
+
+#include "testing/gtest/include/gtest/gtest.h"
+#include "testing/js_embedder_test.h"
+
+namespace {
+
+const double kExpected0 = 6.0;
+const double kExpected1 = 7.0;
+const double kExpected2 = 8.0;
+
+const wchar_t kScript0[] = L"fred = 6";
+const wchar_t kScript1[] = L"fred = 7";
+const wchar_t kScript2[] = L"fred = 8";
+
+} // namespace
+
+class CFXJSEngineEmbedderTest : public JSEmbedderTest {
+ public:
+ void ExecuteInCurrentContext(const WideString& script) {
+ FXJSErr error;
+ int sts = engine()->Execute(script, &error);
+ EXPECT_EQ(0, sts);
+ }
+ void CheckAssignmentInCurrentContext(double expected) {
+ v8::Local<v8::Object> This = engine()->GetThisObj();
+ v8::Local<v8::Value> fred = engine()->GetObjectProperty(This, L"fred");
+ EXPECT_TRUE(fred->IsNumber());
+ EXPECT_EQ(expected, engine()->ToDouble(fred));
+ }
+};
+
+TEST_F(CFXJSEngineEmbedderTest, Getters) {
+ v8::Isolate::Scope isolate_scope(isolate());
+ v8::HandleScope handle_scope(isolate());
+ v8::Context::Scope context_scope(GetV8Context());
+
+ ExecuteInCurrentContext(WideString(kScript1));
+ CheckAssignmentInCurrentContext(kExpected1);
+}
+
+TEST_F(CFXJSEngineEmbedderTest, MultipleEngines) {
+ v8::Isolate::Scope isolate_scope(isolate());
+ v8::HandleScope handle_scope(isolate());
+
+ CFXJS_Engine engine1(isolate());
+ engine1.InitializeEngine();
+
+ CFXJS_Engine engine2(isolate());
+ engine2.InitializeEngine();
+
+ v8::Local<v8::Context> context1 = engine1.GetV8Context();
+ v8::Local<v8::Context> context2 = engine2.GetV8Context();
+
+ v8::Context::Scope context_scope(GetV8Context());
+ ExecuteInCurrentContext(WideString(kScript0));
+ CheckAssignmentInCurrentContext(kExpected0);
+
+ {
+ v8::Context::Scope context_scope1(context1);
+ ExecuteInCurrentContext(WideString(kScript1));
+ CheckAssignmentInCurrentContext(kExpected1);
+ }
+ {
+ v8::Context::Scope context_scope2(context2);
+ ExecuteInCurrentContext(WideString(kScript2));
+ CheckAssignmentInCurrentContext(kExpected2);
+ }
+
+ CheckAssignmentInCurrentContext(kExpected0);
+
+ {
+ v8::Context::Scope context_scope1(context1);
+ CheckAssignmentInCurrentContext(kExpected1);
+ {
+ v8::Context::Scope context_scope2(context2);
+ CheckAssignmentInCurrentContext(kExpected2);
+ }
+ CheckAssignmentInCurrentContext(kExpected1);
+ }
+ {
+ v8::Context::Scope context_scope2(context2);
+ CheckAssignmentInCurrentContext(kExpected2);
+ {
+ v8::Context::Scope context_scope1(context1);
+ CheckAssignmentInCurrentContext(kExpected1);
+ }
+ CheckAssignmentInCurrentContext(kExpected2);
+ }
+
+ CheckAssignmentInCurrentContext(kExpected0);
+
+ engine1.ReleaseEngine();
+ engine2.ReleaseEngine();
+}