zoukankan      html  css  js  c++  java
  • [Unit Testing] Mock a Node module's dependencies using Proxyquire

    Sometimes when writing a unit test, you know that the module you're testing imports a module that you would like to observe, or at the very least mock to prevent side effects like network activity or file system operations.

    For JavaScript unit tests that run in Node, we can hijack the built-in require function by using the proxyquire module, which allows us to mock one or more modules that are second-class dependencies in our unit test, replacing them with whatever we want.

    This means we could replace functions with no-ops to prevent side effects, or replace them with Sinon spies to observe the inner workings of the module you're testing.

    In this video, we'll demonstrate the basics of using Proxyquire to prevent and observe a file system operation.

    index.js:

    const fs = require('fs');
    
    exports.writeFile = (filename, contents) => {
      fs.writeFileSync(filename, contents.trim(), 'utf8');
    }

    For unit testing, we don't want to call 'fs.writeFileSync', instead we want to using mock function.

    const assert = require('assert');
    const proxyquire = require('proxyquire');
    const sinon = require('sinon');
    
    const fsMock = {};
    // In index.js file, we want to mock 'fs' module with our fsMock object
    const main = proxyquire('./index.js', {'fs', fsMock});
    describe('main.writeFile', () => {
      it('should write a trimmed string to the specififed file', () => {
        fsMock.writeFileSync = sinon.spy();
        main.writeFile('file.txt', 'string');
        assert.deepEqual(fsMock.writeFileSync.getCall(0).args, ['file.txt', 'string', 'utf8'])
      })
    })
  • 相关阅读:
    hadoop机架感知
    Ajax请求结果的缓存
    Blocks语法
    CentOS yum 源的配置与使用
    .NET三层架构开发初步
    Mac技巧合集第一期
    Fine Uploader文件上传组件
    WCF 系列文章
    http权威指南读书笔记
    WCF Service Hosting的线程关联性Mono实现比.NET统一?
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10216084.html
Copyright © 2011-2022 走看看