Chromium Code Reviews| Index: fpdfsdk/src/jsapi/fxjs_v8_embeddertest.cpp |
| diff --git a/fpdfsdk/src/jsapi/fxjs_v8_embeddertest.cpp b/fpdfsdk/src/jsapi/fxjs_v8_embeddertest.cpp |
| index 55eb9c8408c9744248c5b0d4c1cf6d0f5e58246f..fc2324781a19d2b9bc8089e2e20249a19c006ab3 100644 |
| --- a/fpdfsdk/src/jsapi/fxjs_v8_embeddertest.cpp |
| +++ b/fpdfsdk/src/jsapi/fxjs_v8_embeddertest.cpp |
| @@ -16,40 +16,42 @@ const wchar_t kScript[] = L"fred = 7"; |
| class FXJSV8Embeddertest : public EmbedderTest { |
| public: |
| - FXJSV8Embeddertest() : m_pIsolate(nullptr) {} |
| - ~FXJSV8Embeddertest() override {} |
| + FXJSV8Embeddertest() |
| + : m_pArrayBufferAllocator(new FXJS_ArrayBufferAllocator) { |
| + v8::Isolate::CreateParams params; |
| + params.array_buffer_allocator = m_pArrayBufferAllocator.get(); |
| + m_pIsolate = v8::Isolate::New(params); |
| + } |
| + |
| + ~FXJSV8Embeddertest() override { m_pIsolate->Dispose(); } |
| void SetUp() override { |
| + EmbedderTest::SetExternalIsolate(m_pIsolate); |
| EmbedderTest::SetUp(); |
| - m_pAllocator.reset(new FXJS_ArrayBufferAllocator()); |
| - |
| - v8::Isolate::CreateParams params; |
| - params.array_buffer_allocator = m_pAllocator.get(); |
| - m_pIsolate = v8::Isolate::New(params); |
| v8::Isolate::Scope isolate_scope(m_pIsolate); |
| v8::Locker locker(m_pIsolate); |
|
Lei Zhang
2015/10/06 23:18:55
BTW, we have |locker| here but not on the main bra
|
| v8::HandleScope handle_scope(m_pIsolate); |
| - FXJS_Initialize(0); |
| FXJS_PerIsolateData::SetUp(m_pIsolate); |
| FXJS_InitializeRuntime(m_pIsolate, nullptr, nullptr, m_pPersistentContext); |
| } |
| void TearDown() override { |
| FXJS_ReleaseRuntime(m_pIsolate, m_pPersistentContext); |
| + m_pPersistentContext.Reset(); |
| FXJS_Release(); |
| EmbedderTest::TearDown(); |
| } |
| - v8::Isolate* isolate() const { return m_pIsolate; } |
| + v8::Isolate* isolate() { return m_pIsolate; } |
| v8::Local<v8::Context> GetV8Context() { |
| - return v8::Local<v8::Context>::New(m_pIsolate, m_pPersistentContext); |
| + return m_pPersistentContext.Get(m_pIsolate); |
| } |
| private: |
| + nonstd::unique_ptr<FXJS_ArrayBufferAllocator> m_pArrayBufferAllocator; |
| v8::Isolate* m_pIsolate; |
| v8::Global<v8::Context> m_pPersistentContext; |
| - nonstd::unique_ptr<FXJS_ArrayBufferAllocator> m_pAllocator; |
| }; |
| TEST_F(FXJSV8Embeddertest, Getters) { |