Skip to content
This repository has been archived by the owner on Nov 4, 2020. It is now read-only.

Commit

Permalink
Release 13.0.0
Browse files Browse the repository at this point in the history
  • Loading branch information
btd committed Sep 5, 2017
1 parent c8a5851 commit b9bf8ff
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 118 deletions.
7 changes: 7 additions & 0 deletions History.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,10 @@
13.0.0 / 2017-09-05
===================

* Removed `.enumerable` and `.enumerables`
* Fixed `.match`ing on `Date`s
* Added TypeScript definitions

12.0.0 / 2017-08-28
===================

Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "should",
"description": "test framework agnostic BDD-style assertions",
"version": "12.0.0",
"version": "13.0.0",
"author": "TJ Holowaychuk <[email protected]>, Denis Bardadym <[email protected]>",
"typings": "./should.d.ts",
"repository": {
Expand Down
145 changes: 28 additions & 117 deletions should.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/*!
* should - test framework agnostic BDD-style assertions
* @version v12.0.0
* @version v13.0.0
* @author TJ Holowaychuk <[email protected]>, Denis Bardadym <[email protected]>
* @link https://github.com/shouldjs/should.js
* @license MIT
Expand Down Expand Up @@ -1412,9 +1412,7 @@ Formatter.addType(new getGlobalType$1.Type(getGlobalType$1.OBJECT, getGlobalType
* MIT Licensed
*/
function isWrapperType(obj) {
return (
obj instanceof Number || obj instanceof String || obj instanceof Boolean
);
return obj instanceof Number || obj instanceof String || obj instanceof Boolean;
}

// XXX make it more strict: numbers, strings, symbols - and nothing else
Expand All @@ -1424,6 +1422,15 @@ function convertPropertyName(name) {

var functionName$1 = defaultFormat.functionName;

function isPlainObject(obj) {
if (typeof obj == "object" && obj !== null) {
var proto = Object.getPrototypeOf(obj);
return proto === Object.prototype || proto === null;
}

return false;
}

/*
* should.js - assertion library
* Copyright(c) 2010-2013 TJ Holowaychuk <[email protected]>
Expand Down Expand Up @@ -3384,12 +3391,7 @@ var containAssertions = function(should, Assertion) {
}

this.assert(nextOther.done);
} else if (
obj != null &&
other != null &&
typeof obj == "object" &&
typeof other == "object"
) {
} else if (obj != null && typeof obj == "object" && other != null && typeof other == "object") {
//TODO compare types object contains object case
forEach(other, function(value, key) {
should(obj[key]).containDeepOrdered(value);
Expand Down Expand Up @@ -3449,12 +3451,7 @@ var containAssertions = function(should, Assertion) {
},
this
);
} else if (
obj != null &&
other != null &&
typeof obj == "object" &&
typeof other == "object"
) {
} else if (obj != null && other != null && typeof obj == "object" && typeof other == "object") {
// object contains object case
forEach(other, function(value, key) {
should(obj[key]).containDeep(value);
Expand Down Expand Up @@ -3500,62 +3497,9 @@ var propertyAssertions = function(should, Assertion) {
};
var obj = this.obj;
this.have.ownProperty(name);
should(Object.getOwnPropertyDescriptor(Object(obj), name)).have.properties(
desc
);
});

function processPropsArgs() {
var args = {};
if (arguments.length > 1) {
args.names = aSlice.call(arguments);
} else {
var arg = arguments[0];
if (typeof arg === "string") {
args.names = [arg];
} else if (Array.isArray(arg)) {
args.names = arg;
} else {
args.names = Object.keys(arg);
args.values = arg;
}
}
return args;
}

Assertion.add("enumerable", function(name, val) {
name = convertPropertyName(name);

this.params = {
operator:
"to have enumerable property " +
formatProp(name) +
(arguments.length > 1 ? " equal to " + i(val) : "")
};

var desc = { enumerable: true };
if (arguments.length > 1) {
desc.value = val;
}
this.have.propertyWithDescriptor(name, desc);
should(Object.getOwnPropertyDescriptor(Object(obj), name)).have.properties(desc);
});

Assertion.add(
"enumerables",
function(/*names*/) {
var args = processPropsArgs.apply(null, arguments);

this.params = {
operator: "to have enumerables " + args.names.map(formatProp)
};

var obj = this.obj;
args.names.forEach(function(name) {
should(obj).have.enumerable(name);
});
}
);

/**
* Asserts given object has property with optionally value. **On success it change given object to be value of property**.
*
Expand Down Expand Up @@ -3628,19 +3572,14 @@ var propertyAssertions = function(should, Assertion) {
}

var operator =
(props.length === 1
? "to have property "
: "to have " + (this.anyOne ? "any of " : "") + "properties ") +
(props.length === 1 ? "to have property " : "to have " + (this.anyOne ? "any of " : "") + "properties ") +
props.join(", ");

this.params = { obj: this.obj, operator: operator };

//check that all properties presented
//or if we request one of them that at least one them presented
this.assert(
missingProperties.length === 0 ||
(this.anyOne && missingProperties.length != names.length)
);
this.assert(missingProperties.length === 0 || (this.anyOne && missingProperties.length != names.length));

// check if values in object matched expected
var valueCheckNames = Object.keys(values);
Expand All @@ -3652,35 +3591,25 @@ var propertyAssertions = function(should, Assertion) {
valueCheckNames.forEach(function(name) {
var value = values[name];
if (eq$1(obj[name], value).length !== 0) {
wrongValues.push(
formatProp(name) + " of " + i(value) + " (got " + i(obj[name]) + ")"
);
wrongValues.push(formatProp(name) + " of " + i(value) + " (got " + i(obj[name]) + ")");
} else {
props.push(formatProp(name) + " of " + i(value));
}
});

if (
(wrongValues.length !== 0 && !this.anyOne) ||
(this.anyOne && props.length === 0)
) {
if ((wrongValues.length !== 0 && !this.anyOne) || (this.anyOne && props.length === 0)) {
props = wrongValues;
}

operator =
(props.length === 1
? "to have property "
: "to have " + (this.anyOne ? "any of " : "") + "properties ") +
(props.length === 1 ? "to have property " : "to have " + (this.anyOne ? "any of " : "") + "properties ") +
props.join(", ");

this.params = { obj: this.obj, operator: operator };

//if there is no not matched values
//or there is at least one matched
this.assert(
wrongValues.length === 0 ||
(this.anyOne && wrongValues.length != valueCheckNames.length)
);
this.assert(wrongValues.length === 0 || (this.anyOne && wrongValues.length != valueCheckNames.length));
}
});

Expand Down Expand Up @@ -3779,10 +3708,7 @@ var propertyAssertions = function(should, Assertion) {
return !has(obj, key);
});

var verb =
"to have " +
(this.onlyThis ? "only " : "") +
(keys.length === 1 ? "key " : "keys ");
var verb = "to have " + (this.onlyThis ? "only " : "") + (keys.length === 1 ? "key " : "keys ");

this.params = { operator: verb + keys.join(", ") };

Expand Down Expand Up @@ -3862,11 +3788,7 @@ var propertyAssertions = function(should, Assertion) {
while (properties.length) {
currentProperty = properties.shift();
this.params = {
operator:
"to have property by path " +
allProps.join(", ") +
" - failed on " +
formatProp(currentProperty)
operator: "to have property by path " + allProps.join(", ") + " - failed on " + formatProp(currentProperty)
};
obj = obj.have.property(currentProperty);
foundProperties.push(currentProperty);
Expand Down Expand Up @@ -4090,12 +4012,10 @@ var matchingAssertions = function(should, Assertion) {
);

if (notMatchedProps.length) {
this.params.operator +=
"\n not matched properties: " + notMatchedProps.join(", ");
this.params.operator += "\n not matched properties: " + notMatchedProps.join(", ");
}
if (matchedProps.length) {
this.params.operator +=
"\n matched properties: " + matchedProps.join(", ");
this.params.operator += "\n matched properties: " + matchedProps.join(", ");
}

this.assert(notMatchedProps.length === 0);
Expand All @@ -4112,12 +4032,7 @@ var matchingAssertions = function(should, Assertion) {
if (typeof res == "boolean") {
this.assert(res); // if it is just boolean function assert on it
}
} else if (
other != null &&
this.obj != null &&
typeof other == "object" &&
typeof this.obj == "object"
) {
} else if (typeof this.obj == "object" && this.obj != null && (isPlainObject(other) || Array.isArray(other))) {
// try to match properties (for Object and Array)
notMatchedProps = [];
matchedProps = [];
Expand All @@ -4132,9 +4047,7 @@ var matchingAssertions = function(should, Assertion) {
matchedProps.push(formatProp(key));
} catch (e) {
if (e instanceof should.AssertionError) {
notMatchedProps.push(
formatProp(key) + " (" + i(this.obj[key]) + ")"
);
notMatchedProps.push(formatProp(key) + " (" + i(this.obj[key]) + ")");
} else {
throw e;
}
Expand All @@ -4144,12 +4057,10 @@ var matchingAssertions = function(should, Assertion) {
);

if (notMatchedProps.length) {
this.params.operator +=
"\n not matched properties: " + notMatchedProps.join(", ");
this.params.operator += "\n not matched properties: " + notMatchedProps.join(", ");
}
if (matchedProps.length) {
this.params.operator +=
"\n matched properties: " + matchedProps.join(", ");
this.params.operator += "\n matched properties: " + matchedProps.join(", ");
}

this.assert(notMatchedProps.length === 0);
Expand Down

0 comments on commit b9bf8ff

Please sign in to comment.