| Index: test/cctest/test-api.cc
|
| diff --git a/test/cctest/test-api.cc b/test/cctest/test-api.cc
|
| index 9769fb79ab5a04410343a424cbfc64095054c639..bc9a0e2ca2fa56d00025e6a68a4af27f754ee2ff 100644
|
| --- a/test/cctest/test-api.cc
|
| +++ b/test/cctest/test-api.cc
|
| @@ -2132,10 +2132,15 @@ THREADED_TEST(GetSetProperty) {
|
| THREADED_TEST(PropertyAttributes) {
|
| v8::HandleScope scope;
|
| LocalContext context;
|
| + // none
|
| + Local<String> prop = v8_str("none");
|
| + context->Global()->Set(prop, v8_num(7));
|
| + CHECK_EQ(v8::None, context->Global()->GetPropertyAttributes(prop));
|
| // read-only
|
| - Local<String> prop = v8_str("read_only");
|
| + prop = v8_str("read_only");
|
| context->Global()->Set(prop, v8_num(7), v8::ReadOnly);
|
| CHECK_EQ(7, context->Global()->Get(prop)->Int32Value());
|
| + CHECK_EQ(v8::ReadOnly, context->Global()->GetPropertyAttributes(prop));
|
| Script::Compile(v8_str("read_only = 9"))->Run();
|
| CHECK_EQ(7, context->Global()->Get(prop)->Int32Value());
|
| context->Global()->Set(prop, v8_num(10));
|
| @@ -2146,6 +2151,25 @@ THREADED_TEST(PropertyAttributes) {
|
| CHECK_EQ(13, context->Global()->Get(prop)->Int32Value());
|
| Script::Compile(v8_str("delete dont_delete"))->Run();
|
| CHECK_EQ(13, context->Global()->Get(prop)->Int32Value());
|
| + CHECK_EQ(v8::DontDelete, context->Global()->GetPropertyAttributes(prop));
|
| + // dont-enum
|
| + prop = v8_str("dont_enum");
|
| + context->Global()->Set(prop, v8_num(28), v8::DontEnum);
|
| + CHECK_EQ(v8::DontEnum, context->Global()->GetPropertyAttributes(prop));
|
| + // absent
|
| + prop = v8_str("absent");
|
| + CHECK_EQ(v8::None, context->Global()->GetPropertyAttributes(prop));
|
| + Local<Value> fake_prop = v8_num(1);
|
| + CHECK_EQ(v8::None, context->Global()->GetPropertyAttributes(fake_prop));
|
| + // exception
|
| + TryCatch try_catch;
|
| + Local<Value> exception =
|
| + CompileRun("({ toString: function() { throw 'exception';} })");
|
| + CHECK_EQ(v8::None, context->Global()->GetPropertyAttributes(exception));
|
| + CHECK(try_catch.HasCaught());
|
| + String::AsciiValue exception_value(try_catch.Exception());
|
| + CHECK_EQ("exception", *exception_value);
|
| + try_catch.Reset();
|
| }
|
|
|
|
|
|
|