node.js官方文档解析 01—assert 断言
assert-------断言
new assert.AssertionError(options)
Error
的一个子类,表明断言的失败。
options(选项)有下列对象
message
<string> 如果有值,则错误信息会被设为该值。actual
(实际)<any> 错误实例的actual
属性会被设为该值。用于actual
错误输入,例如使用assert.strictEqual()
。expected
(期望值)<any> 错误实例的expected
属性会被设为该值。用于expected
错误输入,例如使用assert.strictEqual()
。operator(运算符)
<string> 错误实例的operator
属性会被设为该值。用于表明比较时使用的是哪个操作(或触发错误的是哪个断言函数)。stackStartFn
<Function> 如果有值,则由提供的函数生成堆栈踪迹。
assert.doesNotReject(block[, error][, message])
doesNotReject(不能拒结)
block
<Function> | <Promise>(责任)error
<RegExp> | <Function>message
<string> | <Error>
assert.doesNotThrow
.doesNotThrow(抛)
block
<Function>error
<RegExp> | <Function>message
<string> | <Error>
断言 block
函数不会抛出错误。
// SyntaxError(语法错误)
assert.equal(actual, expected[, message])
.equal(相等)
或者 assert.strictEqual()
.(和上面的意思相同,表示一个别名)
eg:使用抽象的相等比较(==)测试实际和预期参数之间的浅、强制的相等性。
const assert = require('assert'); assert.equal(1, 1);
// OK, 1 == 1
assert.equal(1, '1');
// OK, 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.fail([message])
.fail(失败)
抛出 AssertionError
,并带上提供的错误信息或默认的错误信息。 如果 message
参数是 Error
的实例,则会抛出它而不是 AssertionError
。
const assert = require('assert').strict; assert.fail();//没有提供错误信息
// 抛出 AssertionError [ERR_ASSERTION]: Failed assert.fail('失败');//字符串
// 抛出 AssertionError [ERR_ASSERTION]: 失败 assert.fail(new TypeError('失败'));
// 抛出 TypeError: 失败
assert.ifError(value)
value(值)
<any>
如果 value
不为 undefined
或 null
,则抛出 value
。可用于测试回调函数的 error
参数。 堆栈踪迹会包含传入 ifError()
的错误的所有帧,包括潜在的 ifError()
自身新增的帧。
//errorFrame(错误帧)
const assert = require('assert').strict; assert.ifError(null);//使用了value规则的undefined和null
// 通过。
assert.ifError(0);
// 抛出 AssertionError [ERR_ASSERTION]: ifError got unwanted exception: 0
assert.ifError('错误信息');
// 抛出 AssertionError [ERR_ASSERTION]: ifError got unwanted exception: '错误信息'
assert.ifError(new Error());
// 抛出 AssertionError [ERR_ASSERTION]: ifError got unwanted exception: Error // 添加一些错误帧。
let err;
(function errorFrame() {
err = new Error('错误信息');
})(); (function ifErrorFrame() {
assert.ifError(err);
})();
// AssertionError [ERR_ASSERTION]: ifError got unwanted exception: 错误信息
// at ifErrorFrame
// at errorFrame
//any类型可以赋值任意类型。
assert.notDeepStrictEqual(actual, expected[, message])
测试 actual
参数与 expected
参数是否不深度全等。 与 assert.deepStrictEqual()
相反。
assert.notStrictEqual(actual, expected[, message])
actual
参数与 expected
参数是否不全等。
const assert = require('assert').strict; assert.notStrictEqual(1, 2);
// 测试通过。 assert.notStrictEqual(1, 1);
// 抛出 AssertionError [ERR_ASSERTION]: Identical input passed to notStrictEqual: 1 assert.notStrictEqual(1, '1');
// 测试通过。
如果两个值全等,则抛出一个带有 message
属性的 AssertionError
,其中 message
属性的值等于传入的 message
参数的值。 如果 message
参数为 undefined
,则赋予默认的错误信息。 如果 message
参数是 Error
的实例,则会抛出它而不是 AssertionError
。
assert.ok(value[, message])
测试 value
是否为真值。
如果 value
不为真值,则抛出一个带有 message
属性的 AssertionError
,其中 message
属性的值等于传入的 message
参数的值。 如果 message
参数为 undefined
,则赋予默认的错误信息。 如果 message
参数是 Error
的实例,则会抛出它而不是 AssertionError
。 如果没有传入参数,则 message
会被设为字符串 'No value argument passed to `assert.ok()`'
。
eg:
const assert = require('assert').strict; assert.ok(true);
// 测试通过。
assert.ok(1);
// 测试通过。 assert.ok();//如果没有传入参数,则message
会被设为字符串'No value argument passed to `assert.ok()`'
。
// 抛出 AssertionError: No value argument passed to `assert.ok()` assert.ok(false, '不是真值');
// 抛出 AssertionError: 不是真值 // 在 repl 中:
assert.ok(typeof 123 === 'string');
// 抛出 AssertionError: false == true // 在文件中(例如 test.js):
assert.ok(typeof 123 === 'string');
// 抛出 AssertionError: The expression evaluated to a falsy value:
//
// assert.ok(typeof 123 === 'string')
assert.ok(false);
// 抛出 AssertionError: The expression evaluated to a falsy value:
//
// assert.ok(false) assert.ok(0);
// 抛出 AssertionError: The expression evaluated to a falsy value:
//
// assert.ok(0) // 等同于 `assert()`:
assert(0);
// 抛出 AssertionError: The expression evaluated to a falsy value:
//
// assert(0)
//promise:表示异步操作的最终完成(或失败)及其产生的值。
assert.rejects(block[, error][, message])//不懂
assert.strictEqual(actual, expected[, message])
测试 actual
参数与 expected
参数是否全等。
const assert = require('assert').strict; assert.strictEqual(1, 2);
// 抛出 AssertionError [ERR_ASSERTION]: Input A expected to strictly equal input B:
// + expected - actual
// - 1
// + 2 assert.strictEqual(1, 1);
// 测试通过。 assert.strictEqual(1, '1');
// 抛出 AssertionError [ERR_ASSERTION]: Input A expected to strictly equal input B:
// + expected - actual
// - 1
// + '1'
如果两个值不全等,则抛出一个带有 message
属性的 AssertionError
,其中 message
属性的值等于传入的 message
参数的值。 如果 message
参数为 undefined
,则赋予默认的错误信息。 如果 message
参数是 Error
的实例,则会抛出它而不是 AssertionError
。
//nested(嵌套)
//info(信息)
node.js官方文档解析 01—assert 断言的更多相关文章
- node.js官方文档解析 02—buffer 缓冲器
Buffer 类的实例类似于整数数组,但 Buffer 的大小是固定的.且在 V8 堆外分配物理内存.Buffer 的大小在被创建时确定,且无法调整. Buffer 类在 Node.js 中是一个全局 ...
- Node.js官方文档:到底什么是阻塞(Blocking)与非阻塞(Non-Blocking)?
译者按: Node.js文档阅读系列之一. 原文: Overview of Blocking vs Non-Blocking 译者: Fundebug 为了保证可读性,本文采用意译而非直译. 这篇博客 ...
- node.js官方文档chm电子书的制作
制作软件:WebCHMSetup2.22.zip,http://www.onlinedown.net/soft/31553.htm 制作好的电子书:Node.js(v6.10.2).zip 参考链接: ...
- Node.js 官方文档中文版
这目录也是醉了 . 列出跟没列出没两样
- bootbox.js官方文档中文版
bootbox.js官方文档中文版简介:Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Boot ...
- Hui之Hui.js 官方文档
基础 // 判断值是否是指定数据类型 var result = hui.isTargetType("百签软件", "string"); //=>true ...
- sanic官方文档解析之Example(二)
1,通过docker部署sanic项目 通过Docker和Docker Compose部署SANIC应用程序是一项很容易实现的任务,下面的示例提供了示例simple_server.py的部署 FROM ...
- Android Google官方文档解析之——Application Fundamentals
Android apps are written in the java programming language.The Android SDK tools compile your code-al ...
- bootbox.js官方文档
简介 Bootbox.js是一个小型的JavaScript库,基于Bootstrap模态框开发,用于创建可编程的对话框. 不像原生的alert等对话框,所有的Bootstrap模态框生成的都是非阻塞事 ...
随机推荐
- 老男孩Python全栈学习 S9 日常作业 005
1.有如下变量,请实现要求的功能 tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age& ...
- 主机管理+堡垒机系统开发:strace工具的实现原理(七)
strace是Linux系统下的一个用来跟踪系统调用的工具,它的实现基础是ptrace系统调用.使用strace工具可以跟踪一个程序执行过程中发生的系统调用. 我这里讲到的内容有一点点和mips体系相 ...
- Java进程线程笔记
什么是并行和并发? 并发和并行是即相似又有区别:(微观) 并行:指两个或多个事件在同一时刻发生: 强调的是时间点. 并发:指两个或多个事件在同一时间段内发生: 强调的是时间段. 进程和线程的区别? 进 ...
- day18 集合框架(JCF)
集合框架(JCF)java collections framework 框架:为了实现某一目的/功能而预先提供的一系列封装好的具有继承或实现关系的类与接口. 1.这种框架是高性能的,对基本类集(动态数 ...
- 第四节:Task的启动的四种方式以及Task、TaskFactory的线程等待和线程延续的解决方案
一. 背景 揭秘: 在前面的章节介绍过,Task出现之前,微软的多线程处理方式有:Thread→ThreadPool→委托的异步调用,虽然也可以基本业务需要的多线程场景,但它们在多个线程的等待处理方面 ...
- 学习python笔记 协程
下面将一个经典的消费者和生产者的案例进行分析: import time def consumer(): r = '' while True: n = yield r if not n: return ...
- “字节跳动-文远知行杯”广东工业大学第十四届程序设计竞赛 1010 Count
思路:矩阵快速幂.推一下初始矩阵就好了 #include<bits/stdc++.h> #define LL long long #define fi first #define se s ...
- 51nod--1174 区间中最大的数 (RMQ)
题目: 1174 区间中最大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 给出一个有N个数的序列,编号0 - N - 1.进行Q次查询,查询编号i至j ...
- Solr坏境搭建
1.1. 搭建步骤 第一步:把solr 的压缩包上传到Linux系统 第二步:解压solr. 第三步:安装Tomcat,解压缩即可. 第四步:把dist目录下的solr.war部署到Tomcat下. ...
- FM算法(一):算法理论
主要内容: 动机 FM算法模型 FM算法VS 其他算法 一.动机 在传统的线性模型如LR中,每个特征都是独立的,如果需要考虑特征与特征直接的交互作用,可能需要人工对特征进行交叉组合:非线性SVM可 ...