Mock Express Response
Node.js library designed to facilitate unit and integration testing of Express.js middleware and route handlers by providing a mock HTTP response object. It emulates the standard Express `response` API, including methods like `json()`, `send()`, and `render()`, allowing developers to inspect the output and behavior of their Express-dependent code without launching a full HTTP server. The package, currently at version 0.3.0, appears to be unmaintained; its last update was in 2017 and the copyright dates to 2015. It is built upon `mock-res` for core HTTP response stream mocking and is intended to be used in conjunction with `mock-express-request` for a complete request/response mock pair. A key differentiator is its direct mirroring of the Express `res` object's internal state, allowing retrieval of rendered data via methods like `_getJSON()` and `_getString()`, which simplifies assertion writing in tests. Due to its age, compatibility with modern Express.js versions (v5+) and native ESM environments is not guaranteed.
Common errors
-
TypeError: MockExpressResponse is not a constructor
cause Attempting to use `MockExpressResponse` as a class in an ES module context when it's a CommonJS export, or incorrect `require` usage.fixEnsure you are using `const MockExpressResponse = require('mock-express-response');` in a CommonJS file. -
TypeError: response.json is not a function
cause The underlying Express `res` methods are not correctly mocked or inherited due to a version mismatch with the expected Express API, especially if using Express v5 or newer.fixVerify that your `express` peer dependency version is compatible with this library (Express v3 or v4). If using a newer Express version, this package is likely incompatible; consider manually mocking the `res` object or using a different testing approach.
Warnings
- gotcha The package is effectively abandoned, with its last release (v0.3.0) in 2017 and copyright dating to 2015. It is unlikely to receive updates for bug fixes, security vulnerabilities, or compatibility with newer Node.js versions or Express.js APIs (e.g., Express v5+). Its `peerDependency` on `express@^3.0.0 || ^4.0.0` explicitly indicates lack of support for Express v5 and beyond.
- gotcha This package strictly supports CommonJS (CJS) imports and does not provide native ES module (ESM) compatibility. Attempting to use `import MockExpressResponse from 'mock-express-response'` in an ESM context will fail.
Install
-
npm install mock-express-response -
yarn add mock-express-response -
pnpm add mock-express-response
Imports
- MockExpressResponse
import MockExpressResponse from 'mock-express-response';
const MockExpressResponse = require('mock-express-response');
Quickstart
const ejs = require('ejs');
const MockExpressRequest = require('mock-express-request');
const MockExpressResponse = require('mock-express-response');
// Basic usage
const response = new MockExpressResponse();
// With options, including a custom render engine and a mock request object
const request = new MockExpressRequest({
url: '/users/123',
method: 'GET'
});
const responseWithOptions = new MockExpressResponse({
render: ejs.renderFile, // Use ejs as a template engine example
request: request
});
// Express response methods
responseWithOptions.json({ user: { id: 1, active: true } });
responseWithOptions.render('user.ejs', { user: { id: 1, name: 'Test User' } });
responseWithOptions.send('<p>User details page</p>');
// To obtain the sent json response for testing
const jsonResult = responseWithOptions._getJSON();
console.log('JSON Result:', jsonResult);
// To obtain the text/html response for testing
const stringResult = responseWithOptions._getString();
console.log('HTML Result:', stringResult);