Use assert-lib: intl402/String

This commit is contained in:
André Bargull 2017-05-04 21:15:31 +02:00
parent 8bed4d442d
commit 3841b0a09e
5 changed files with 14 additions and 60 deletions

View File

@ -12,15 +12,7 @@ author: Norbert Lindenberg
var invalidValues = [undefined, null]; var invalidValues = [undefined, null];
invalidValues.forEach(function (value) { invalidValues.forEach(function (value) {
var error; assert.throws(TypeError, function() {
try {
var result = String.prototype.localeCompare.call(value, ""); var result = String.prototype.localeCompare.call(value, "");
} catch (e) { }, "String.prototype.localeCompare did not reject this = " + value + ".");
error = e;
}
if (error === undefined) {
$ERROR("String.prototype.localeCompare did not reject this = " + value + ".");
} else if (error.name !== "TypeError") {
$ERROR("String.prototype.localeCompare rejected this = " + value + " with wrong error " + error.name + ".");
}
}); });

View File

@ -15,12 +15,6 @@ for (i = 0; i < thisValues.length; i++) {
var j; var j;
for (j = 0; j < thatValues.length; j++) { for (j = 0; j < thatValues.length; j++) {
var result = String.prototype.localeCompare.call(thisValues[i], thatValues[j]); var result = String.prototype.localeCompare.call(thisValues[i], thatValues[j]);
if ((result === 0) !== (i === j)) { assert.sameValue((result === 0), (i === j), "localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as " + (result === 0 ? "equal" : "different") + ".");
if (result === 0) {
$ERROR("localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as equal.");
} else {
$ERROR("localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as different.");
}
}
} }
} }

View File

@ -15,12 +15,6 @@ for (i = 0; i < thisValues.length; i++) {
var j; var j;
for (j = 0; j < thatValues.length; j++) { for (j = 0; j < thatValues.length; j++) {
var result = String.prototype.localeCompare.call(thisValues[i], thatValues[j]); var result = String.prototype.localeCompare.call(thisValues[i], thatValues[j]);
if ((result === 0) !== (i === j)) { assert.sameValue((result === 0), (i === j), "localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as " + (result === 0 ? "equal" : "different") + ".");
if (result === 0) {
$ERROR("localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as equal.");
} else {
$ERROR("localeCompare treats " + thisValues[i] + " and " + thatValues[j] + " as different.");
}
}
} }
} }

View File

@ -14,10 +14,6 @@ var thisValues = ["a", "t", "u", "undefined", "UNDEFINED", "nicht definiert", "x
var i; var i;
for (i = 0; i < thisValues.length; i++) { for (i = 0; i < thisValues.length; i++) {
var thisValue = thisValues[i]; var thisValue = thisValues[i];
if (thisValue.localeCompare() !== thisValue.localeCompare(undefined)) { assert.sameValue(thisValue.localeCompare(), thisValue.localeCompare(undefined), "String.prototype.localeCompare does not treat missing 'that' argument as undefined.");
$ERROR("String.prototype.localeCompare does not treat missing 'that' argument as undefined."); assert.sameValue(thisValue.localeCompare(undefined), thisValue.localeCompare("undefined"), "String.prototype.localeCompare does not treat undefined 'that' argument as \"undefined\".");
}
if (thisValue.localeCompare(undefined) !== thisValue.localeCompare("undefined")) {
$ERROR("String.prototype.localeCompare does not treat undefined 'that' argument as \"undefined\".");
}
} }

View File

@ -23,21 +23,11 @@ locales.forEach(function (locales) {
} catch (e) { } catch (e) {
referenceError = e; referenceError = e;
} }
if (referenceError === undefined) { assert.notSameValue(referenceError, undefined, "Internal error: Expected exception was not thrown by Intl.Collator for locales " + locales + ".");
$ERROR("Internal error: Expected exception was not thrown by Intl.Collator for locales " + locales + ".");
} assert.throws(referenceError.constructor, function() {
try {
var result = "".localeCompare("", locales); var result = "".localeCompare("", locales);
} catch (e) { }, "String.prototype.localeCompare didn't throw exception for locales " + locales + ".");
error = e;
}
if (error === undefined) {
$ERROR("String.prototype.localeCompare didn't throw exception for locales " + locales + ".");
} else if (error.name !== referenceError.name) {
$ERROR("String.prototype.localeCompare threw exception " + error.name +
" for locales " + locales + "; expected " + referenceError.name + ".");
}
}); });
options.forEach(function (options) { options.forEach(function (options) {
@ -47,21 +37,9 @@ options.forEach(function (options) {
} catch (e) { } catch (e) {
referenceError = e; referenceError = e;
} }
if (referenceError === undefined) { assert.notSameValue(referenceError, undefined, "Internal error: Expected exception was not thrown by Intl.Collator for options " + JSON.stringify(options) + ".");
$ERROR("Internal error: Expected exception was not thrown by Intl.Collator for options " +
JSON.stringify(options) + "."); assert.throws(referenceError.constructor, function() {
}
try {
var result = "".localeCompare("", [], options); var result = "".localeCompare("", [], options);
} catch (e) { }, "String.prototype.localeCompare didn't throw exception for options " + JSON.stringify(options) + ".");
error = e;
}
if (error === undefined) {
$ERROR("String.prototype.localeCompare didn't throw exception for options " +
JSON.stringify(options) + ".");
} else if (error.name !== referenceError.name) {
$ERROR("String.prototype.localeCompare threw exception " + error.name +
" for options " + JSON.stringify(options) + "; expected " + referenceError.name + ".");
}
}); });