mirror of https://github.com/tc39/test262.git
Merge pull request #330 from bocoup/correct-promise-test
Fix bugs in Promise tests
This commit is contained in:
commit
134c484abb
|
@ -11,20 +11,17 @@ description: iterator.next throws, causing Promise.all to reject
|
|||
---*/
|
||||
|
||||
var iterThrows = {};
|
||||
Object.defineProperty(iterThrows, Symbol.iterator, {
|
||||
get: function () {
|
||||
var error = new Test262Error();
|
||||
iterThrows[Symbol.iterator] = function() {
|
||||
return {
|
||||
next: function () {
|
||||
throw new Error("abrupt completion");
|
||||
throw error;
|
||||
}
|
||||
};
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
Promise.all(iterThrows).then(function () {
|
||||
$ERROR('Promise unexpectedly resolved: Promise.all(iterThrows) should throw TypeError');
|
||||
},function (err) {
|
||||
if (!(err instanceof TypeError)) {
|
||||
$ERROR('Expected TypeError, got ' + err);
|
||||
}
|
||||
},function (reason) {
|
||||
assert.sameValue(reason, error);
|
||||
}).then($DONE,$DONE);
|
||||
|
|
|
@ -14,21 +14,14 @@ var p = Promise.resolve("foo");
|
|||
|
||||
Object.defineProperty(p, "constructor", {
|
||||
get: function () {
|
||||
throw new Error("abrupt completion");
|
||||
throw new Test262Error();
|
||||
}
|
||||
});
|
||||
|
||||
try {
|
||||
assert.throws(Test262Error, function() {
|
||||
p.then(function() {
|
||||
$ERROR("Should never be called.");
|
||||
}, function() {
|
||||
$ERROR("Should never be called.");
|
||||
});
|
||||
} catch (e) {
|
||||
if (!(e instanceof Error)) {
|
||||
$ERROR("Expected Error, got " + e);
|
||||
}
|
||||
if (e.message !== "abrupt completion") {
|
||||
$ERROR("Expected the Error we threw, got " + e);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
|
|
@ -8,21 +8,18 @@ description: Promise.race rejects if IteratorStep throws
|
|||
---*/
|
||||
|
||||
var iterThrows = {};
|
||||
Object.defineProperty(iterThrows, Symbol.iterator, {
|
||||
get: function () {
|
||||
var error = new Test262Error();
|
||||
iterThrows[Symbol.iterator] = function () {
|
||||
return {
|
||||
next: function () {
|
||||
throw new Error("abrupt completion");
|
||||
throw error;
|
||||
}
|
||||
};
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
Promise.race(iterThrows).then(function () {
|
||||
$ERROR('Promise unexpectedly fulfilled: Promise.race(iterThrows) should throw TypeError');
|
||||
},function (err) {
|
||||
if (!(err instanceof TypeError)) {
|
||||
$ERROR('Expected TypeError, got ' + err);
|
||||
}
|
||||
}, function (reason) {
|
||||
assert.sameValue(reason, error);
|
||||
}).then($DONE,$DONE);
|
||||
|
||||
|
|
Loading…
Reference in New Issue