本文实例讲述了Node.js API详解之 assert模块用法。分享给大家供大家参考,具体如下:
Node.js API详解之 assert
assert 模块提供了断言测试的函数,用于测试不变式。
断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,
可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。
同样,程序投入运行后,最终用户在遇到问题时可以重新启用断言。
使用断言可以创建更稳定、品质更好且不易于出错的代码。
当需要在一个值为false时中断当前操作的话,可以使用断言。
单元测试必须使用断言(Junit/JunitX)。
使用方式:
const assert = require('assert');
assert.ok(value[, message])
说明:
测试 value 是否为真值。 相当于 assert.equal(!!value, true, message)。
如果 value 不为真值,则抛出一个带有 message 属性的 AssertionError,
其中 message 属性的值等于传入的 message 参数的值。
如果 message 参数为 undefined,则赋予默认的错误信息。
demo:
const assert = require('assert'); assert.ok(true); // 测试通过。 assert.ok(1); // 测试通过。 assert.ok(false); // 抛出 "AssertionError: false == true" assert.ok(0); // 抛出 "AssertionError: 0 == true" assert.ok(false, '不是真值'); // 抛出 "AssertionError: 不是真值"
assert(value[, message])
说明:
assert.ok() 的别名。
用法与 assert.ok() 相同。
demo:
const assert = require('assert'); assert(true); // 测试通过。 assert(1); // 测试通过。 assert(false); // 抛出 "AssertionError: false == true" assert(0); // 抛出 "AssertionError: 0 == true" assert(false, '不是真值'); // 抛出 "AssertionError: 不是真值"
assert.ifError(value)
说明:
如果 value 为真,则抛出 value。 可用于测试回调函数的 error 参数。
源码:function ifError(err) { if (err) throw err; };
demo:
const assert = require('assert'); assert.ifError(0); // 通过。 assert.ifError(1); // 抛出 1。 assert.ifError('error'); // 抛出 'error'。 assert.ifError(new Error()); // 抛出 Error。
assert.equal(actual, expected[, message])
说明:
使用相等运算符(==)测试 actual 参数与 expected 参数是否相等
demo:
const assert = require('assert'); assert.equal(1, 1); // 测试通过,1 == 1。 assert.equal(1, '1'); // 测试通过,1 == '1'。 assert.equal(1, 2); // 抛出 AssertionError: 1 == 2 assert.equal({ a: { b: 1 } }, { a: { b: 1 } }); // 抛出 AssertionError: { a: { b: 1 } } == { a: { b: 1 } }
assert.deepEqual(actual, expected[, message])
说明:
测试 actual 参数与 expected 参数是否深度相等。 原始值使用相等运算符(==)比较。
只测试可枚举的自身属性,不测试对象的原型、连接符、或不可枚举的属性(这些情况使用 assert.deepStrictEqual())。
Map 和 Set 包含的子项也会被测试。
如果两个值不相等,则抛出一个带有 message 属性的 AssertionError,
其中 message 属性的值等于传入的 message 参数的值。
如果 message 参数为 undefined,则赋予默认的错误信息。
demo:
const assert = require('assert'); const obj1 = { a: { b: 1 } }; const obj2 = { a: { b: 2 } }; const obj3 = { a: { b: 1 } }; const obj4 = Object.create(obj1); assert.deepEqual(/a/gi, new Date()); //测试通过,因为 RegExp 对象的属性不是可枚举的: assert.deepEqual(obj1, obj1); // 测试通过,对象与自身相等。 assert.deepEqual(obj1, obj2); // 抛出 AssertionError: { a: { b: 1 } } deepEqual { a: { b: 2 } } // 因为 b 属性的值不同。 assert.deepEqual(obj1, obj3); // 测试通过,两个对象相等。 assert.deepEqual(obj1, obj4); // 抛出 AssertionError: { a: { b: 1 } } deepEqual {} // 因为不测试原型。
assert.deepStrictEqual(actual, expected[, message])
说明:
与 assert.deepEqual() 大致相同,但有一些区别:
1.原始值使用全等运算符(===)比较。Set 的值与 Map 的键使用 SameValueZero 比较。
2.对象的原型也使用全等运算符比较。
3.对象的类型标签要求相同。
4.比较[对象包装器][]时,其对象和里面的值要求相同。
demo:
const assert = require('assert'); assert.deepEqual({ a: 1 }, { a: '1' }); // 测试通过,因为 1 == '1'。 assert.deepStrictEqual({ a: 1 }, { a: '1' }); // 抛出 AssertionError: { a: 1 } deepStrictEqual { a: '1' } // 因为使用全等运算符 1 !== '1'。 // 以下对象都没有自身属性。 const date = new Date(); const object = {}; const fakeDate = {}; Object.setPrototypeOf(fakeDate, Date.prototype); assert.deepEqual(object, fakeDate); // 测试通过,不测试原型。 assert.deepStrictEqual(object, fakeDate); // 抛出 AssertionError: {} deepStrictEqual Date {} // 因为原型不同。 assert.deepEqual(date, fakeDate); // 测试通过,不测试类型标签。 assert.deepStrictEqual(date, fakeDate); // 抛出 AssertionError: 2017-03-11T14:25:31.849Z deepStrictEqual Date {} // 因为类型标签不同。 assert.deepStrictEqual(new Number(1), new Number(2)); // 测试不通过,因为数值对象包装器里面的数值也会被比较。 assert.deepStrictEqual(new String('foo'), Object('foo')); // 测试通过,因为这两个对象和里面的字符串都是相同的
assert.strictEqual(actual, expected[, message])
说明:
使用全等运算符(===)测试 actual 参数与 expected 参数是否全等。
demo:
onst assert = require('assert'); assert.strictEqual(1, 2); // 抛出 AssertionError: 1 === 2 assert.strictEqual(1, 1); // 测试通过。 assert.strictEqual(1, '1'); // 抛出 AssertionError: 1 === '1'
assert.notEqual(actual, expected[, message])
说明:
使用不等运算符(!=)测试 actual 参数与 expected 参数是否不相等。
demo:
const assert = require('assert'); assert.notEqual(1, 2); // 测试通过。 assert.notEqual(1, 1); // 抛出 AssertionError: 1 != 1 assert.notEqual(1, '1'); // 抛出 AssertionError: 1 != '1'
assert.notDeepEqual(actual, expected[, message])
说明:
测试 actual 参数与 expected 参数是否不深度相等。 与 assert.deepEqual() 相反。
demo:
const assert = require('assert'); const obj1 = { a: { b: 1 } }; const obj2 = { a: { b: 2 } }; const obj3 = { a: { b: 1 } }; const obj4 = Object.create(obj1); assert.notDeepEqual(obj1, obj1); // 抛出 AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } } assert.notDeepEqual(obj1, obj2); // 测试通过,obj1 与 obj2 不深度相等。 assert.notDeepEqual(obj1, obj3); // 抛出 AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } } assert.notDeepEqual(obj1, obj4); // 测试通过,obj1 与 obj4 不深度相等。
assert.notDeepStrictEqual(actual, expected[, message])
说明:
测试 actual 参数与 expected 参数是否不深度全等。 与 assert.deepStrictEqual() 相反。
demo:
const assert = require('assert'); assert.notDeepEqual({ a: 1 }, { a: '1' }); // 抛出 AssertionError: { a: 1 } notDeepEqual { a: '1' } assert.notDeepStrictEqual({ a: 1 }, { a: '1' }); // 测试通过。
assert.notStrictEqual(actual, expected[, message])
说明:
使用不全等运算符(!==)测试 actual 参数与 expected 参数是否不全等。
demo:
const assert = require('assert'); assert.notStrictEqual(1, 2); // 测试通过。 assert.notStrictEqual(1, 1); // 抛出 AssertionError: 1 !== 1 assert.notStrictEqual(1, '1'); // 测试通过。 assert.fail(message)
assert.fail(actual, expected[, message[, operator[, stackStartFunction]]])
说明:
抛出 AssertionError。 如果 message 参数为空,则错误信息为 actual 参数 + operator 参数 + expected 参数。
如果只提供了 actual 参数与 expected 参数,则 operator 参数默认为 ‘!='。
如果提供了 message 参数,则它会作为错误信息,其他参数会保存在错误对象的属性中。
如果提供了 stackStartFunction 参数,则该函数上的栈帧都会从栈信息中移除
demo:
const assert = require('assert'); assert.fail(1, 2, undefined, '>'); // 抛出 AssertionError [ERR_ASSERTION]: 1 > 2 assert.fail(1, 2, '错误信息'); // 抛出 AssertionError [ERR_ASSERTION]: 错误信息 assert.fail(1, 2, '错误信息', '>'); // 抛出 AssertionError [ERR_ASSERTION]: 错误信息 // 上面两个例子的 `actual` 参数、`expected` 参数与 `operator` 参数不影响错误消息。 assert.fail(); // 抛出 AssertionError [ERR_ASSERTION]: Failed assert.fail('错误信息'); // 抛出 AssertionError [ERR_ASSERTION]: 错误信息 assert.fail('a', 'b'); // 抛出 AssertionError [ERR_ASSERTION]: 'a' != 'b' //使用 stackStartFunction 参数拦截异常的栈信息: function suppressFrame() { assert.fail('a', 'b', undefined, '!==', suppressFrame); } suppressFrame(); // AssertionError [ERR_ASSERTION]: 'a' !== 'b' // at repl:1:1 // at ContextifyScript.Script.runInThisContext (vm.js:44:33) // ...
assert.throws(block[, error][, message])
说明:
断言 block 函数会抛出错误。
error 参数可以是构造函数、正则表达式、或自定义函数。
如果指定了 message 参数,则当 block 函数不抛出错误时,message 参数会作为 AssertionError 的错误信息。
demo:
const assert = require('assert'); assert.throws( () => { throw new Error('错误信息'); }, /123/ ); // Error: 错误信息 assert.throws( () => { throw new Error('错误信息'); }, /错误/ ); // 通过 assert.throws( () => { throw new Error('错误信息'); }, Error ); // 通过 assert.throws( () => { throw new Error('错误信息'); }, function(err) { if ((err instanceof Error) && /错误/.test(err)) { return true; } }, '不是期望的错误' ); // 通过 // error 参数不能是字符串。 如果第二个参数是字符串,则视为省略 error 参数,传入的字符串会被用于 message 参数。 // 这是错误的!不要这么做! assert.throws(() => { throw new Error('错误信息'); }, '错误信息', '没有抛出期望的信息'); // 应该这么做。 assert.throws(() => { throw new Error('错误信息'); }, /错误信息/, '没有抛出期望的信息');
assert.doesNotThrow(block[, error][, message])
说明:
断言 block 函数不会抛出错误。
当 assert.doesNotThrow() 被调用时,它会立即调用 block 函数。
如果抛出错误且错误类型与 error 参数指定的相同,则抛出 AssertionError。
如果错误类型不相同,或 error 参数为 undefined,则抛出错误。
demo:
const assert = require('assert'); assert.doesNotThrow( () => { throw new TypeError('错误信息'); }, SyntaxError ); // TypeError: 错误信息 assert.doesNotThrow( () => { throw new TypeError('错误信息'); }, TypeError ); // AssertionError [ERR_ASSERTION]: Got unwanted exception. // 错误信息 // 如果抛出了 AssertionError 且有给 message 参数传值,则 message 参数的值会被附加到 AssertionError 的信息中: assert.doesNotThrow( () => { throw new TypeError('错误信息'); }, TypeError, '抛出错误' ); // AssertionError [ERR_ASSERTION]: Got unwanted exception: 抛出错误 // 错误信息
注意事项
说明:
对于 SameValueZero 比较,建议使用 ES2015 的 Object.is()。
demo:
const a = 0; const b = -a; assert.notStrictEqual(a, b); // 抛出 AssertionError: 0 !== -0 // 因为全等运算符不区分 -0 与 +0。 assert(!Object.is(a, b)); // 但 Object.is() 可以区分。 const str1 = 'foo'; const str2 = 'foo'; assert.strictEqual(str1 / 1, str2 / 1); // 抛出 AssertionError: NaN === NaN // 因为全等运算符不能用于测试 NaN。 assert(Object.is(str1 / 1, str2 / 1)); // 但 Object.is() 可以测试。
SameValueZero
说明:
内部比较操作SameValueZero(x,y)
如果 type of x 不同于 type of y,返回false。
如果 type of x 是数字,那么
如果 x 为 NaN, y 为 NaN,返回 true。
如果 x 是 +0 而 y 是 -0,返回 true。
如果 x 是 -0 而 y 是 +0,返回 true。
如果 x 与 y 相同,则返回 true。
返回 假。
希望本文所述对大家node.js程序设计有所帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]