mirror of
https://github.com/nodejs/node.git
synced 2025-05-13 02:59:02 +00:00

The use-case is for any framework that provides user mw a response replacement, that collects the desired response state, and applies them only on conclusion. As such a framework, I'd want to validate the header names and values as soon as the user-code provides them. This - to eliminate errors on response-send time, and provide developer stack trace that contains the line that submits the offending values. PR-URL: https://github.com/nodejs/node/pull/33119 Reviewed-By: Anna Henningsen <anna@addaleax.net>
63 lines
1.6 KiB
JavaScript
63 lines
1.6 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
const assert = require('assert');
|
|
const { validateHeaderName, validateHeaderValue } = require('http');
|
|
|
|
// Expected static methods
|
|
isFunc(validateHeaderName, 'validateHeaderName');
|
|
isFunc(validateHeaderValue, 'validateHeaderValue');
|
|
|
|
// Expected to be useful as static methods
|
|
console.log('validateHeaderName');
|
|
// - when used with valid header names - should not throw
|
|
[
|
|
'user-agent',
|
|
'USER-AGENT',
|
|
'User-Agent',
|
|
'x-forwarded-for'
|
|
].forEach((name) => {
|
|
console.log('does not throw for "%s"', name);
|
|
validateHeaderName(name);
|
|
});
|
|
|
|
// - when used with invalid header names:
|
|
[
|
|
'איקס-פורוורד-פור',
|
|
'x-forwarded-fםr',
|
|
].forEach((name) => {
|
|
console.log('throws for: "%s"', name.slice(0, 50));
|
|
assert.throws(
|
|
() => validateHeaderName(name),
|
|
{ code: 'ERR_INVALID_HTTP_TOKEN' }
|
|
);
|
|
});
|
|
|
|
console.log('validateHeaderValue');
|
|
// - when used with valid header values - should not throw
|
|
[
|
|
['x-valid', 1],
|
|
['x-valid', '1'],
|
|
['x-valid', 'string'],
|
|
].forEach(([name, value]) => {
|
|
console.log('does not throw for "%s"', name);
|
|
validateHeaderValue(name, value);
|
|
});
|
|
|
|
// - when used with invalid header values:
|
|
[
|
|
// [header, value, expectedCode]
|
|
['x-undefined', undefined, 'ERR_HTTP_INVALID_HEADER_VALUE'],
|
|
['x-bad-char', 'לא תקין', 'ERR_INVALID_CHAR'],
|
|
].forEach(([name, value, code]) => {
|
|
console.log('throws %s for: "%s: %s"', code, name, value);
|
|
assert.throws(
|
|
() => validateHeaderValue(name, value),
|
|
{ code }
|
|
);
|
|
});
|
|
|
|
// Misc.
|
|
function isFunc(v, ttl) {
|
|
assert.ok(v.constructor === Function, `${ttl} is expected to be a function`);
|
|
}
|