Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(72)

Side by Side Diff: test/cctest/test-api.cc

Issue 196103004: Add support for per-isolate private symbols (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: More comments; force dictionary mode Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« src/isolate.cc ('K') | « src/symbol.js ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without 2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are 3 // modification, are permitted provided that the following conditions are
4 // met: 4 // met:
5 // 5 //
6 // * Redistributions of source code must retain the above copyright 6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer. 7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above 8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following 9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided 10 // disclaimer in the documentation and/or other materials provided
(...skipping 2739 matching lines...) Expand 10 before | Expand all | Expand 10 after
2750 2750
2751 THREADED_TEST(SymbolProperties) { 2751 THREADED_TEST(SymbolProperties) {
2752 i::FLAG_harmony_symbols = true; 2752 i::FLAG_harmony_symbols = true;
2753 2753
2754 LocalContext env; 2754 LocalContext env;
2755 v8::Isolate* isolate = env->GetIsolate(); 2755 v8::Isolate* isolate = env->GetIsolate();
2756 v8::HandleScope scope(isolate); 2756 v8::HandleScope scope(isolate);
2757 2757
2758 v8::Local<v8::Object> obj = v8::Object::New(isolate); 2758 v8::Local<v8::Object> obj = v8::Object::New(isolate);
2759 v8::Local<v8::Symbol> sym1 = v8::Symbol::New(isolate); 2759 v8::Local<v8::Symbol> sym1 = v8::Symbol::New(isolate);
2760 v8::Local<v8::Symbol> sym2 = v8::Symbol::New(isolate, "my-symbol"); 2760 v8::Local<v8::Symbol> sym2 =
2761 v8::Symbol::New(isolate, v8_str("my-symbol"));
2761 2762
2762 CcTest::heap()->CollectAllGarbage(i::Heap::kNoGCFlags); 2763 CcTest::heap()->CollectAllGarbage(i::Heap::kNoGCFlags);
2763 2764
2764 // Check basic symbol functionality. 2765 // Check basic symbol functionality.
2765 CHECK(sym1->IsSymbol()); 2766 CHECK(sym1->IsSymbol());
2766 CHECK(sym2->IsSymbol()); 2767 CHECK(sym2->IsSymbol());
2767 CHECK(!obj->IsSymbol()); 2768 CHECK(!obj->IsSymbol());
2768 2769
2769 CHECK(sym1->Equals(sym1)); 2770 CHECK(sym1->Equals(sym1));
2770 CHECK(sym2->Equals(sym2)); 2771 CHECK(sym2->Equals(sym2));
2771 CHECK(!sym1->Equals(sym2)); 2772 CHECK(!sym1->Equals(sym2));
2772 CHECK(!sym2->Equals(sym1)); 2773 CHECK(!sym2->Equals(sym1));
2773 CHECK(sym1->StrictEquals(sym1)); 2774 CHECK(sym1->StrictEquals(sym1));
2774 CHECK(sym2->StrictEquals(sym2)); 2775 CHECK(sym2->StrictEquals(sym2));
2775 CHECK(!sym1->StrictEquals(sym2)); 2776 CHECK(!sym1->StrictEquals(sym2));
2776 CHECK(!sym2->StrictEquals(sym1)); 2777 CHECK(!sym2->StrictEquals(sym1));
2777 2778
2778 CHECK(sym2->Name()->Equals(v8::String::NewFromUtf8(isolate, "my-symbol"))); 2779 CHECK(sym2->Name()->Equals(v8_str("my-symbol")));
2779 2780
2780 v8::Local<v8::Value> sym_val = sym2; 2781 v8::Local<v8::Value> sym_val = sym2;
2781 CHECK(sym_val->IsSymbol()); 2782 CHECK(sym_val->IsSymbol());
2782 CHECK(sym_val->Equals(sym2)); 2783 CHECK(sym_val->Equals(sym2));
2783 CHECK(sym_val->StrictEquals(sym2)); 2784 CHECK(sym_val->StrictEquals(sym2));
2784 CHECK(v8::Symbol::Cast(*sym_val)->Equals(sym2)); 2785 CHECK(v8::Symbol::Cast(*sym_val)->Equals(sym2));
2785 2786
2786 v8::Local<v8::Value> sym_obj = v8::SymbolObject::New(isolate, sym2); 2787 v8::Local<v8::Value> sym_obj = v8::SymbolObject::New(isolate, sym2);
2787 CHECK(sym_obj->IsSymbolObject()); 2788 CHECK(sym_obj->IsSymbolObject());
2788 CHECK(!sym2->IsSymbolObject()); 2789 CHECK(!sym2->IsSymbolObject());
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after
2838 } 2839 }
2839 2840
2840 2841
2841 THREADED_TEST(PrivateProperties) { 2842 THREADED_TEST(PrivateProperties) {
2842 LocalContext env; 2843 LocalContext env;
2843 v8::Isolate* isolate = env->GetIsolate(); 2844 v8::Isolate* isolate = env->GetIsolate();
2844 v8::HandleScope scope(isolate); 2845 v8::HandleScope scope(isolate);
2845 2846
2846 v8::Local<v8::Object> obj = v8::Object::New(isolate); 2847 v8::Local<v8::Object> obj = v8::Object::New(isolate);
2847 v8::Local<v8::Private> priv1 = v8::Private::New(isolate); 2848 v8::Local<v8::Private> priv1 = v8::Private::New(isolate);
2848 v8::Local<v8::Private> priv2 = v8::Private::New(isolate, 2849 v8::Local<v8::Private> priv2 =
2849 v8_str("my-private")); 2850 v8::Private::New(isolate, v8_str("my-private"));
2850 2851
2851 CcTest::heap()->CollectAllGarbage(i::Heap::kNoGCFlags); 2852 CcTest::heap()->CollectAllGarbage(i::Heap::kNoGCFlags);
2852 2853
2853 CHECK(priv2->Name()->Equals(v8::String::NewFromUtf8(isolate, "my-private"))); 2854 CHECK(priv2->Name()->Equals(v8::String::NewFromUtf8(isolate, "my-private")));
2854 2855
2855 // Make sure delete of a non-existent private symbol property works. 2856 // Make sure delete of a non-existent private symbol property works.
2856 CHECK(obj->DeletePrivate(priv1)); 2857 CHECK(obj->DeletePrivate(priv1));
2857 CHECK(!obj->HasPrivate(priv1)); 2858 CHECK(!obj->HasPrivate(priv1));
2858 2859
2859 CHECK(obj->SetPrivate(priv1, v8::Integer::New(isolate, 1503))); 2860 CHECK(obj->SetPrivate(priv1, v8::Integer::New(isolate, 1503)));
(...skipping 30 matching lines...) Expand all
2890 2891
2891 // Private properties are inherited (for the time being). 2892 // Private properties are inherited (for the time being).
2892 v8::Local<v8::Object> child = v8::Object::New(isolate); 2893 v8::Local<v8::Object> child = v8::Object::New(isolate);
2893 child->SetPrototype(obj); 2894 child->SetPrototype(obj);
2894 CHECK(child->HasPrivate(priv1)); 2895 CHECK(child->HasPrivate(priv1));
2895 CHECK_EQ(2002, child->GetPrivate(priv1)->Int32Value()); 2896 CHECK_EQ(2002, child->GetPrivate(priv1)->Int32Value());
2896 CHECK_EQ(0, child->GetOwnPropertyNames()->Length()); 2897 CHECK_EQ(0, child->GetOwnPropertyNames()->Length());
2897 } 2898 }
2898 2899
2899 2900
2901 THREADED_TEST(GlobalSymbols) {
2902 i::FLAG_harmony_symbols = true;
2903
2904 LocalContext env;
2905 v8::Isolate* isolate = env->GetIsolate();
2906 v8::HandleScope scope(isolate);
2907
2908 v8::Local<String> name = v8_str("my-symbol");
2909 v8::Local<v8::Symbol> glob = v8::Symbol::For(isolate, name);
2910 v8::Local<v8::Symbol> glob2 = v8::Symbol::For(isolate, name);
2911 CHECK(glob2->SameValue(glob));
2912
2913 v8::Local<v8::Symbol> glob_api = v8::Symbol::ForApi(isolate, name);
2914 v8::Local<v8::Symbol> glob_api2 = v8::Symbol::ForApi(isolate, name);
2915 CHECK(glob_api2->SameValue(glob_api));
2916 CHECK(!glob_api->SameValue(glob));
2917
2918 v8::Local<v8::Symbol> sym = v8::Symbol::New(isolate, name);
2919 CHECK(!sym->SameValue(glob));
2920
2921 CompileRun("var sym2 = Symbol.for('my-symbol')");
2922 v8::Local<Value> sym2 = env->Global()->Get(v8_str("sym2"));
2923 CHECK(sym2->SameValue(glob));
2924 CHECK(!sym2->SameValue(glob_api));
2925 }
2926
2927
2928 THREADED_TEST(GlobalPrivates) {
2929 LocalContext env;
2930 v8::Isolate* isolate = env->GetIsolate();
2931 v8::HandleScope scope(isolate);
2932
2933 v8::Local<String> name = v8_str("my-private");
2934 v8::Local<v8::Private> glob = v8::Private::ForApi(isolate, name);
2935 v8::Local<v8::Object> obj = v8::Object::New(isolate);
2936 CHECK(obj->SetPrivate(glob, v8::Integer::New(isolate, 3)));
2937
2938 v8::Local<v8::Private> glob2 = v8::Private::ForApi(isolate, name);
2939 CHECK(obj->HasPrivate(glob2));
2940
2941 v8::Local<v8::Private> priv = v8::Private::New(isolate, name);
2942 CHECK(!obj->HasPrivate(priv));
2943
2944 CompileRun("var intern = %CreateGlobalPrivateSymbol('my-private')");
2945 v8::Local<Value> intern = env->Global()->Get(v8_str("intern"));
2946 CHECK(!obj->Has(intern));
2947 }
2948
2949
2900 class ScopedArrayBufferContents { 2950 class ScopedArrayBufferContents {
2901 public: 2951 public:
2902 explicit ScopedArrayBufferContents( 2952 explicit ScopedArrayBufferContents(
2903 const v8::ArrayBuffer::Contents& contents) 2953 const v8::ArrayBuffer::Contents& contents)
2904 : contents_(contents) {} 2954 : contents_(contents) {}
2905 ~ScopedArrayBufferContents() { free(contents_.Data()); } 2955 ~ScopedArrayBufferContents() { free(contents_.Data()); }
2906 void* Data() const { return contents_.Data(); } 2956 void* Data() const { return contents_.Data(); }
2907 size_t ByteLength() const { return contents_.ByteLength(); } 2957 size_t ByteLength() const { return contents_.ByteLength(); }
2908 private: 2958 private:
2909 const v8::ArrayBuffer::Contents contents_; 2959 const v8::ArrayBuffer::Contents contents_;
(...skipping 7272 matching lines...) Expand 10 before | Expand all | Expand 10 after
10182 v8::FunctionTemplate::New(context->GetIsolate()); 10232 v8::FunctionTemplate::New(context->GetIsolate());
10183 t2->SetHiddenPrototype(true); 10233 t2->SetHiddenPrototype(true);
10184 10234
10185 // Inherit from t1 and mark prototype as hidden. 10235 // Inherit from t1 and mark prototype as hidden.
10186 t2->Inherit(t1); 10236 t2->Inherit(t1);
10187 t2->InstanceTemplate()->Set(v8_str("mine"), v8_num(4)); 10237 t2->InstanceTemplate()->Set(v8_str("mine"), v8_num(4));
10188 10238
10189 Local<v8::Object> o2 = t2->GetFunction()->NewInstance(); 10239 Local<v8::Object> o2 = t2->GetFunction()->NewInstance();
10190 CHECK(o2->SetPrototype(o1)); 10240 CHECK(o2->SetPrototype(o1));
10191 10241
10192 v8::Local<v8::Symbol> sym = v8::Symbol::New(context->GetIsolate(), "s1"); 10242 v8::Local<v8::Symbol> sym =
10243 v8::Symbol::New(context->GetIsolate(), v8_str("s1"));
10193 o1->Set(sym, v8_num(3)); 10244 o1->Set(sym, v8_num(3));
10194 o1->SetHiddenValue(v8_str("h1"), 10245 o1->SetHiddenValue(
10195 v8::Integer::New(context->GetIsolate(), 2013)); 10246 v8_str("h1"), v8::Integer::New(context->GetIsolate(), 2013));
10196 10247
10197 // Call the runtime version of GetLocalPropertyNames() on 10248 // Call the runtime version of GetLocalPropertyNames() on
10198 // the natively created object through JavaScript. 10249 // the natively created object through JavaScript.
10199 context->Global()->Set(v8_str("obj"), o2); 10250 context->Global()->Set(v8_str("obj"), o2);
10200 context->Global()->Set(v8_str("sym"), sym); 10251 context->Global()->Set(v8_str("sym"), sym);
10201 // PROPERTY_ATTRIBUTES_NONE = 0 10252 // PROPERTY_ATTRIBUTES_NONE = 0
10202 CompileRun("var names = %GetLocalPropertyNames(obj, 0);"); 10253 CompileRun("var names = %GetLocalPropertyNames(obj, 0);");
10203 10254
10204 ExpectInt32("names.length", 7); 10255 ExpectInt32("names.length", 7);
10205 ExpectTrue("names.indexOf(\"foo\") >= 0"); 10256 ExpectTrue("names.indexOf(\"foo\") >= 0");
(...skipping 12130 matching lines...) Expand 10 before | Expand all | Expand 10 after
22336 "f.call(friend);"); 22387 "f.call(friend);");
22337 CHECK_EQ(2, named_access_count); 22388 CHECK_EQ(2, named_access_count);
22338 22389
22339 // Test access using Object.setPrototypeOf reflective method. 22390 // Test access using Object.setPrototypeOf reflective method.
22340 named_access_count = 0; 22391 named_access_count = 0;
22341 CompileRun("Object.setPrototypeOf(friend, {});"); 22392 CompileRun("Object.setPrototypeOf(friend, {});");
22342 CHECK_EQ(1, named_access_count); 22393 CHECK_EQ(1, named_access_count);
22343 CompileRun("Object.getPrototypeOf(friend);"); 22394 CompileRun("Object.getPrototypeOf(friend);");
22344 CHECK_EQ(2, named_access_count); 22395 CHECK_EQ(2, named_access_count);
22345 } 22396 }
OLDNEW
« src/isolate.cc ('K') | « src/symbol.js ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698