Replace runTestCase with assert helpers [test/language/expressions/delete]

This commit is contained in:
André Bargull 2015-08-06 18:31:06 +02:00
parent ba8a41efe9
commit 4eac0d909e
20 changed files with 46 additions and 132 deletions

View File

@ -6,15 +6,12 @@ es5id: 11.4.1-2-2
description: >
delete operator returns true when deleting returned value from a
function
includes: [runTestCase.js]
---*/
function testcase() {
var bIsFooCalled = false;
var foo = function(){bIsFooCalled = true;};
var d = delete foo();
if(d === true && bIsFooCalled === true)
return true;
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(bIsFooCalled, true, 'bIsFooCalled');

View File

@ -6,13 +6,8 @@ es5id: 11.4.1-2-3
description: >
delete operator returns true when deleting a non-reference
(boolean)
includes: [runTestCase.js]
---*/
function testcase() {
var d = delete true;
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -4,13 +4,8 @@
/*---
es5id: 11.4.1-2-4
description: delete operator returns true when deleting a non-reference (string)
includes: [runTestCase.js]
---*/
function testcase() {
var d = delete "abc";
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -4,13 +4,8 @@
/*---
es5id: 11.4.1-2-5
description: delete operator returns true when deleting a non-reference (obj)
includes: [runTestCase.js]
---*/
function testcase() {
var d = delete {a:0} ;
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -4,13 +4,8 @@
/*---
es5id: 11.4.1-2-6
description: delete operator returns true when deleting a non-reference (null)
includes: [runTestCase.js]
---*/
function testcase() {
var d = delete null;
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -7,14 +7,9 @@ description: >
delete operator returns true when deleting an unresolvable
reference
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
// just cooking up a long/veryLikely unique name
var d = delete __ES3_1_test_suite_test_11_4_1_3_unique_id_0__;
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -6,14 +6,9 @@ es5id: 11.4.1-3-3
description: >
delete operator returns true when deleting an explicitly qualified
yet unresolvable reference (property undefined for base obj)
includes: [runTestCase.js]
---*/
function testcase() {
var __ES3_1_test_suite_test_11_4_1_3_unique_id_3__ = {};
var d = delete __ES3_1_test_suite_test_11_4_1_3_unique_id_3__.x;
if (d === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');

View File

@ -5,10 +5,8 @@
es5id: 11.4.1-4-a-3-s
description: >
TypeError isn't thrown when deleting configurable data property
includes: [runTestCase.js]
---*/
function testcase() {
var obj = {};
Object.defineProperty(obj, "prop", {
value: "abc",
@ -16,6 +14,5 @@ function testcase() {
});
delete obj.prop;
return !obj.hasOwnProperty("prop");
}
runTestCase(testcase);
assert.sameValue(obj.hasOwnProperty("prop"), false, 'obj.hasOwnProperty("prop")');

View File

@ -5,10 +5,8 @@
es5id: 11.4.1-4-a-4-s
description: >
TypeError isn't thrown when deleting configurable accessor property
includes: [runTestCase.js]
---*/
function testcase() {
var obj = {};
Object.defineProperty(obj, "prop", {
get: function () {
@ -18,6 +16,5 @@ function testcase() {
});
delete obj.prop;
return !obj.hasOwnProperty("prop");
}
runTestCase(testcase);
assert.sameValue(obj.hasOwnProperty("prop"), false, 'obj.hasOwnProperty("prop")');

View File

@ -9,18 +9,14 @@ es5id: 11.4.1-4.a-1
description: >
delete operator returns true when deleting a configurable data
property
includes: [runTestCase.js]
---*/
function testcase() {
var o = {};
var desc = { value: 1, configurable: true };
Object.defineProperty(o, "foo", desc);
var d = delete o.foo;
if (d === true && o.hasOwnProperty("foo") === false) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(o.hasOwnProperty("foo"), false, 'o.hasOwnProperty("foo")');

View File

@ -8,15 +8,11 @@ info: >
es5id: 11.4.1-4.a-12
description: delete operator returns false when deleting a property(length)
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
var a = [1,2,3]
a.x = 10;
var d = delete a.length
if(d === false && a.length === 3)
return true;
}
runTestCase(testcase);
assert.sameValue(d, false, 'd');
assert.sameValue(a.length, 3, 'a.length');

View File

@ -7,15 +7,11 @@ info: >
language provides no way to directly exercise [[Delete]], the tests are placed here.
es5id: 11.4.1-4.a-14
description: delete operator returns true when deleting Array elements
includes: [runTestCase.js]
---*/
function testcase() {
var a = [1,2,3]
a.x = 10;
var d = delete a[1]
if(d === true && a[1] === undefined)
return true;
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(a[1], undefined, 'a[1]');

View File

@ -7,15 +7,11 @@ info: >
language provides no way to directly exercise [[Delete]], the tests are placed here.
es5id: 11.4.1-4.a-15
description: delete operator returns true when deleting Array expandos
includes: [runTestCase.js]
---*/
function testcase() {
var a = [1,2,3]
a.x = 10;
var d = delete a.x;
if( d === true && a.x === undefined)
return true;
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(a.x, undefined, 'a.x');

View File

@ -9,10 +9,8 @@ es5id: 11.4.1-4.a-2
description: >
delete operator returns true when deleting a configurable accessor
property
includes: [runTestCase.js]
---*/
function testcase() {
var o = {};
// define an accessor
@ -22,8 +20,6 @@ function testcase() {
Object.defineProperty(o, "foo", desc);
var d = delete o.foo;
if (d === true && o.hasOwnProperty("foo") === false) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(o.hasOwnProperty("foo"), false, 'o.hasOwnProperty("foo")');

View File

@ -10,18 +10,14 @@ description: >
delete operator returns false when deleting a non-configurable
data property
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
var o = {};
var desc = { value : 1, configurable: false }; // all other attributes default to false
Object.defineProperty(o, "foo", desc);
// Now, deleting o.foo should fail because [[Configurable]] on foo is false.
var d = delete o.foo;
if (d === false && o.hasOwnProperty("foo") === true) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, false, 'd');
assert.sameValue(o.hasOwnProperty("foo"), true, 'o.hasOwnProperty("foo")');

View File

@ -10,14 +10,9 @@ description: >
delete operator returns false when deleting a non-configurable
data property (NaN)
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
// NaN (15.1.1.1) has [[Configurable]] set to false.
var d = delete NaN;
if (d === false) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, false, 'd');

View File

@ -8,10 +8,8 @@ info: >
es5id: 11.4.1-4.a-6
description: delete operator returns true when deleting a property inside 'with'
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
var o = new Object();
o.x = 1;
var d;
@ -19,8 +17,6 @@ function testcase() {
{
d = delete x;
}
if (d === true && o.x === undefined) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, true, 'd');
assert.sameValue(o.x, undefined, 'o.x');

View File

@ -10,13 +10,8 @@ description: >
delete operator returns false when deleting a non-configurable
data property (Math.LN2)
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
var d = delete Math.LN2;
if (d === false) {
return true;
}
}
runTestCase(testcase);
assert.sameValue(d, false, 'd');

View File

@ -7,11 +7,8 @@ description: >
delete operator returns false when deleting a direct reference to
a function argument
flags: [noStrict]
includes: [runTestCase.js]
---*/
function testcase() {
function foo(a,b) {
// Now, deleting 'a' directly should fail
@ -19,6 +16,5 @@ function testcase() {
var d = delete a;
return (d === false && a === 1);
}
return foo(1,2);
}
runTestCase(testcase);
assert(foo(1,2), 'foo(1,2) !== true');

View File

@ -4,12 +4,7 @@
/*---
es5id: 11.4.1-5-a-28-s
description: Strict Mode - TypeError is not thrown when deleting RegExp.length
includes: [runTestCase.js]
---*/
function testcase() {
var a = new RegExp();
var b = delete RegExp.length;
return true;
}
runTestCase(testcase);