Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

check-types

philbooth14.1mMIT11.2.3

A little library for asserting types and values, with zero dependencies.

type, types, type-check, type-checking, duck-typing, arguments, parameters, values, data, contract, assert, check, verify, safe, safety

readme

check-types.js

Build status Package status Downloads License

A little JavaScript library for asserting types and values, with zero dependencies.

Why would I want that?

Writing explicit conditions in your functions to check arguments and throw errors is a task that swiftly becomes tiresome and adds complexity to your codebase.

The purpose of check-types.js is to remove this burden from JavaScript application developers in an efficient and robust manner, abstracted by a simple API.

How little is it?

25 kb unminified with comments, 7.4 kb minified, 2.5 kb minified + gzipped.

How do I install it?

Via npm:

npm i check-types --save

Or if you just want the git repo:

git clone git@gitlab.com:philbooth/check-types.js.git

How do I use it?

Loading the library

If you are running in Node.js or a CommonJS environment, you can require check-types like so:

const check = require('check-types');

It also the supports the AMD-style format preferred by Require.js.

If you are including check-types.js with an HTML <script> tag, or neither of the above environments are detected, it will export the interface globally as check.

Calling the exported functions

Once you've loaded the library in your application, a whole bunch of functions are available to call.

Most of the functions are predicates, which can be executed in a number of different contexts:

  • check.xxx(thing): These functions are basic predicates, returning true or false depending on the type and value of thing.

  • check.not.xxx(thing): The not modifier negates predicates, returning true if the predicate returns false and false if the predicate returns true. It is also itself a function, which simply returns the negation of its argument.

  • check.maybe.xxx(thing): The maybe modifier tweaks predicates to return true if thing is null or undefined, otherwise their normal result is returned. It is also itself a function, which returns true when its argument is null or undefined, otherwise it returns its argument.

  • check.assert.xxx(thing, message): The assert modifier changes predicates to throw when their result is false, otherwise it returns thing. It can be applied to the not and maybe modifiers using the forms check.assert.not.xxx(thing, message) and check.assert.maybe.xxx(thing, message). It is also itself a function, which simply throws when its argument is false.

  • check.array.of.xxx(thing): The array.of modifier first checks that it is operating on an array and then applies the modified predicate to each item of the array. If the predicate fails for any item, it returns false, otherwise it returns true. It can also be prefixed by other modifiers, so check.maybe.array.of, check.not.array.of, check.assert.array.of, check.assert.maybe.array.of and check.assert.not.array.of all work as you would expect them to.

  • check.arrayLike.of.xxx(thing): The arrayLike.of modifier is synonymous with array.of, except it operates on array-like objects.

  • check.iterable.of.xxx(thing): The iterable.of modifier is synonymous with array.of, except it operates on iterables.

  • check.object.of.xxx(thing): The object.of modifier is synonymous with array.of, except it operates on an object's properties.

Additionally, there are some batch operations to help you apply predicates to each value of an array or object. These are implemented by check.map, check.any and check.all.

General predicates

  • check.equal(thing, thang): Returns true if thing === thang, false otherwise.

  • check.null(thing): Returns true if thing is null, false otherwise.

  • check.undefined(thing): Returns true if thing is undefined, false otherwise.

  • check.assigned(thing): Returns true if thing is not null or undefined, false otherwise.

  • check.primitive(thing): Returns true if thing is a primitive type, false otherwise. Primitive types are null, undefined, booleans, numbers, strings and symbols.

  • check.hasLength(thing, value): Returns true if thing has a length property that equals value, false otherwise.

String predicates

  • check.string(thing): Returns true if thing is a string, false otherwise.

  • check.emptyString(thing, options): Returns true if thing is the empty string, false otherwise.

  • check.nonEmptyString(thing, options): Returns true if thing is a non-empty string, false otherwise.

  • check.contains(string, substring): Returns true if string contains substring, false otherwise.

  • check.in(substring, string): Returns true if substring is in string, false otherwise.

  • check.match(string, regex): Returns true if string matches regex, false otherwise.

Number predicates

  • check.number(thing): Returns true if thing is a number, false otherwise. Note that NaN, Number.POSITIVE_INFINITY and Number.NEGATIVE_INFINITY are not considered numbers here.

  • check.integer(thing): Returns true if thing is an integer, false otherwise.

  • check.float(thing): Returns true if thing is a non-integer number, false otherwise.

  • check.zero(thing): Returns true if thing is zero, false otherwise.

  • check.one(thing): Returns true if thing is one, false otherwise.

  • check.infinity(thing): Returns true if thing is positive or negative infinity, false otherwise.

  • check.greater(thing, value): Returns true if thing is a number greater than value, false otherwise.

  • check.greaterOrEqual(thing, value): Returns true if thing is a number greater than or equal to value, false otherwise.

  • check.less(thing, value): Returns true if thing is a number less than value, false otherwise.

  • check.lessOrEqual(thing, value): Returns true if thing is a number less than or equal to value, false otherwise.

  • check.between(thing, a, b): Returns true if thing is a number between a and b (excluding a and b), false otherwise. The arguments a and b may be in any order, it doesn't matter which is greater.

  • check.inRange(thing, a, b): Returns true if thing is a number in the range a .. b (including a and b), false otherwise. The arguments a and b may be in any order, it doesn't matter which is greater.

  • check.positive(thing): Returns true if thing is a number greater than zero, false otherwise.

  • check.negative(thing): Returns true if thing is a number less than zero, false otherwise.

  • check.odd(thing): Returns true if thing is an odd number, false otherwise.

  • check.even(thing): Returns true if thing is an even number, false otherwise.

Boolean predicates

  • check.boolean(thing): Returns true if thing is a boolean, false otherwise.

Object predicates

  • check.object(thing): Returns true if thing is a plain-old JavaScript object, false otherwise.

  • check.emptyObject(thing): Returns true if thing is an empty object, false otherwise.

  • check.nonEmptyObject(thing): Returns true if thing is a non-empty object, false otherwise.

  • check.thenable(thing): Returns true if thing has a then method, false otherwise.

  • check.instanceStrict(thing, prototype): Returns true if thing is an instance of prototype, false otherwise.

  • check.instance(thing, prototype): Returns true if thing is an instance of prototype, false otherwise. Falls back to testing constructor.name and Object.prototype.toString if the instanceof test fails.

  • check.contains(object, value): Returns true if object contains value, false otherwise.

  • check.in(value, object): Returns true if value is in object, false otherwise.

  • check.containsKey(object, key): Returns true if object contains key key, false otherwise.

  • check.keyIn(key, object): Returns true if key key is in object, false otherwise.

  • check.like(thing, duck): Duck-typing checker. Returns true if thing has all of the properties of duck, false otherwise.

  • check.identical(thing, thang): Deep equality checker. Returns true if thing has all of the same values as thang, false otherwise.

Array predicates

  • check.array(thing): Returns true if thing is an array, false otherwise.

  • check.emptyArray(thing): Returns true if thing is an empty array, false otherwise.

  • check.nonEmptyArray(thing): Returns true if thing is a non-empty array, false otherwise.

  • check.arrayLike(thing): Returns true if thing has a numeric length property, false otherwise.

  • check.iterable(thing): Returns true if thing implements the iterable protocol, false otherwise. In pre-ES6 environments, this predicate falls back to arrayLike behaviour.

  • check.contains(array, value): Returns true if array contains value, false otherwise.

  • check.in(value, array): Returns true if value is in array, false otherwise.

Date predicates

  • check.date(thing): Returns true if thing is a valid date, false otherwise.

Function predicates

  • check.function(thing): Returns true if thing is a function, false otherwise.

  • check.throws(() => thing()): Returns true if thing is a function that throws, false otherwise.

Modifiers

  • check.not(value): Returns the negation of value.

  • check.not.xxx(...): Returns the negation of the predicate.

  • check.maybe(value): Returns true if value is null or undefined, otherwise it returns value.

  • check.maybe.xxx(...): Returns true if thing is null or undefined, otherwise it propagates the return value from its predicate.

  • check.array.of.xxx(value): Returns true if value is an array and the predicate is true for every item. Also works with the not and maybe modifiers.

  • check.arrayLike.of.xxx(thing): The arrayLike.of modifier is synonymous with array.of, except it operates on array-like objects.

  • check.iterable.of.xxx(thing): The iterable.of modifier is synonymous with array.of, except it operates on iterables.

  • check.object.of.xxx(thing): The object.of modifier is synonymous with array.of, except it operates on an object's properties.

  • check.assert(value, message, ErrorType): Throws a TypeError if value is falsy, otherwise it returns value. message and ErrorType are optional arguments that control the message and type of the thrown error object.

  • check.assert.xxx(...): Throws a TypeError if the predicate returns false, otherwise it returns the subject value. The last two arguments are an optional message and error type that control the message and type of the thrown error object. Also works with the not, maybe and ...of modifiers.

Batch operations

  • check.map(things, predicates): Maps each value from the things array or object to the corresponding predicate and returns the array or object of results. Passing a single predicate instead of an array or object maps all of the values to the same predicate.

  • check.all(results): Returns true if all the result values are true in an array or object returned by map.

  • check.any(results): Returns true if any result value is true in an array or object returned by map.

Some examples

check.even(3);
// Returns false
check.not.even(3);
// Returns true
check.maybe.even(null);
// Returns true
check.assert.even(3);
// Throws `new TypeError('assert failed: expected 3 to be even number')`
check.assert.not.even(3);
// Doesn't throw
check.assert.maybe.even(null);
// Doesn't throw
check.contains('foo', 'oo')
// Returns true
check.contains('foe', 'oo')
// Returns false
check.contains(['foo', 'bar'], 'bar')
// Returns true
check.contains(['foo', 'bar'], 'ar')
// Returns false
check.like({ foo: 'bar' }, { foo: 'baz' });
// Returns true
check.like({ foo: 'bar' }, { baz: 'qux' });
// Returns false
check.array.of.nonEmptyString([ 'foo', 'bar' ]);
// Returns true
check.array.of.nonEmptyString([ 'foo', 'bar', '' ]);
// Returns false
check.array.of.inRange([ 0, 1, 2 ], 0, 2);
// Returns true
check.array.of.inRange([ 0, 1, 2 ], 0, 1);
// Returns false
check.assert(myFunction(), 'Something went wrong', CustomError);
// Throws `new CustomError('Something went wrong')` if myFunction returns `false`
check.map([ 'foo', 'bar', '' ], check.nonEmptyString);
// Returns [ true, true, false ]
check.map({
    foo: 2,
    bar: { baz: 'qux' }
}, {
    foo: check.odd,
    bar: { baz: check.nonEmptyString }
});
// Returns { foo: false, bar: { baz: true } }
check.all(
    check.map(
        { foo: 0, bar: '' },
        { foo: check.number, bar: check.string }
    )
);
// Returns true
check.any(
    check.map(
        [ 1, 2, 3, '' ],
        check.string
    )
);
// Returns true

Are there TypeScript definitions?

Yes!

Thanks to @idchlife, type definitions were added to DefinitelyTyped. You can add them to your project via npm:

npm i @types/check-types --save-dev

Where can I use it?

As of version 2.0, this library no longer supports ES3. That means you can't use it in IE 7 or 8.

Everywhere else should be fine.

If those versions of IE are important to you, worry not! The 1.x versions all support old IE and any future 1.x versions will adhere to that too.

See the releases for more information.

What changed from 10.x to 11.x?

Breaking changes were made to the API in version 11.0.0.

Specifically, the options argument was removed from the emptyString and nonEmptyString predicates because it caused problematic behaviour in the assert modifier. Callers who were previously using options.trim with these predicates should call check.match instead:

check.match(stringWithSpaces, /^\s*$/);

See the history for more details.

What changed from 9.x to 10.x?

Breaking changes were made to the API in version 10.0.0.

Specifically, the includes predicate was merged into the contains predicate and errors thrown by the assert modifier were given more useful error messages including details about the failing data.

See the history for more details.

What changed from 8.x to 9.x?

Breaking changes were made to the API in version 9.0.0.

Specifically, an options argument was added to the emptyString and nonEmptyString predicates. In each case, if options.trim is truthy, strings will be trimmed before making the comparison.

See the history for more details.

What changed from 7.x to 8.x?

Breaking changes were made to the API in version 8.0.0.

Specifically, the apply batch operation was removed and map was instead changed to work with both arrays and objects, to simplify the API surface.

See the history for more details.

What changed from 6.x to 7.x?

Breaking changes were made to the API in version 7.0.0.

Specifically, the instance predicate was renamed to instanceStrict and the builtIn and userDefined predicates were combined to form a new instance predicate.

See the history for more details.

What changed from 5.x to 6.x?

Breaking changes were made to the API in version 6.0.0.

Specifically, the either modifier was removed. Instead, calling code can use the any function, or simply express the boolean logic in JS.

See the history for more details.

What changed from 4.x to 5.x?

Breaking changes were made to the API in version 5.0.0.

Specifically, the predicates isMap and error were removed in favour of the new predicate builtIn, which can be used to test for all built-in objects.

See the history for more details.

What changed from 3.x to 4.x?

Breaking changes were made to the API in version 4.0.0.

Specifically, the predicate unemptyString was renamed to nonEmptyString and the predicate error was changed to support derived Error objects.

See the history for more details.

What changed from 2.x to 3.x?

Breaking changes were made to the API in version 3.0.0.

Specifically, the predicate length was renamed to hasLength and the predicate webUrl was removed.

See the history for more details.

What changed from 1.x to 2.x?

Breaking changes were made to the API in version 2.0.0.

Specifically:

  • Support for ES3 was dropped
  • The predicates gitUrl, email and floatNumber were removed.
  • verify was renamed to assert.
  • nulled was renamed to null.
  • oddNumber was renamed to odd.
  • evenNumber was renamed to even.
  • positiveNumber was renamed to positive.
  • negativeNumber was renamed to negative.
  • intNumber was renamed to integer.
  • bool was renamed to boolean.
  • defined was swapped to become undefined.
  • webUrl was tightened to reject more cases.

See the history for more details.

What changed from 0.x to 1.x?

Breaking changes were made to the API in version 1.0.0.

Specifically, all of the predicates were renamed from check.isXxxx to check.xxx and all of the verifiers were renamed from check.verifyXxxx to check.verify.xxx.

See the history for more details.

How do I set up the build environment?

The build environment relies on Node.js, NPM, JSHint, Mocha, Chai, UglifyJS and please-release-me. Assuming that you already have Node.js and NPM set up, you just need to run npm install to install all of the dependencies as listed in package.json.

The unit tests are in test/check-types.js. You can run them with the command npm test. To run the tests in a web browser, open test/check-types.html.

What license is it released under?

MIT

changelog

History

11.2.3

Bug fixes

  • predicates: make identical work for nested objects (b6ba2728bf4e6b73a97a199739d031e827d42321)
  • tests: fix bad assertion in tests for like and identical (38eea40d2115c5dc70560cfeca35efca95a33e49)

11.2.2

Bug fixes

  • predicates: don't throw if args to identical are null (4c20caee0380ed88bf3b503bfdbae476ceaf19dd)

11.2.1

Bug fixes

  • predicates: don't throw if args to like are null (eb2721f6a681a9184e25f32b87cb50b28a24cdb6)

Other changes

  • docs: correct unminified size in readme (e2fad64c12fa129c82d693e3d29a59868a4c4f17)
  • ci: run tests in node 16 and 18 (fbd87fbab6040552c9b73d36532b4292a31d1083)

11.2.0

New features

  • predicates: implement identical (a6e0adb8e43e0cedb5f2ab98d1592605befff99b)

Other changes

  • package: drop license and history files from package (ef89d67b2495915a98b74a0645d3e6c445eebc41)
  • docs: add note about zero dependencies to readme (2f7c15c4c7e4d6bd4c16aa9610de7171586e9872)
  • tests: extra test cases for like predicate (29bc848f7806dd00e77cfbf2ecf2afdd72d0f163)
  • package: drop bower/component support (24ccb9196d5854dbd1b38b89c27042f0897ea72c)
  • package: update dev deps (bb0d193651b0f2e90108c518963949424cba95c4)

11.1.2

Bug fixes

  • errors: format true correctly in error messages (51291ef)

11.1.1

Other changes

  • build: update minified script (99f024b)
  • docs: tweak comment (6a69673)

11.1.0

New features

  • predicates: add thenable (d95829c)

Other changes

  • docs: remove some examples (8c67463)
  • docs: add missing link to readme index (3da9662)

11.0.0

Breaking changes

  • api: remove trim option from emptyString and nonEmptyString (3747900)

New features

  • predicates: implement float (b6bf1dc)
  • predicates: implement throws (018f50a)
  • predicates: implement one (3fb7424)

Bug fixes

  • lib: stop object predicates throwing when prototypes is null (b0bab07)

Other changes

  • tests: add missing test case for assert.throws (6f9c2f7)
  • docs: update author list (81ab8a9)

10.1.2

Performance improvements

  • lib: shortcut unnecessary iteration for Sets in contains (522f073)

10.1.1

Bug fixes

  • docs: fix broken description for keyIn predicate (6eb431e)

10.1.0

New features

  • api: add keyIn predicate (1ff2227)
  • api: add containsKey predicate (40c28c7)

Other changes

  • lib: fix lint errors (dcecb88)

10.0.0

Breaking changes

  • assert: return detailed error messages from assertions (c0ceacd)
  • api: merge the includes predicate into contains (2fd60c4)

New features

  • predicates: add inside as argument-flipped wrapper for contains (1c95714)

Refactorings

  • api: rename inside predicate to in (55e07a5)

9.0.1

Bug fixes

  • docs: link to changes for 9.0.0 (4108a66)

Other changes

  • package: remove package-lock.json from source control (09679a7)

9.0.0

Breaking changes

  • lib: support a trim option on emptyString and nonEmptyString (75599d2)

Other changes

  • docs: update download counter (ee81d9c)

8.0.3

Bug fixes

  • docs: remove stale link from readme (9f467b3)

Other changes

  • ci: turn off node 4/6 builds (301e09a)
  • lib: delete old commented-out code (2d11e0b)

8.0.2

Bug fixes

  • lib: ignore properties in map that have no predicate (f6bbad7)
  • docs: add missing section link to readme index (5cfec25)
  • ci: stop testing in node 0.10 (f986f1c)

Other changes

  • docs: update readme (e602bfd)
  • package: npm update (1b32cd4)

8.0.1

Bug fixes

  • docs: fix link to change log (9166ecf)

Other changes

  • docs: update copyright (ddc00b8)

8.0.0

Breaking changes

  • api: remove apply and combine functionality with map (ecc40e5)

Bug fixes

  • docs: fix links to change log (ae3811a)

Refactorings

  • lib: eliminate intermediate arrays when iterating properties (8eeda6f)
  • lib: use native Array.isArray internally (ebc9ed0)

Other changes

  • deps: update dev dependencies and rebuild (854b012)
  • project: turn on gitlab pipeline (ab4f662)

7.4.0

New features

  • docs: add note about typescript definitions to readme (13c7a90)

Bug fixes

  • docs: remove errant semicolon from example code (9053f95)
  • docs: clarify the behaviour of between and inRange (88a2f61)
  • tests: ensure tests run in non-es6 environments (4bae637)

Other changes

  • deps: update please-release-me (72377bf)
  • project: migrate to gitlab (19919b5)
  • package: update authors (9848df0)

7.3.0

  • feature: add primitive predicate (3114d7f)

7.2.1

  • fix: perf tweaks for tight loops (8a9919d)
  • chore: update ci config (136f185)

7.2.0

  • feature: return the target value from assertions (73da792)
  • chore: add release script dependency (cacc348)
  • fix: make assert throw for any falsy value (4f15c73)

7.1

  • Implement nonEmptyObject. Thanks to Victor Bakke.
  • Implement nonEmptyArray. Thanks to Victor Bakke.
  • Fix error messages on assertions that take a string as their last argument.
  • Add support for custom error types in assertions.
  • Throw TypeErrors by default.

7.0

  • Breaking changes:
    • Rename instance to instanceStrict.
    • Combine builtIn and userDefined to form new instance predicate.
  • Exclude non-src files from npm package

6.0

  • Breaking change:
    • either modifier removed.
  • Eliminated some string duplication.

5.1

  • Fix broken implementation of maybe.array.of.

5.0

  • Breaking changes:
    • isMap predicate removed (see builtIn).
    • error predicate removed (see builtIn).
  • Implement builtIn predicate.
  • Implement userDefined predicate.
  • Implement emptyString predicate.
  • Implement infinity predicate.

4.3

4.2

  • Implement includes.

4.1

  • Implement equal.

4.0

  • Breaking changes:
    • Rename unemptyString => nonEmptyString.
    • Support derived error objects in error.
  • Fix HTMLElement instance predicate bug in Safari.

3.3

  • Implement greaterOrEqual.
  • Implement lessOrEqual.
  • Implement inRange.
  • Fix default error message for function. Thanks to Paul Jolly.

3.2

  • Implement arrayLike
  • Implement iterable
  • Implement array.of
  • Implement arrayLike.of
  • Implement iterable.of
  • Implement object.of
  • Fix unhandled exception when dereferencing undefined data inside map.

3.1

  • Accept a single predicate in map.
  • Remove assertions from hasLength and like.

3.0

  • Breaking changes:
    • Rename length => hasLength.
    • Drop webUrl. (sorry @bahmutov!)
  • Turn assert, not and maybe into standalone functions as well as modifiers.
  • Implement match for general regex-matching. Possibly of interest to former users of webUrl, gitUrl and email.
  • Implement contains.
  • Implement between.
  • Implement greater.
  • Implement less.
  • Implement zero.
  • Implement emptyArray.
  • Implement error.
  • Fix errant check that property counts match in map.

2.2

  • Ensure date predicate returns false for invalid dates.

2.1

  • Add either.

2.0

  • Breaking changes:
    • Drop ES3 support.
    • Rename verify => assert.
    • Remame nulled => null.
    • Switch defined to undefined for consistency with null.
    • Tightened implementation of webUrl to reject more cases.
    • Drop gitUrl. (sorry @galniv!)
    • Drop email. (sorry @rodrigo!)
    • Drop floatNumber. (sorry @rodrigo!)
    • Rename oddNumber, evenNumber, positiveNumber, negativeNumber, intNumber => odd, even, positive, negative, integer.
    • Rename bool => boolean.
    • Rename every => all.
  • Add predicate assigned.
  • Add apply batch operation.
  • Delete superfluous unit tests.

1.4

1.3

  • Implement email, intNumber and floatNumber predicates. Thanks to Rodrigo González.
  • Infinity is not a number.
  • Implement defined and nulled. Thanks to Alejandro Villanueva.
  • Speculatively fix conflict with angular-mocks.

1.2

  • Implement not modifier.
  • Implement gitUrl predicate. Thanks to Gal Niv.

1.1

  • Replace check.maybe.verify.xxx with check.verify.maybe.xxx.

1.0

  • API overhaul:
    • Predicates exported as check.xxx rather than check.isXxx.
    • Verifiers exported as check.verify.xxx rather than check.verifyXxx. Thanks to Marc-Olivier Ricard.
  • Unit tests added for error messages.

0.8

0.7

  • Added check.maybe modifier. Thanks to Marc-Olivier Ricard.
  • Added check.map, check.every and check.any batch operations. Thanks to Marc-Olivier Ricard.
  • Harmonised the node and browser unit tests.