| Index: test/cctest/test-api.cc
|
| diff --git a/test/cctest/test-api.cc b/test/cctest/test-api.cc
|
| index 96717346ebf810cce554508752c9a81ef54709a4..d71011668790a0d6c9eee526c2b960f27069344c 100644
|
| --- a/test/cctest/test-api.cc
|
| +++ b/test/cctest/test-api.cc
|
| @@ -15072,18 +15072,39 @@ THREADED_TEST(DateAccess) {
|
| CHECK_EQ(1224744689038.0, date.As<v8::Date>()->ValueOf());
|
| }
|
|
|
| +void CheckIsSymbolAt(v8::Isolate* isolate, v8::Local<v8::Array> properties,
|
| + unsigned index, const char* name) {
|
| + v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
| + v8::Local<v8::Value> value =
|
| + properties->Get(context, v8::Integer::New(isolate, index))
|
| + .ToLocalChecked();
|
| + CHECK(value->IsSymbol());
|
| + v8::String::Utf8Value symbol_name(Local<Symbol>::Cast(value)->Name());
|
| + CHECK_EQ(0, strcmp(name, *symbol_name));
|
| +}
|
| +
|
| +void CheckStringArray(v8::Isolate* isolate, v8::Local<v8::Array> properties,
|
| + unsigned length, const char* names[]) {
|
| + v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
| + CHECK_EQ(length, properties->Length());
|
| + for (unsigned i = 0; i < length; i++) {
|
| + v8::Local<v8::Value> value =
|
| + properties->Get(context, v8::Integer::New(isolate, i)).ToLocalChecked();
|
| + if (names[i] == nullptr) {
|
| + DCHECK(value->IsSymbol());
|
| + } else {
|
| + v8::String::Utf8Value elm(value);
|
| + CHECK_EQ(0, strcmp(names[i], *elm));
|
| + }
|
| + }
|
| +}
|
|
|
| void CheckProperties(v8::Isolate* isolate, v8::Local<v8::Value> val,
|
| - unsigned elmc, const char* elmv[]) {
|
| + unsigned length, const char* names[]) {
|
| v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
| v8::Local<v8::Object> obj = val.As<v8::Object>();
|
| v8::Local<v8::Array> props = obj->GetPropertyNames(context).ToLocalChecked();
|
| - CHECK_EQ(elmc, props->Length());
|
| - for (unsigned i = 0; i < elmc; i++) {
|
| - v8::String::Utf8Value elm(
|
| - props->Get(context, v8::Integer::New(isolate, i)).ToLocalChecked());
|
| - CHECK_EQ(0, strcmp(elmv[i], *elm));
|
| - }
|
| + CheckStringArray(isolate, props, length, names);
|
| }
|
|
|
|
|
| @@ -15194,6 +15215,97 @@ THREADED_TEST(PropertyEnumeration2) {
|
| }
|
| }
|
|
|
| +THREADED_TEST(PropertyNames) {
|
| + LocalContext context;
|
| + v8::Isolate* isolate = context->GetIsolate();
|
| + v8::HandleScope scope(isolate);
|
| + v8::Local<v8::Value> result = CompileRun(
|
| + "var result = {0: 0, 1: 1, a: 2, b: 3};"
|
| + "result[Symbol('symbol')] = true;"
|
| + "result.__proto__ = {2: 4, 3: 5, c: 6, d: 7};"
|
| + "result;");
|
| + v8::Local<v8::Object> object = result.As<v8::Object>();
|
| + v8::PropertyFilter default_filter =
|
| + static_cast<v8::PropertyFilter>(v8::ONLY_ENUMERABLE | v8::SKIP_SYMBOLS);
|
| + v8::PropertyFilter include_symbols_filter = v8::ONLY_ENUMERABLE;
|
| +
|
| + v8::Local<v8::Array> properties =
|
| + object->GetPropertyNames(context.local()).ToLocalChecked();
|
| + const char* expected_properties1[] = {"0", "1", "a", "b", "2", "3", "c", "d"};
|
| + CheckStringArray(isolate, properties, 8, expected_properties1);
|
| +
|
| + properties =
|
| + object
|
| + ->GetPropertyNames(context.local(),
|
| + v8::KeyCollectionMode::kIncludePrototypes,
|
| + default_filter, v8::IndexFilter::kIncludeIndices)
|
| + .ToLocalChecked();
|
| + CheckStringArray(isolate, properties, 8, expected_properties1);
|
| +
|
| + properties = object
|
| + ->GetPropertyNames(context.local(),
|
| + v8::KeyCollectionMode::kIncludePrototypes,
|
| + include_symbols_filter,
|
| + v8::IndexFilter::kIncludeIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties1_1[] = {"0", "1", "a", "b", nullptr,
|
| + "2", "3", "c", "d"};
|
| + CheckStringArray(isolate, properties, 9, expected_properties1_1);
|
| + CheckIsSymbolAt(isolate, properties, 4, "symbol");
|
| +
|
| + properties =
|
| + object
|
| + ->GetPropertyNames(context.local(),
|
| + v8::KeyCollectionMode::kIncludePrototypes,
|
| + default_filter, v8::IndexFilter::kSkipIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties2[] = {"a", "b", "c", "d"};
|
| + CheckStringArray(isolate, properties, 4, expected_properties2);
|
| +
|
| + properties = object
|
| + ->GetPropertyNames(context.local(),
|
| + v8::KeyCollectionMode::kIncludePrototypes,
|
| + include_symbols_filter,
|
| + v8::IndexFilter::kSkipIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties2_1[] = {"a", "b", nullptr, "c", "d"};
|
| + CheckStringArray(isolate, properties, 5, expected_properties2_1);
|
| + CheckIsSymbolAt(isolate, properties, 2, "symbol");
|
| +
|
| + properties =
|
| + object
|
| + ->GetPropertyNames(context.local(), v8::KeyCollectionMode::kOwnOnly,
|
| + default_filter, v8::IndexFilter::kIncludeIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties3[] = {"0", "1", "a", "b"};
|
| + CheckStringArray(isolate, properties, 4, expected_properties3);
|
| +
|
| + properties = object
|
| + ->GetPropertyNames(
|
| + context.local(), v8::KeyCollectionMode::kOwnOnly,
|
| + include_symbols_filter, v8::IndexFilter::kIncludeIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties3_1[] = {"0", "1", "a", "b", nullptr};
|
| + CheckStringArray(isolate, properties, 5, expected_properties3_1);
|
| + CheckIsSymbolAt(isolate, properties, 4, "symbol");
|
| +
|
| + properties =
|
| + object
|
| + ->GetPropertyNames(context.local(), v8::KeyCollectionMode::kOwnOnly,
|
| + default_filter, v8::IndexFilter::kSkipIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties4[] = {"a", "b"};
|
| + CheckStringArray(isolate, properties, 2, expected_properties4);
|
| +
|
| + properties = object
|
| + ->GetPropertyNames(
|
| + context.local(), v8::KeyCollectionMode::kOwnOnly,
|
| + include_symbols_filter, v8::IndexFilter::kSkipIndices)
|
| + .ToLocalChecked();
|
| + const char* expected_properties4_1[] = {"a", "b", nullptr};
|
| + CheckStringArray(isolate, properties, 3, expected_properties4_1);
|
| + CheckIsSymbolAt(isolate, properties, 2, "symbol");
|
| +}
|
|
|
| THREADED_TEST(AccessChecksReenabledCorrectly) {
|
| LocalContext context;
|
|
|