[test] Clear unhandled scheduled exceptions from ValueSerializerTest
This patch adds destructor to ValueSerializerTest test fixture class which reset unhandled scheduled exceptions thrown from the current test. In some cases unhandled scheduled exceptions from current test (eg. from one test from ValueSerializerTestWithWasm test case) produce that Context::New(isolate()) from next test's constructor returns NULL. This error is easily reproduced when unittest file (compiled for ARM or MIPS simulator) is directly executed (not by tools/run_tests.py script), so all tests are executed together. When the script is used, each test from ValueSerializerTestWithWasm test case is separately executed and unhandled exception from one test doesn't efect to another test from the same test case. BUG= Review-Url: https://codereview.chromium.org/2644083002 Cr-Commit-Position: refs/heads/master@{#42547}
This commit is contained in:
parent
7425b1f2c9
commit
73281702c8
@ -54,6 +54,17 @@ class ValueSerializerTest : public TestWithIsolate {
|
|||||||
.ToChecked();
|
.ToChecked();
|
||||||
}
|
}
|
||||||
host_object_constructor_template_ = function_template;
|
host_object_constructor_template_ = function_template;
|
||||||
|
isolate_ = reinterpret_cast<i::Isolate*>(isolate());
|
||||||
|
}
|
||||||
|
|
||||||
|
~ValueSerializerTest() {
|
||||||
|
// In some cases unhandled scheduled exceptions from current test produce
|
||||||
|
// that Context::New(isolate()) from next test's constructor returns NULL.
|
||||||
|
// In order to prevent that, we added destructor which will clear scheduled
|
||||||
|
// exceptions just for the current test from test case.
|
||||||
|
if (isolate_->has_scheduled_exception()) {
|
||||||
|
isolate_->clear_scheduled_exception();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const Local<Context>& serialization_context() {
|
const Local<Context>& serialization_context() {
|
||||||
@ -256,6 +267,7 @@ class ValueSerializerTest : public TestWithIsolate {
|
|||||||
Local<Context> serialization_context_;
|
Local<Context> serialization_context_;
|
||||||
Local<Context> deserialization_context_;
|
Local<Context> deserialization_context_;
|
||||||
Local<FunctionTemplate> host_object_constructor_template_;
|
Local<FunctionTemplate> host_object_constructor_template_;
|
||||||
|
i::Isolate* isolate_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(ValueSerializerTest);
|
DISALLOW_COPY_AND_ASSIGN(ValueSerializerTest);
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user