专栏名称: 张淼
Web前端开发工程师
目录
相关文章推荐
前端早读课  ·  【第3472期】资源预加载可能会拖慢网站速度 ·  21 小时前  
前端大全  ·  湖南大学的 DeepSeek ... ·  3 天前  
前端早读课  ·  【第3470期】利用大型语言模型(LLMs) ... ·  2 天前  
51好读  ›  专栏  ›  张淼

测试用例驱动阅读Express源码

张淼  · 掘金  · 前端  · 2018-03-19 03:47

正文

测试用例驱动阅读Express源码

1.简介

Expres是基于Node.js平台,快速、开放、极简的web开发框架。(Expres中文官网首页原话)。之所以引用这句话,是因为这句话简单明了的告知了大家,它到底是什么。基于Node的一个开发框架,目的是给web开发提供了方便。今天我们就用测试用例开发的模式,一步步追踪Express路由系统源码是怎么实现的。

整体代码感知

本次实践项目,完整目录结构如下(以下会直接说某个文件的内容):

Express
  |--lib
  |   |-express.js(主文件)
  |   |-application.js(相当于中转站直接访问路由信息)
  |   |-Router(路由,中间件)
  |       |-index.js
  |       |-layer.js
  |       |-route.js
  |
  |--test
  |   |-getTest.js
  |   |-routerTest.js
  |   |-middleTest.js

测试用例一(简单服务)

var express = require('express');
var app = express();

app.get('/', function (req, res) {
  res.send('Hello World!');
});

var server = app.listen(3000, function () {
  console.log('server started on port 3000');
});

以上代码是Express官网入门的一个最简单的实例,简单的搭建了一个服务,并且访问根目录的时候,会返回Hello World!我们可以看到app是引用后的express执行得到的一个对象(说明express是一个函数),并且在该对象上有get和listen两个方法。主文件express.js,结构如下:

const app = require('./application');
function createApplication(){
   return app;
}
module.exports = createApplication;

application.js中应该具有一个对象,并且该对象上面有两个方法.首先有一个存放路由的数组,默认有一个对象,我定义为兜底对象,就是当输入的路由信息并不存在的时候,执行该对象的handler。到此,两个文件执行完毕,我们就实现最简单的服务搭建以及get路由功能。

let router = [
    {
        path:'*',
        method:'*',
        handler(req,res){
            res.end('Not Found');
        }
    }

];
let http = require('http');
const app = {
    get(path,handler){
        router.push({
            method:'get',
            path,
            handler
        });
    },
    listen(){
        const server = http.createServer(function(req,res){
            for(let i=0;i<router.length;i++){
                let {path,method,handler} = router[i];
                if(path == req.url && method == req.method.toLowerCase()){
                    return handler(req,res);
                }
            }
            router[0].handler(req,res);
        });
        server.listen.apply(server,arguments);
    }
}
module.exports  = app;

测试用例二(路由)

app.get('/',function(req,res,next){
    console.log(1);
    next();
},function(req,res,next){
    console.log(11);
    next();
}).get('/',function(req,res,next){
    console.log(2);
    next();
}).get('/'






请到「今天看啥」查看全文