mirror of
https://github.com/denoland/deno.git
synced 2025-01-10 16:11:13 -05:00
a21a5ad2fa
Resolves #1705 This PR adds the Deno APIs as a global namespace named `Deno`. For backwards compatibility, the ability to `import * from "deno"` is preserved. I have tried to convert every test and internal code the references the module to use the namespace instead, but because I didn't break compatibility I am not sure. On the REPL, `deno` no longer exists, replaced only with `Deno` to align with the regular runtime. The runtime type library includes both the namespace and module. This means it duplicates the whole type information. When we remove the functionality from the runtime, it will be a one line change to the library generator to remove the module definition from the type library. I marked a `TODO` in a couple places where to remove the `"deno"` module, but there are additional places I know I didn't mark.
322 lines
7.7 KiB
TypeScript
322 lines
7.7 KiB
TypeScript
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
|
import { test, assert, assertEqual } from "./test_util.ts";
|
|
|
|
// Logic heavily copied from web-platform-tests, make
|
|
// sure pass mostly header basic test
|
|
/* tslint:disable-next-line:max-line-length */
|
|
// ref: https://github.com/web-platform-tests/wpt/blob/7c50c216081d6ea3c9afe553ee7b64534020a1b2/fetch/api/headers/headers-basic.html
|
|
/* tslint:disable:no-unused-expression */
|
|
test(function newHeaderTest() {
|
|
new Headers();
|
|
new Headers(undefined);
|
|
new Headers({});
|
|
try {
|
|
new Headers(null);
|
|
} catch (e) {
|
|
assertEqual(
|
|
e.message,
|
|
"Failed to construct 'Headers'; The provided value was not valid"
|
|
);
|
|
}
|
|
});
|
|
|
|
const headerDict = {
|
|
name1: "value1",
|
|
name2: "value2",
|
|
name3: "value3",
|
|
name4: undefined,
|
|
"Content-Type": "value4"
|
|
};
|
|
const headerSeq = [];
|
|
for (const name in headerDict) {
|
|
headerSeq.push([name, headerDict[name]]);
|
|
}
|
|
|
|
test(function newHeaderWithSequence() {
|
|
const headers = new Headers(headerSeq);
|
|
for (const name in headerDict) {
|
|
assertEqual(headers.get(name), String(headerDict[name]));
|
|
}
|
|
assertEqual(headers.get("length"), null);
|
|
});
|
|
|
|
test(function newHeaderWithRecord() {
|
|
const headers = new Headers(headerDict);
|
|
for (const name in headerDict) {
|
|
assertEqual(headers.get(name), String(headerDict[name]));
|
|
}
|
|
});
|
|
|
|
test(function newHeaderWithHeadersInstance() {
|
|
const headers = new Headers(headerDict);
|
|
const headers2 = new Headers(headers);
|
|
for (const name in headerDict) {
|
|
assertEqual(headers2.get(name), String(headerDict[name]));
|
|
}
|
|
});
|
|
|
|
test(function headerAppendSuccess() {
|
|
const headers = new Headers();
|
|
for (const name in headerDict) {
|
|
headers.append(name, headerDict[name]);
|
|
assertEqual(headers.get(name), String(headerDict[name]));
|
|
}
|
|
});
|
|
|
|
test(function headerSetSuccess() {
|
|
const headers = new Headers();
|
|
for (const name in headerDict) {
|
|
headers.set(name, headerDict[name]);
|
|
assertEqual(headers.get(name), String(headerDict[name]));
|
|
}
|
|
});
|
|
|
|
test(function headerHasSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
for (const name in headerDict) {
|
|
assert(headers.has(name), "headers has name " + name);
|
|
/* tslint:disable-next-line:max-line-length */
|
|
assert(
|
|
!headers.has("nameNotInHeaders"),
|
|
"headers do not have header: nameNotInHeaders"
|
|
);
|
|
}
|
|
});
|
|
|
|
test(function headerDeleteSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
for (const name in headerDict) {
|
|
assert(headers.has(name), "headers have a header: " + name);
|
|
headers.delete(name);
|
|
assert(!headers.has(name), "headers do not have anymore a header: " + name);
|
|
}
|
|
});
|
|
|
|
test(function headerGetSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
for (const name in headerDict) {
|
|
assertEqual(headers.get(name), String(headerDict[name]));
|
|
assertEqual(headers.get("nameNotInHeaders"), null);
|
|
}
|
|
});
|
|
|
|
test(function headerEntriesSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
const iterators = headers.entries();
|
|
for (const it of iterators) {
|
|
const key = it[0];
|
|
const value = it[1];
|
|
assert(headers.has(key));
|
|
assertEqual(value, headers.get(key));
|
|
}
|
|
});
|
|
|
|
test(function headerKeysSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
const iterators = headers.keys();
|
|
for (const it of iterators) {
|
|
assert(headers.has(it));
|
|
}
|
|
});
|
|
|
|
test(function headerValuesSuccess() {
|
|
const headers = new Headers(headerDict);
|
|
const iterators = headers.values();
|
|
const entries = headers.entries();
|
|
const values = [];
|
|
for (const pair of entries) {
|
|
values.push(pair[1]);
|
|
}
|
|
for (const it of iterators) {
|
|
assert(values.includes(it));
|
|
}
|
|
});
|
|
|
|
const headerEntriesDict = {
|
|
name1: "value1",
|
|
Name2: "value2",
|
|
name: "value3",
|
|
"content-Type": "value4",
|
|
"Content-Typ": "value5",
|
|
"Content-Types": "value6"
|
|
};
|
|
|
|
test(function headerForEachSuccess() {
|
|
const headers = new Headers(headerEntriesDict);
|
|
const keys = Object.keys(headerEntriesDict);
|
|
keys.forEach(key => {
|
|
const value = headerEntriesDict[key];
|
|
const newkey = key.toLowerCase();
|
|
headerEntriesDict[newkey] = value;
|
|
});
|
|
let callNum = 0;
|
|
headers.forEach((value, key, container) => {
|
|
assertEqual(headers, container);
|
|
assertEqual(value, headerEntriesDict[key]);
|
|
callNum++;
|
|
});
|
|
assertEqual(callNum, keys.length);
|
|
});
|
|
|
|
test(function headerSymbolIteratorSuccess() {
|
|
assert(Symbol.iterator in Headers.prototype);
|
|
const headers = new Headers(headerEntriesDict);
|
|
for (const header of headers) {
|
|
const key = header[0];
|
|
const value = header[1];
|
|
assert(headers.has(key));
|
|
assertEqual(value, headers.get(key));
|
|
}
|
|
});
|
|
|
|
test(function headerTypesAvailable() {
|
|
function newHeaders(): Headers {
|
|
return new Headers();
|
|
}
|
|
const headers = newHeaders();
|
|
assert(headers instanceof Headers);
|
|
});
|
|
|
|
// tslint:disable-next-line:max-line-length
|
|
// Modified from https://github.com/bitinn/node-fetch/blob/7d3293200a91ad52b5ca7962f9d6fd1c04983edb/test/test.js#L2001-L2014
|
|
// Copyright (c) 2016 David Frank. MIT License.
|
|
test(function headerIllegalReject() {
|
|
let errorCount = 0;
|
|
try {
|
|
new Headers({ "He y": "ok" });
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
new Headers({ "Hé-y": "ok" });
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
new Headers({ "He-y": "ăk" });
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
const headers = new Headers();
|
|
try {
|
|
headers.append("Hé-y", "ok");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
headers.delete("Hé-y");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
headers.get("Hé-y");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
headers.has("Hé-y");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
headers.set("Hé-y", "ok");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
try {
|
|
headers.set("", "ok");
|
|
} catch (e) {
|
|
errorCount++;
|
|
}
|
|
assertEqual(errorCount, 9);
|
|
// 'o k' is valid value but invalid name
|
|
new Headers({ "He-y": "o k" });
|
|
});
|
|
|
|
// If pair does not contain exactly two items,then throw a TypeError.
|
|
test(function headerParamsShouldThrowTypeError() {
|
|
let hasThrown = 0;
|
|
|
|
try {
|
|
new Headers(([["1"]] as unknown) as Array<[string, string]>);
|
|
hasThrown = 1;
|
|
} catch (err) {
|
|
if (err instanceof TypeError) {
|
|
hasThrown = 2;
|
|
} else {
|
|
hasThrown = 3;
|
|
}
|
|
}
|
|
|
|
assertEqual(hasThrown, 2);
|
|
});
|
|
|
|
test(function headerParamsArgumentsCheck() {
|
|
const methodRequireOneParam = ["delete", "get", "has", "forEach"];
|
|
|
|
const methodRequireTwoParams = ["append", "set"];
|
|
|
|
methodRequireOneParam.forEach(method => {
|
|
const headers = new Headers();
|
|
let hasThrown = 0;
|
|
let errMsg = "";
|
|
try {
|
|
headers[method]();
|
|
hasThrown = 1;
|
|
} catch (err) {
|
|
errMsg = err.message;
|
|
if (err instanceof TypeError) {
|
|
hasThrown = 2;
|
|
} else {
|
|
hasThrown = 3;
|
|
}
|
|
}
|
|
assertEqual(hasThrown, 2);
|
|
assertEqual(
|
|
errMsg,
|
|
`Headers.${method} requires at least 1 argument, but only 0 present`
|
|
);
|
|
});
|
|
|
|
methodRequireTwoParams.forEach(method => {
|
|
const headers = new Headers();
|
|
let hasThrown = 0;
|
|
let errMsg = "";
|
|
|
|
try {
|
|
headers[method]();
|
|
hasThrown = 1;
|
|
} catch (err) {
|
|
errMsg = err.message;
|
|
if (err instanceof TypeError) {
|
|
hasThrown = 2;
|
|
} else {
|
|
hasThrown = 3;
|
|
}
|
|
}
|
|
assertEqual(hasThrown, 2);
|
|
assertEqual(
|
|
errMsg,
|
|
`Headers.${method} requires at least 2 arguments, but only 0 present`
|
|
);
|
|
|
|
hasThrown = 0;
|
|
errMsg = "";
|
|
try {
|
|
headers[method]("foo");
|
|
hasThrown = 1;
|
|
} catch (err) {
|
|
errMsg = err.message;
|
|
if (err instanceof TypeError) {
|
|
hasThrown = 2;
|
|
} else {
|
|
hasThrown = 3;
|
|
}
|
|
}
|
|
assertEqual(hasThrown, 2);
|
|
assertEqual(
|
|
errMsg,
|
|
`Headers.${method} requires at least 2 arguments, but only 1 present`
|
|
);
|
|
});
|
|
});
|