zoukankan      html  css  js  c++  java
  • mocha学习(四)为项目开发一个BDD测试

    辅助模块

    我们进行单元测试,一般都需要组合几个工具来来使用的。下面我们开始介绍:

    chai断言库

    chai 断言库支持BDD 的 expect/should 语法风格 和TDD的 assert 语法风格。(在第一章的中有讲到)

    superagent

    在用Node做Web开发的时候,模拟HTTP请求时必不可少的。这也就引出了superagent这个模块,它是一个模拟http请求的库。它作用是简化发起请求的库。

    项目的package.json 代码如下:

    {
      "name": "mocha-test",
      "version": "0.0.1",
      "private": true,
      "scripts": {
        "start": "node app.js",
        "test": "mocha test"
      },
      "devDependencies": {
        "superagent": "1.4.0",
        "chai": "3.4.0"
      }
    }

    项目描述

    在右边环境中初始化了一个project的文件夹。里面我们安装了chai断言库和superagent模块。现在我们在project文件夹中完成一个小小的nodejs项目。

    首先我们创建一个app.js文件。内容如下:

    var http = require('http'),
        PORT = 3000;
    
    function onRequest(request, response) {
        console.log("Request received.");
        response.writeHead(200, {"Content-Type": "text/plain"});
        response.write("Hello World");
        response.end();
    }
    
    var server = http.createServer(onRequest);
    server.listen(PORT);

    描述:为了让项目尽可能的简单,我们没有用到任何的框架。只是创建了一个http服务器监听了80端口。

    1. 在project文件夹中创建一个app.js文件
    2. 再把上述中的内容写入到app.js文件中,然后点击保存文件。一定要保存!一定要保存!一定要保存!重要的事说要三遍(不建议拷贝)

    项目重构

    我们的app.js需要最外部暴露两个方法。所以要对我们右边的项目进行修改。

    需要修改的代码:

    var server = http.createServer(onRequest);
    server.listen(PORT);

    重构为:

    var server = http.createServer(onRequest);
    var boot = function () {
        server.listen(PORT, function () {
            console.info('Express server listening on port ' + PORT);
        });
    };
    var shutdown = function () {
        server.close();
    };
    if (require.main === module) {
        boot();
    } else {
        console.info('Running app as a module');
        exports.boot = boot;
        exports.shutdown = shutdown;
    }

    重构描述:现在我们把启动服务和关闭服务分别进行了封装并且对外进行了暴露。

    按照上述中的描述改写 app.js 中的代码。
     

    测试用例

    现在,我们创建一个名字为 tests 的测试文件夹,并创建一个index.js的文件。测试用例前需要启动服务器,结束后关闭服务。这个时候就用到了前面暴露的 boot() 和 shutdown() 方法。

    示例如下:

    var boot = require('../app').boot,
        shutdown = require('../app').shutdown,
        request = require('superagent'),
        expect = require('chai').expect;
    
    describe('server', function () {
        before(function () {
            boot();
        });
        describe('index', function () {
            it('should respond to GET', function (done) {
                request
                    .get('http://localhost:3000')
                    .end(function (err, res) {
                        expect(res.status).to.equal(200);
                        done();
                    });
            });
        });
        after(function () {
            shutdown();
        });
    });

    运行命令:mocha tests

    1. 在tests文件夹中创建一个index.js文件
    2. 再把上述中的内容写入到index.js文件中,然后点击保存文件。一定要保存!一定要保存!一定要保存!重要的事说要三遍(不建议拷贝)
    3. 最后在linux环境中输入命令:mocha tests。
    声明 欢迎转载,但请保留文章原始出处:) 博客园:https://www.cnblogs.com/chenxiaomeng/ 如出现转载未声明 将追究法律责任~谢谢合作
  • 相关阅读:
    Template、ItemsPanel、ItemContainerStyle、ItemTemplate(包括ListBox的Item子项是横向排列)
    特殊字符处理(WPF)
    DataGrid的组成论述(WPF)
    DataGrid合并单元格(wpf)
    WPF各种控件详解——(WPF从我炫系列)
    C# WPF DataGrid 隔行变色及内容居中对齐
    WPF中的事件及冒泡事件和隧道事件(预览事件)的区别
    迭代式返回 IEnumerable<T>
    react className 样式控制
    React setState更新数组中的某个元素Element item
  • 原文地址:https://www.cnblogs.com/chenxiaomeng/p/15067831.html
Copyright © 2011-2022 走看看