codeceptjs-assert is CodeceptJS helper which wraps assert library to complete assertion tests with CodeceptJS logging. This wrapper allow us to print asserts as steps in output. Also we can expand this lib with different methods and other assertion libraries.
NPM package: https://www.npmjs.com/package/codeceptjs-assert
This helper should be added in codecept.json/codecept.conf.js
Example:
{
"helpers": {
"AssertWrapper" : {
"require": "codeceptjs-assert"
}
}
}
Tests shallow, coercive equality between the actual and expected parameters using the Abstract Equality Comparison ( == ).
https://nodejs.org/docs/latest-v8.x/api/assert.html#assert_assert_equal_actual_expected_message
I.assert('true', true);
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Tests for deep equality between the actual and expected parameters. Primitive values are compared with the Abstract Equality Comparison ( == ).
https://nodejs.org/docs/latest-v8.x/api/assert.html#assert_assert_deepequal_actual_expected_message
I.assertDeepEqual({ a: { b: 1 } }, { a: { b: 2 } });
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Generally identical to assert.deepEqual() with a few exceptions:
- Primitive values are compared using the Strict Equality Comparison ( === ). Set values and Map keys are compared using the SameValueZero comparison. (Which means they are free of the caveats).
- [[Prototype]] of objects are compared using the Strict Equality Comparison too.
- Type tags of objects should be the same.
- Object wrappers are compared both as objects and unwrapped values.
I.assertDeepStrictEqual({ a: 1 }, { a: '1' });
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Alias to assert method
https://nodejs.org/docs/latest-v8.x/api/assert.html#assert_assert_equal_actual_expected_message
I.assertEqual('true', true);
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Throws an AssertionError. The error message is set as the values of actual and expected separated by the provided operator
I.assertFail('true', true);
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to displayoperator
- (optional) default:!=
Tests if value is truthy.
https://nodejs.org/docs/latest-v8.x/api/assert.html#assert_assert_ok_value_message
I.assertOk(1 == '1', 'not equal');
Parameters
value
- any valuemessage
- (optional) error message to display
Check that actual and expected are not equal
https://nodejs.org/docs/latest-v8.x/api/assert.html#assert_assert_notequal_actual_expected_message
I.assertNotEqual('true', 'foo');
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Tests for any deep inequality.
I.assertNotDeepStrictEqual({ a: { b: 1 } }, { a: { b: 2 } });
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Tests for any deep inequality.
I.assertNotDeepEqual({ a: { b: 1 } }, { a: { b: 2 } });
Parameters
actual
- actual resultexpected
- expected resultmessage
- (optional) error message to display
Compare expected and actual status code.
I.assertStatusCode(200, 400);
Parameters
actual
- actual resultexpected
- expected result
Expect that body is not empty.
I.assertBodyIsNotEmpty({foo: 'bar'});
Parameters
actual
- actual resultmessage
- (optional) error message to display
Check that list of keys are in object.
I.assertKeyInObjectExists('foo.bar.three', {foo: 'bar', bar: 'foo'});
Parameters
keys
- list of keys split by `.obj
- tested object
Check that list of keys are not in object
I.assertKeyInObjectNotExists('foo.bar.three', {foo: 'bar', bar: 'foo'});
Parameters
keys
- list of keys split by `.obj
- tested object
Check that each element in array match predicate
I.assertEach(['foo', 3], (el) => typeof el == 'string');
Parameters
items
- tested arraypredicate
- predicate function. should return true for each elementmessage
- error message to display
Check that array has at least one element that match predicate
I.assertExists(['foo', 3], (el) => typeof el == 'string');
Parameters
items
- tested arraypredicate
- predicate function. should return true for each elementmessage
- error message to display
Check that string contains substring
I.assertStringIncludes('mystring'. 'str');
Parameters
actual
- tested stringsubstring
- expected substring