热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

NodeJS—Assert使用示例

NodeJs中Assert断言库的使用示例:从中可以找到一些规律:equal、notEqual、deepEqual、notDeepEqual:使用''比较符进行比较

NodeJs中Assert断言库的使用示例:

从中可以找到一些规律:

  • equal、notEqual、deepEqual、notDeepEqual:使用‘==‘比较符进行比较。即:不含strict的方法,使用的都是‘==‘比较符。
  • strictEqual、notStrictEqual、strictDeepEqual、notStrictDeepEqual:使用‘===‘比较符进行比较。即:含strict的方法,使用的都是‘===‘比较符。
describe(‘Assert用法测试‘, function () {

    var obj1 = {
        name: ‘111‘,
        parent: {
            mother: ‘222‘
        }
    }

    var obj2 = {
        name: ‘111‘,
        parent: {
            mother: ‘222‘
        }
    }

    var obj3 = {
        name: ‘333‘
    }

    var obj4 = {
        name: 333
    }

    it(‘assert.ok‘, function () {
        var msg = ‘值应为真‘
        assert.ok(true, msg)
        assert.ok(‘1‘, msg)
        assert.ok(1, msg)
    });

    it(‘assert.equal‘, function () {
        assert.equal(1, ‘1‘, ‘两个值应相等。使用\‘==\‘进行比较‘)
    })

    it(‘assert.notEqual‘, function () {
        assert.notEqual(1, 2, ‘两个值应不相等。使用\‘!=\‘进行比较‘)
    })

    it(‘assert.deepEqual‘, function () {
        assert.deepEqual(obj1, obj2, ‘两个对象中的属性应深度全等。使用\‘==\‘进行比较‘)
    })

    it(‘assert.notDeepEqual‘, function () {
        assert.notDeepEqual(obj1, obj3, ‘两个对象中的属性应深度不全等。使用\‘!=\‘进行比较‘)
    })

    it(‘assert.strictEqual‘, function () {
        var msg = ‘两个值应相等。使用\‘===\‘进行比较‘
        assert.strictEqual(1, 1, msg)
        assert.strictEqual(‘1‘, ‘1‘, msg)
        assert.strictEqual(true, true, msg)
    })

    it(‘assert.notStrictEqual‘, function () {
        var msg = ‘两个值应不相等,或值为不同类型。使用\‘!==\‘进行比较‘
        assert.notStrictEqual(1, ‘1‘, msg)
        assert.notStrictEqual(1, 2, msg)
    })

    it(‘assert.deepStrictEqual‘, function () {
        assert.deepStrictEqual(obj1, obj2, ‘两个对象中的属性应深度全等,并且对应的值为同一类型。使用\‘===\‘进行比较‘)
    })

    it(‘assert.notDeepStrictEqual‘, function () {
        assert.notDeepStrictEqual(obj4, obj3, ‘两个对象中的属性应深度不全等,或对应的值为不同类型。使用\‘!==\‘进行比较‘)
    })

    it(‘assert.throws‘, function () {
        // 方法中应当抛出对应错误信息
        assert.throws(function () {
            throw ‘错误信息‘
        }, /错误信息/)
    })

    it(‘assert.doesNotThrow‘, function () {
        // 方法中不应抛出对应错误
        assert.doesNotThrow(function () {
            var a = 1 + 1;
        }, RangeError, ‘抛出了RangeError错误‘)
    })

    it(‘assert.ifError‘, function () {
        // 参数为真是,抛出错误;为假时,测试通过
        assert.ifError(false)
    })

    // it(‘assert.fail‘, function () {
    //     assert.fail(1, ‘1‘, ‘主动抛出错误‘)
    // })

})

NodeJS—Assert使用示例


推荐阅读
  • 深入解析 OpenCV 2 中 Mat 对象的类型、深度与步长属性
    在OpenCV 2中,`Mat`类作为核心组件,对于图像处理至关重要。本文将深入探讨`Mat`对象的类型、深度与步长属性,这些属性是理解和优化图像操作的基础。通过具体示例,我们将展示如何利用这些属性实现高效的图像缩小功能。此外,还将讨论这些属性在实际应用中的重要性和常见误区,帮助读者更好地掌握`Mat`类的使用方法。 ... [详细]
  • 大数据应用实例:电视收视率分析企业项目实操第二篇
    本文继续探讨大数据在电视收视率分析中的应用,详细介绍了如何在CentOS系统中进行防火墙管理。针对CentOS 6.5及更早版本,提供了具体的命令操作步骤,包括停止防火墙服务和禁用防火墙启动。此外,还深入讨论了这些操作对数据传输和系统安全的影响,为实际项目实施提供了宝贵的技术参考。 ... [详细]
  • 通过优化模板消息机制,本研究提出了一种高效的信息化推送方案。该方案利用获取的访问令牌(access token)和指定的模板ID,实现了精准且快速的信息推送,显著提升了用户体验和信息传递效率。具体实现中,通过调用相关API接口,确保了消息的准确性和及时性,为用户提供更加便捷的服务。 ... [详细]
  • 在探讨如何高效处理大规模数据报表的分页展示之前,首先需要明确导致报表加载缓慢的主要原因。通常情况下,这主要是由于两个方面:一是查询条件过于宽泛,使得数据库返回的结果集包含数百万甚至更多的记录;二是前端渲染性能不足,无法高效处理大量数据。为了优化这一过程,可以从以下几个方面入手:优化查询条件,减少不必要的数据返回;采用分页查询技术,每次仅加载所需的数据;利用缓存机制,减少对数据库的频繁访问;提升前端渲染效率,使用虚拟滚动等技术提高用户体验。 ... [详细]
  • 本文深入探讨了原型模式在软件设计中的应用与实现。原型模式通过使用已有的实例作为原型来创建新对象,而不是直接通过类实例化。这种方式不仅简化了对象的创建过程,还提高了系统的灵活性和效率。具体来说,原型模式涉及一个支持克隆功能的接口或基类,子类通过实现该接口来提供具体的克隆方法,从而实现对象的快速复制。此外,文章还详细分析了原型模式的优缺点及其在实际项目中的应用场景,为开发者提供了实用的指导和建议。 ... [详细]
  • 本文详细探讨了Java集合框架的使用方法及其性能特点。首先,通过关系图展示了集合接口之间的层次结构,如`Collection`接口作为对象集合的基础,其下分为`List`、`Set`和`Queue`等子接口。其中,`List`接口支持按插入顺序保存元素且允许重复,而`Set`接口则确保元素唯一性。此外,文章还深入分析了不同集合类在实际应用中的性能表现,为开发者选择合适的集合类型提供了参考依据。 ... [详细]
  • 本文深入解析了 Apache 配置文件 `httpd.conf` 和 `.htaccess` 的优化方法,探讨了如何通过合理配置提升服务器性能和安全性。文章详细介绍了这两个文件的关键参数及其作用,并提供了实际应用中的最佳实践,帮助读者更好地理解和运用 Apache 配置。 ... [详细]
  • 题目描述非常吸引人。每颗星星可以通过其在窗口的左下角和右上角位置构建两条扫描线,从而将问题转化为区间增减和求最大值的操作。需要注意的是,位于边界的星星不应计入结果,因此在处理时应分别对左右边界进行适当的增减调整。此外,利用线段树和离散化技术可以显著提高算法效率,确保在大规模数据下的性能表现。 ... [详细]
  • Vuex 实战进阶:构建高效笔记本应用(第二篇)
    在上一篇文章中,我们初步探讨了 Vuex 在该项目中的应用。本文将深入解析整个项目的架构设计。首先回顾 `main.js` 的内容,然后重点分析 `App.vue` 文件,其中引入了 `Toolbar.vue` 和 `NodeList.vue` 组件,详细说明它们在应用中的作用和交互方式。通过这些组件的协同工作,我们将展示如何构建一个高效且响应迅速的笔记本应用。 ... [详细]
  • 新年伊始,正是学习的最佳时机。本文全面解析了CK1957-Zookeeper的核心概念与实践技巧,旨在帮助初学者快速掌握这一深度学习工具。通过详细的理论讲解和实际操作示例,读者可以更好地理解Zookeeper的工作原理及其在分布式系统中的应用。无论是新手还是有一定基础的学习者,都能从中受益匪浅。 ... [详细]
  • 探究Oracle数据库字符集编码的详细方法与实践
    本文深入探讨了Oracle数据库字符集编码的详细方法与实践。首先,通过执行 `SELECT USERENV('language') FROM DUAL;` 查询服务端字符集编码。其次,通过在注册表中搜索 `NLS_LANG` 参数来查看客户端字符集编码。此外,文章还介绍了如何在不同场景下正确配置和转换字符集,以确保数据的一致性和完整性。 ... [详细]
  • 在执行 Vim/VM 命令时遇到错误提示:检测到名为
    在使用 Docker 时,通过 Vim 编辑 Dockerfile 文件时遇到了错误提示:“检测到名为 .dockerfile.swp 的交换文件”。这一问题通常是因为上次编辑该文件时意外中断,导致系统生成了临时的交换文件。为了解决这个问题,可以手动删除该交换文件或使用 Vim 的恢复功能来恢复未保存的更改。 ... [详细]
  • Python学习:环境配置与安装指南
    Python作为一种跨平台的编程语言,适用于Windows、Linux和macOS等多种操作系统。为了确保本地已成功安装Python,用户可以通过终端或命令行界面输入`python`或`python3`命令进行验证。此外,建议使用虚拟环境管理工具如`venv`或`conda`,以便更好地隔离不同项目依赖,提高开发效率。 ... [详细]
  • 斐波那契数在组合数学中的应用与探索
    斐波那契数列作为数学领域中一个广为人知的数列,不仅拥有丰富的数学性质,还与自然界的诸多现象紧密相连。本文将深入探讨这一数列背后的奥秘,揭示其在组合数学中的广泛应用,并通过具体问题的引入,展示斐波那契数列在解决复杂组合问题时的独特优势。 ... [详细]
  • Jenkins学习精华:自动化构建与持续集成入门指南
    本文综合了网络资源及同事分享的PPT内容,详细介绍了Jenkins在自动化构建与持续集成中的应用。首先涵盖了Jenkins的安装与配置流程,接着阐述了如何根据项目需求设定自动化编译任务,包括确定开发环境、选择合适的编译工具以及实现代码的自动更新等关键步骤。特别强调了在SVN环境中通过命令行实现代码自动拉取的最佳实践。 ... [详细]
author-avatar
Carol卍_932
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有