Continue working on realms (#4356)

- Rework symbols to have the same value across realms
- Support realms for native functions
- Support test262
- Use new.target realms for constructing intrinsics

JerryScript-DCO-1.0-Signed-off-by: Zoltan Herczeg zherczeg.u-szeged@partner.samsung.com
This commit is contained in:
Zoltan Herczeg
2020-12-09 17:44:21 +01:00
committed by GitHub
parent df92c86ecf
commit cc1e8d2dee
23 changed files with 593 additions and 284 deletions
+100
View File
@@ -0,0 +1,100 @@
/* Copyright JS Foundation and other contributors, http://js.foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "ecma-globals.h"
#include "ecma-helpers.h"
#include "test-common.h"
static void
create_number_property (jerry_value_t object_value,
char *name_p,
double number)
{
jerry_value_t name_value = jerry_create_string ((const jerry_char_t *) name_p);
jerry_value_t number_value = jerry_create_number (number);
jerry_value_t result_value = jerry_set_property (object_value, name_value, number_value);
TEST_ASSERT (!jerry_value_is_error (result_value));
jerry_release_value (result_value);
jerry_release_value (number_value);
jerry_release_value (name_value);
} /* create_number_property */
static double
eval_and_get_number (char *script_p)
{
jerry_value_t result_value;
result_value = jerry_eval ((const jerry_char_t *) script_p, strlen (script_p), JERRY_PARSE_NO_OPTS);
TEST_ASSERT (jerry_value_is_number (result_value));
double result = jerry_get_number_value (result_value);
jerry_release_value (result_value);
return result;
} /* eval_and_get_number */
/**
* Unit test's main function.
*/
int
main (void)
{
TEST_INIT ();
jerry_init (JERRY_INIT_EMPTY);
if (!jerry_is_feature_enabled (JERRY_FEATURE_REALM))
{
printf ("Skipping test, Realms not enabled\n");
return 0;
}
jerry_value_t global_value = jerry_get_global_object ();
jerry_value_t realm_value = jerry_create_realm ();
create_number_property (global_value, "a", 3.5);
create_number_property (global_value, "b", 7.25);
create_number_property (realm_value, "a", -1.25);
create_number_property (realm_value, "b", -6.75);
TEST_ASSERT (eval_and_get_number ("a") == 3.5);
jerry_value_t result_value = jerry_set_realm (realm_value);
TEST_ASSERT (result_value == global_value);
TEST_ASSERT (eval_and_get_number ("a") == -1.25);
result_value = jerry_set_realm (global_value);
TEST_ASSERT (result_value == realm_value);
TEST_ASSERT (eval_and_get_number ("b") == 7.25);
result_value = jerry_set_realm (realm_value);
TEST_ASSERT (result_value == global_value);
TEST_ASSERT (eval_and_get_number ("b") == -6.75);
result_value = jerry_set_realm (global_value);
TEST_ASSERT (result_value == realm_value);
jerry_value_t object_value = jerry_create_object ();
result_value = jerry_set_realm (object_value);
TEST_ASSERT (jerry_value_is_error (result_value));
jerry_release_value (result_value);
jerry_release_value (object_value);
jerry_release_value (global_value);
jerry_release_value (realm_value);
jerry_cleanup ();
return 0;
} /* main */
+8 -8
View File
@@ -220,10 +220,10 @@ main (void)
const jerry_char_t obj_src[] = ""
"({"
" [Symbol.hasInstance]: 1,"
" [Symbol.isConcatSpreadable]: 2,"
" [Symbol.iterator]: 3,"
" [Symbol.asyncIterator]: 4,"
" [Symbol.asyncIterator]: 1,"
" [Symbol.hasInstance]: 2,"
" [Symbol.isConcatSpreadable]: 3,"
" [Symbol.iterator]: 4,"
" [Symbol.match]: 5,"
" [Symbol.replace]: 6,"
" [Symbol.search]: 7,"
@@ -236,10 +236,10 @@ main (void)
const char *symbols[] =
{
"asyncIterator",
"hasInstance",
"isConcatSpreadable",
"iterator",
"asyncIterator",
"match",
"replace",
"search",
@@ -261,7 +261,7 @@ main (void)
double expected = 1.0;
uint32_t prop_index = 0;
for (jerry_well_known_symbol_t id = JERRY_SYMBOL_HAS_INSTANCE;
for (jerry_well_known_symbol_t id = JERRY_SYMBOL_ASYNC_ITERATOR;
id <= JERRY_SYMBOL_UNSCOPABLES;
id++, expected++, prop_index++)
{
@@ -315,7 +315,7 @@ main (void)
expected = 1.0;
prop_index = 0;
for (jerry_well_known_symbol_t id = JERRY_SYMBOL_HAS_INSTANCE;
for (jerry_well_known_symbol_t id = JERRY_SYMBOL_ASYNC_ITERATOR;
id <= JERRY_SYMBOL_UNSCOPABLES;
id++, expected++, prop_index++)
{
@@ -335,7 +335,7 @@ main (void)
TEST_ASSERT (jerry_value_is_undefined (invalid_well_known_symbol));
jerry_release_value (invalid_well_known_symbol);
invalid_symbol = (jerry_well_known_symbol_t) (JERRY_SYMBOL_HAS_INSTANCE - 1);
invalid_symbol = (jerry_well_known_symbol_t) (JERRY_SYMBOL_ASYNC_ITERATOR - 1);
invalid_well_known_symbol = jerry_get_well_known_symbol (invalid_symbol);
TEST_ASSERT (jerry_value_is_undefined (invalid_well_known_symbol));
jerry_release_value (invalid_well_known_symbol);