aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZoltan Herczeg <zherczeg.u-szeged@partner.samsung.com>2021-01-22 09:17:38 +0100
committerGitHub <noreply@github.com>2021-01-22 09:17:38 +0100
commitd646cf51eeb4e4bff4e2e308c500c2a8aebfdad8 (patch)
tree195bdfec6c9188511316e57a9f3809af0f7e349f
parentbf7fa3958129914cfbb228a9aea6d49d079d65ad (diff)
Set the correct realm when global code is running (#4522)
JerryScript-DCO-1.0-Signed-off-by: Zoltan Herczeg zherczeg.u-szeged@partner.samsung.com
-rw-r--r--jerry-core/vm/vm.c11
-rw-r--r--tests/unit-core/test-realm.c50
2 files changed, 60 insertions, 1 deletions
diff --git a/jerry-core/vm/vm.c b/jerry-core/vm/vm.c
index 9a382055..d6076f51 100644
--- a/jerry-core/vm/vm.c
+++ b/jerry-core/vm/vm.c
@@ -321,11 +321,20 @@ vm_run_global (const ecma_compiled_code_t *bytecode_p) /**< pointer to bytecode
#if ENABLED (JERRY_BUILTIN_REALMS)
ecma_value_t this_binding = ((ecma_global_object_t *) global_obj_p)->this_binding;
+
+ ecma_global_object_t *saved_global_object_p = JERRY_CONTEXT (global_object_p);
+ JERRY_CONTEXT (global_object_p) = (ecma_global_object_t *) global_obj_p;
#else /* !ENABLED (JERRY_BUILTIN_REALMS) */
ecma_value_t this_binding = ecma_make_object_value (global_obj_p);
#endif /* ENABLED (JERRY_BUILTIN_REALMS) */
- return vm_run (&shared, this_binding, global_scope_p);
+ ecma_value_t result = vm_run (&shared, this_binding, global_scope_p);
+
+#if ENABLED (JERRY_BUILTIN_REALMS)
+ JERRY_CONTEXT (global_object_p) = saved_global_object_p;
+#endif /* ENABLED (JERRY_BUILTIN_REALMS) */
+
+ return result;
} /* vm_run_global */
/**
diff --git a/tests/unit-core/test-realm.c b/tests/unit-core/test-realm.c
index e53686ea..28e46947 100644
--- a/tests/unit-core/test-realm.c
+++ b/tests/unit-core/test-realm.c
@@ -70,6 +70,27 @@ check_type_error (jerry_value_t result_value) /**< result value */
jerry_release_value (result_value);
} /* check_type_error */
+static void
+check_array_prototype (jerry_value_t realm_value, jerry_value_t result_value)
+{
+ jerry_value_t name_value = jerry_create_string ((const jerry_char_t *) "Array");
+ jerry_value_t array_value = jerry_get_property (realm_value, name_value);
+ TEST_ASSERT (jerry_value_is_object (array_value));
+ jerry_release_value (name_value);
+
+ name_value = jerry_create_string ((const jerry_char_t *) "prototype");
+ jerry_value_t prototype_value = jerry_get_property (array_value, name_value);
+ TEST_ASSERT (jerry_value_is_object (prototype_value));
+ jerry_release_value (name_value);
+ jerry_release_value (array_value);
+
+ jerry_value_t compare_value = jerry_binary_operation (JERRY_BIN_OP_STRICT_EQUAL, result_value, prototype_value);
+ jerry_release_value (prototype_value);
+
+ TEST_ASSERT (jerry_value_is_boolean (compare_value) && jerry_get_boolean_value (compare_value));
+ jerry_release_value (compare_value);
+} /* check_array_prototype */
+
/**
* Unit test's main function.
*/
@@ -209,6 +230,35 @@ main (void)
jerry_release_value (result_value);
}
+ realm_value = jerry_create_realm ();
+
+ result_value = jerry_set_realm (realm_value);
+ TEST_ASSERT (!jerry_value_is_error (result_value));
+
+ const char *script_p = "global2 = global1 - 1; Object.getPrototypeOf([])";
+ jerry_value_t script_value = jerry_parse (NULL,
+ 0,
+ (const jerry_char_t *) script_p,
+ strlen (script_p),
+ JERRY_PARSE_NO_OPTS);
+
+ TEST_ASSERT (!jerry_value_is_error (script_value));
+ jerry_set_realm (result_value);
+
+ /* Script is compiled in another realm. */
+ create_number_property (realm_value, "global1", 7.5);
+ result_value = jerry_run (script_value);
+ TEST_ASSERT (!jerry_value_is_error (result_value));
+
+ check_array_prototype (realm_value, result_value);
+
+ jerry_release_value (result_value);
+ jerry_release_value (script_value);
+
+ TEST_ASSERT (get_number_property (realm_value, "global2") == 6.5);
+
+ jerry_release_value (realm_value);
+
jerry_cleanup ();
return 0;
} /* main */