mirror of
https://github.com/zebrajr/express.git
synced 2025-12-06 12:19:51 +01:00
Since v5 relies on node >= 18, this is now possible (since v16, v14.18.0 [^1][^2]). It's functionally irrelevant: 1. It's not required for CJS nor ESM (with a few exceptions [^3]) 2. It has no performance promises However, there are upsides to this approach: 1. It brings clear boundaries to what's a built-in and what's an external dependency 2. It reduces the risk of importing unwanted deps where a built-in is expected 3. It's slightly more interoperable with other JS runtimes that provide node compatibility[^4], albeit only during development. Once imported from npm, built-ins are assumed. [^1]:https://nodejs.org/docs/latest-v22.x/api/modules.html#built-in-modules [^2]:https://github.com/nodejs/node/pull/37246 [^3]:https://nodejs.org/api/modules.html#built-in-modules-with-mandatory-node-prefix [^4]:https://docs.deno.com/runtime/fundamentals/node/#using-node's-built-in-modules
71 lines
2.1 KiB
JavaScript
71 lines
2.1 KiB
JavaScript
'use strict'
|
|
|
|
var assert = require('node:assert');
|
|
var utils = require('../lib/utils');
|
|
|
|
describe('utils.etag(body, encoding)', function(){
|
|
it('should support strings', function(){
|
|
assert.strictEqual(utils.etag('express!'),
|
|
'"8-O2uVAFaQ1rZvlKLT14RnuvjPIdg"')
|
|
})
|
|
|
|
it('should support utf8 strings', function(){
|
|
assert.strictEqual(utils.etag('express❤', 'utf8'),
|
|
'"a-JBiXf7GyzxwcrxY4hVXUwa7tmks"')
|
|
})
|
|
|
|
it('should support buffer', function(){
|
|
assert.strictEqual(utils.etag(Buffer.from('express!')),
|
|
'"8-O2uVAFaQ1rZvlKLT14RnuvjPIdg"')
|
|
})
|
|
|
|
it('should support empty string', function(){
|
|
assert.strictEqual(utils.etag(''),
|
|
'"0-2jmj7l5rSw0yVb/vlWAYkK/YBwk"')
|
|
})
|
|
})
|
|
|
|
describe('utils.setCharset(type, charset)', function () {
|
|
it('should do anything without type', function () {
|
|
assert.strictEqual(utils.setCharset(), undefined);
|
|
});
|
|
|
|
it('should return type if not given charset', function () {
|
|
assert.strictEqual(utils.setCharset('text/html'), 'text/html');
|
|
});
|
|
|
|
it('should keep charset if not given charset', function () {
|
|
assert.strictEqual(utils.setCharset('text/html; charset=utf-8'), 'text/html; charset=utf-8');
|
|
});
|
|
|
|
it('should set charset', function () {
|
|
assert.strictEqual(utils.setCharset('text/html', 'utf-8'), 'text/html; charset=utf-8');
|
|
});
|
|
|
|
it('should override charset', function () {
|
|
assert.strictEqual(utils.setCharset('text/html; charset=iso-8859-1', 'utf-8'), 'text/html; charset=utf-8');
|
|
});
|
|
});
|
|
|
|
describe('utils.wetag(body, encoding)', function(){
|
|
it('should support strings', function(){
|
|
assert.strictEqual(utils.wetag('express!'),
|
|
'W/"8-O2uVAFaQ1rZvlKLT14RnuvjPIdg"')
|
|
})
|
|
|
|
it('should support utf8 strings', function(){
|
|
assert.strictEqual(utils.wetag('express❤', 'utf8'),
|
|
'W/"a-JBiXf7GyzxwcrxY4hVXUwa7tmks"')
|
|
})
|
|
|
|
it('should support buffer', function(){
|
|
assert.strictEqual(utils.wetag(Buffer.from('express!')),
|
|
'W/"8-O2uVAFaQ1rZvlKLT14RnuvjPIdg"')
|
|
})
|
|
|
|
it('should support empty string', function(){
|
|
assert.strictEqual(utils.wetag(''),
|
|
'W/"0-2jmj7l5rSw0yVb/vlWAYkK/YBwk"')
|
|
})
|
|
})
|