Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Switch to Airtap #43

Closed
wants to merge 4 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 5 additions & 3 deletions .zuul.yml → .airtap.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
ui: mocha-qunit
tunnel: ngrok
sauce_connect: true
loopback: airtap.local
browsers:
- name: chrome
version: latest
- name: firefox
version: latest
- name: safari
version: 9..latest
- name: iphone
version: latest
- name: ie
version: 9..latest
- name: microsoftedge
version: latest
version: 13..latest
47 changes: 24 additions & 23 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -1,29 +1,30 @@
language: node_js
node_js:
# we can get rid of most of these in the next major
- '0.8'
- '0.10'
- '0.11'
- '0.12'
- '1'
- '2'
- '3'
- '4'
- '5'
- '6'
- '7'
- '8'
- '9'
- '10'
- 'stable'
before_install:
- nvm install-latest-npm
matrix:
include:
- node_js: '0.8'
env: TASK=test-node
- node_js: '0.10'
env: TASK=test-node
- node_js: '0.11'
env: TASK=test-node
- node_js: '0.12'
env: TASK=test-node
- node_js: 1
env: TASK=test-node
- node_js: 2
env: TASK=test-node
- node_js: 3
env: TASK=test-node
- node_js: 4
env: TASK=test-node
- node_js: 5
env: TASK=test-node
- node_js: '0.10'
env: TASK=test-browser
script: "npm run $TASK"
script:
- npm run test-node
- if [ "${TRAVIS_PULL_REQUEST}" = "false" ] && [ "${TRAVIS_NODE_VERSION}" = "stable" ]; then npm run test-browser; fi
addons:
sauce_connect: true
hosts:
- airtap.local
env:
global:
- secure: qThuKBZQtkooAvzaYldECGNqvKGPRTnXx62IVyhSbFlsCY1VCmjhLldhyPDiZQ3JqL1XvSkK8OMDupiHqZnNE0nGijoO4M/kaEdjBB+jpjg3f8I6te2SNU935SbkfY9KHAaFXMZwdcq7Fk932AxWEu+FMSDM+080wNKpEATXDe4=
Expand Down
13 changes: 6 additions & 7 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,15 @@
"util": "0.10.3"
},
"devDependencies": {
"mocha": "~1.21.4",
"zuul": "~3.10.0",
"zuul-ngrok": "^4.0.0"
"airtap": "^2.0.2",
"tape": "^4.10.1"
},
"license": "MIT",
"scripts": {
"test-node": "mocha --ui qunit test.js",
"test-browser": "zuul -- test.js",
"test-node": "node test.js",
"test-browser": "airtap -- test.js",
"test": "npm run test-node && npm run test-browser",
"test-native": "TEST_NATIVE=true mocha --ui qunit test.js",
"browser-local": "zuul --no-coverage --local 8000 -- test.js"
"test-native": "TEST_NATIVE=true node test.js",
"browser-local": "airtap --no-coverage --local 8000 -- test.js"
}
}
76 changes: 52 additions & 24 deletions test.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,16 @@

var nodeAssert = require('assert');
var ourAssert = require('./');
var tape = require('tape');
var keys = Object.keys;
if (process.env.TEST_NATIVE === true) {
tests(nodeAssert, 'node assert');
tape('node assert', function (t) {
tests(t, nodeAssert, 'node assert');
});
} else {
tests(ourAssert, 'our assert');
tape('our assert', function (t) {
tests(t, ourAssert, 'our assert');
});
}

function makeBlock(f) {
Expand All @@ -35,8 +40,8 @@ function makeBlock(f) {
};
}

function tests (assert, what) {
test('assert.ok', function () {
function tests (t, assert, what) {
t.test('assert.ok', function (t) {
assert.throws(makeBlock(assert, false), assert.AssertionError, 'ok(false)');

assert.doesNotThrow(makeBlock(assert, true), assert.AssertionError, 'ok(true)');
Expand All @@ -50,9 +55,10 @@ function tests (assert, what) {
assert.AssertionError, 'ok(true)');

assert.doesNotThrow(makeBlock(assert.ok, 'test'), 'ok(\'test\')');
t.end()
});

test('assert.equal', function () {
t.test('assert.equal', function (t) {
assert.throws(makeBlock(assert.equal, true, false), assert.AssertionError, 'equal');

assert.doesNotThrow(makeBlock(assert.equal, null, null), 'equal');
Expand All @@ -69,38 +75,42 @@ function tests (assert, what) {

assert.throws(makeBlock(assert.notEqual, true, true),
assert.AssertionError, 'notEqual');
t.end()
});

test('assert.strictEqual', function () {
t.test('assert.strictEqual', function (t) {
assert.throws(makeBlock(assert.strictEqual, 2, '2'),
assert.AssertionError, 'strictEqual');

assert.throws(makeBlock(assert.strictEqual, null, undefined),
assert.AssertionError, 'strictEqual');

assert.doesNotThrow(makeBlock(assert.notStrictEqual, 2, '2'), 'notStrictEqual');
t.end()
});

test('assert.deepStrictEqual', function () {
t.test('assert.deepStrictEqual', function (t) {
assert.throws(makeBlock(assert.deepStrictEqual, [2], ['2']),
assert.AssertionError, 'deepStrictEqual');

assert.throws(makeBlock(assert.deepStrictEqual, [null], [undefined]),
assert.AssertionError, 'deepStrictEqual');

assert.doesNotThrow(makeBlock(assert.notDeepStrictEqual, [2], ['2']), 'notDeepStrictEqual');
t.end()
});

test('assert.deepEqual - 7.2', function () {
t.test('assert.deepEqual - 7.2', function (t) {
assert.doesNotThrow(makeBlock(assert.deepEqual, new Date(2000, 3, 14),
new Date(2000, 3, 14)), 'deepEqual date');

assert.throws(makeBlock(assert.deepEqual, new Date(), new Date(2000, 3, 14)),
assert.AssertionError,
'deepEqual date');
t.end()
});

test('assert.deepEqual - 7.3', function () {
t.test('assert.deepEqual - 7.3', function (t) {
assert.doesNotThrow(makeBlock(assert.deepEqual, /a/, /a/));
assert.doesNotThrow(makeBlock(assert.deepEqual, /a/g, /a/g));
assert.doesNotThrow(makeBlock(assert.deepEqual, /a/i, /a/i));
Expand All @@ -115,17 +125,19 @@ function tests (assert, what) {
var re1 = /a/;
re1.lastIndex = 3;
assert.throws(makeBlock(assert.deepEqual, re1, /a/));
t.end()
});

test('assert.deepEqual - 7.4', function () {
t.test('assert.deepEqual - 7.4', function (t) {
assert.doesNotThrow(makeBlock(assert.deepEqual, 4, '4'), 'deepEqual == check');
assert.doesNotThrow(makeBlock(assert.deepEqual, true, 1), 'deepEqual == check');
assert.throws(makeBlock(assert.deepEqual, 4, '5'),
assert.AssertionError,
'deepEqual == check');
t.end()
});

test('assert.deepEqual - 7.5', function () {
t.test('assert.deepEqual - 7.5', function (t) {
// having the same number of owned properties && the same set of keys
assert.doesNotThrow(makeBlock(assert.deepEqual, {a: 4}, {a: 4}));
assert.doesNotThrow(makeBlock(assert.deepEqual, {a: 4, b: '2'}, {a: 4, b: '2'}));
Expand All @@ -144,9 +156,10 @@ function tests (assert, what) {
assert.throws(makeBlock(assert.deepEqual, keys(a1), keys(a2)),
assert.AssertionError);
assert.doesNotThrow(makeBlock(assert.deepEqual, a1, a2));
t.end()
});

test('assert.deepEqual - ES6 primitives', function () {
t.test('assert.deepEqual - ES6 primitives', function (t) {
assert.throws(makeBlock(assert.deepEqual, null, {}), assert.AssertionError);
assert.throws(makeBlock(assert.deepEqual, undefined, {}), assert.AssertionError);
assert.throws(makeBlock(assert.deepEqual, 'a', ['a']), assert.AssertionError);
Expand All @@ -156,30 +169,33 @@ function tests (assert, what) {
if (typeof Symbol === 'symbol') {
assert.throws(makeBlock(assert.deepEqual, Symbol(), {}), assert.AssertionError);
}
t.end()
});

test('assert.deepEqual - object wrappers', function () {
t.test('assert.deepEqual - object wrappers', function (t) {
assert.doesNotThrow(makeBlock(assert.deepEqual, new String('a'), ['a']));
assert.doesNotThrow(makeBlock(assert.deepEqual, new String('a'), {0: 'a'}));
assert.doesNotThrow(makeBlock(assert.deepEqual, new Number(1), {}));
assert.doesNotThrow(makeBlock(assert.deepEqual, new Boolean(true), {}));
t.end()
});

test('assert.deepEqual - Buffers', function () {
t.test('assert.deepEqual - Buffers', function (t) {
assert.doesNotThrow(makeBlock(assert.deepEqual, new Buffer([1, 2, 3]), new Buffer([1, 2, 3])));
if (typeof global.Uint8Array === 'function') {
assert.throws(makeBlock(assert.deepEqual, new Buffer([1, 2, 3]), new Uint8Array([1, 2, 3])));
}
if (typeof global.Uint16Array === 'function') {
assert.doesNotThrow(makeBlock(assert.deepEqual, new Uint16Array([1, 2, 3]), new Uint16Array([1, 2, 3])));
}
t.end()
});

function thrower(errorConstructor) {
throw new errorConstructor('test');
}

test('assert - Testing the throwing', function () {
t.test('assert - Testing the throwing', function (t) {
var aethrow = makeBlock(thrower, assert.AssertionError);
aethrow = makeBlock(thrower, assert.AssertionError);

Expand Down Expand Up @@ -224,15 +240,17 @@ function tests (assert, what) {
}
assert.equal(true, threw,
'a.doesNotThrow is not catching type matching errors');
t.end()
});

test('assert.ifError', function () {
t.test('assert.ifError', function (t) {
assert.throws(function() {assert.ifError(new Error('test error'))});
assert.doesNotThrow(function() {assert.ifError(null)});
assert.doesNotThrow(function() {assert.ifError()});
t.end()
});

test('assert - make sure that validating using constructor really works', function () {
t.test('assert - make sure that validating using constructor really works', function (t) {
var threw = false;
try {
assert.throws(
Expand All @@ -245,21 +263,24 @@ function tests (assert, what) {
threw = true;
}
assert.ok(threw, 'wrong constructor validation');
t.end()
});

test('assert - use a RegExp to validate error message', function () {
t.test('assert - use a RegExp to validate error message', function (t) {
assert.throws(makeBlock(thrower, TypeError), /test/);
t.end()
});

test('assert - se a fn to validate error object', function () {
t.test('assert - se a fn to validate error object', function (t) {
assert.throws(makeBlock(thrower, TypeError), function(err) {
if ((err instanceof TypeError) && /test/.test(err)) {
return true;
}
});
t.end()
});

test('assert - Make sure deepEqual doesn\'t loop forever on circular refs', function () {
t.test('assert - Make sure deepEqual doesn\'t loop forever on circular refs', function (t) {
var b = {};
b.b = b;

Expand All @@ -274,15 +295,17 @@ function tests (assert, what) {
gotError = true;
}
assert.ok(gotError || !equal, gotError ? 'got error': 'are equal');
t.end()
});

test('assert - Ensure reflexivity of deepEqual with `arguments` objects', function() {
t.test('assert - Ensure reflexivity of deepEqual with `arguments` objects', function(t) {
var args = (function() { return arguments; })();
assert.throws(makeBlock(assert.deepEqual, [], args), assert.AssertionError);
assert.throws(makeBlock(assert.deepEqual, args, []), assert.AssertionError);
t.end()
});

test('assert - test assertion message', function () {
t.test('assert - test assertion message', function (t) {
function testAssertionMessage(actual, expected) {
try {
assert.equal(actual, '');
Expand Down Expand Up @@ -315,9 +338,10 @@ function tests (assert, what) {
testAssertionMessage({a: undefined, b: null}, '{ a: undefined, b: null }');
testAssertionMessage({a: NaN, b: Infinity, c: -Infinity},
'{ a: NaN, b: Infinity, c: -Infinity }');
t.end()
});

test('assert - regressions from node.js testcase', function () {
t.test('assert - regressions from node.js testcase', function (t) {
var threw = false;

try {
Expand All @@ -341,9 +365,10 @@ function tests (assert, what) {
} catch (e) {
assert.equal(e.toString().split('\n')[0], 'AssertionError: oh no');
}
t.end()
});

test('assert - strict mode', function () {
t.test('assert - strict mode', function (t) {
var assertStrict = assert.strict;

assertStrict.throws(makeBlock(assertStrict.equal, 1, true), assertStrict.AssertionError);
Expand All @@ -356,5 +381,8 @@ function tests (assert, what) {
assertStrict.equal(assertStrict.notEqual, assertStrict.notStrictEqual);
assertStrict.equal(assertStrict.notDeepEqual, assertStrict.notDeepStrictEqual);
assertStrict.equal(Object.keys(assertStrict).length, Object.keys(assert).length);
t.end()
});

t.end()
}