Refactor the Object.defineProperties function

Fix assert and corner cases in Object.defineProperties function.

JerryScript-DCO-1.0-Signed-off-by: Kristof Kosztyo kkosztyo.u-szeged@partner.samsung.com
This commit is contained in:
Kristof Kosztyo
2015-06-01 14:17:19 +02:00
parent f6b875c36c
commit 6ebb32452e
2 changed files with 286 additions and 49 deletions
+170
View File
@@ -26,9 +26,179 @@ Object.defineProperties(obj, {
"Hello": {
value: "world",
writable: false
},
"inner_object": {
value : {
"a" : 1,
"b" : {
value: "foo"
}
}
}
});
assert (obj.foo === true);
assert (obj.bar === "baz");
assert (obj.Hello === "world");
assert (obj.inner_object.a === 1);
assert (obj.inner_object.b.value === "foo");
// These cases should throw TypeError
try {
Object.defineProperties(obj, undefined);
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}
try {
Object.defineProperties(obj, null);
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}
try {
Object.defineProperties(undefined, {
"foo": {
value: true,
writable: true
}
});
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}
// Check for internal assert, see issue #131.
try {
Object.defineProperties([], undefined);
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}
// If one of the properties is wrong than it shouldn't update the object.
var obj2 = {
a: 5
};
try {
Object.defineProperties(obj2, {
"foo": {
value: true,
writable: true
},
"bar": {
value: 3,
set: 3
},
"Hello": {
value: "world",
writable: false
}
});
assert (false);
} catch (e) {
assert (e instanceof TypeError);
assert (obj2.foo === undefined);
assert (obj2.set === undefined);
assert (obj2.Hello === undefined);
assert (obj2.a === 5);
}
// Define accessors
var obj = {};
Object.defineProperties(obj, {
"foo": {
value: 42,
writable: true,
},
"bar": {
get: function() { return this.foo },
set: function(v) { this.foo = v }
}
});
assert (obj.bar === 42);
obj.bar = "baz";
assert (obj.foo === "baz");
// Define get method which throws error
var obj = {};
var props = {
prop1: {
value: 1,
writable: true,
},
get bar() {
throw TypeError;
return { value : 2, writable : true };
},
prop2: {
value: 3,
writable: true,
},
prop3: {
value: 4,
writable: true,
}
};
try {
Object.defineProperties(obj, props);
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}
// Define get method which deletes a property
var obj = {};
Object.defineProperties(obj, {
"foo": {
value: 42,
writable: true,
},
"a": {
value: "b",
configurable: true
},
"bar": {
get: function() {
delete this.a;
return this.foo;
},
}
});
assert (obj.a === "b");
assert (obj.bar === 42);
assert (obj.a === undefined);
// This code should throw TypeError
var obj = {};
var props = {
prop1: {
value: 1,
writable: true,
},
get bar() {
delete props.prop1;
delete props.prop2;
return { value : 2, writable : true };
},
prop2: {
value: 3,
writable: true,
},
prop3: {
value: 4,
writable: true,
}
};
try {
Object.defineProperties(obj, props);
assert (false);
} catch (e) {
assert (e instanceof TypeError);
}