Tiny, but fully loaded test-runner.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Muthu Kumar c2d5bf19b7 [refactor] Up to 0.3.1 7 years ago
.vscode [refactor] Up to 0.3.1 7 years ago
assets [docs] Added basic README & utility helpers 7 years ago
src [refactor] Up to 0.3.1 7 years ago
.eslintrc.js [feature] Added support for before and after hooks 7 years ago
.gitignore [version] Updated docs and bumped version to 0.2.5 7 years ago
README.md [docs] Added examples for async tests 7 years ago
hello.txt [version] Updated docs and bumped version to 0.2.5 7 years ago
index.js [refactor] Up to 0.3.1 7 years ago
package.json [refactor] Up to 0.3.1 7 years ago
sample.test.js [refactor] Up to 0.3.1 7 years ago
shrinkwrap.yaml [refactor] Up to 0.3.1 7 years ago

README.md

Gunner

Django Unchained

Tiny, but fully loaded.

Gunner is a zero magic, fast test-runner and assertion framework. There are no magic globals or CLI specific interface.

Requirements & Usage

Gunner uses very modern JavaScript, and hence requires node 10+ currently.

Create a new Gunner instance and simply write your tests. The assertion methods are passed in as the callback to the test function.

const gunner = new Gunner();

gunner.test('arrays are equal', expect => {
	return expect([1, 2,]).deepEqual([1 ,2]);
});

gunner.run();

API

Gunner.constructor

Gunner#test(title, implementation)

Gunner#run(options)


new Gunner

Creates a new Gunner instance.

Options

  • name [default: undefined]: A name for this Gunner instance.

Usage

const gunner = new Gunner(options);

Gunner#test

Registers a new test. A test can have multiple expect statements. They should be returned as an array. The first expect to fail will cause the test to fail.

Usage

gunner.test('sum should equal 3', expect => {
	const sum = 1 + 2;
	return expect(sum).equal(3);
});

Expecting multiple results:

gunner.test('multiple expects should be true', expect => {
	const a = 1 + 2;
	const b = 'Hello World';

	return ([
		expect(a).equal(3),
		expect(b).equal('Goodbye World'),
	]);
});

Asynchronous tests:

gunner.test('asynchronous test', async expect => {

	const response = await axios.post(url, request);
	const userObject = await db.find('userdetails', { username });

	return [
		expect(response.status).equal(200);
		expect(userObject).deepEquals(testUser);
	];

})

Gunner#run

Starts running Gunner tests. Takes an options object as optional parameter.

Options

  • log [default: true]: Turn logs on or off (returns array of results)
  • trace [default: false]: Turn stack traces on or off

Usage

const options = { logs: true, trace: true };
gunner.run(options);