mirror of
https://github.com/denoland/deno.git
synced 2025-03-03 17:34:47 -05:00
chore: upgrade internal deno_std to 0.160 (#16333)
This commit is contained in:
parent
204c46dcc1
commit
74be01273c
11 changed files with 206 additions and 41 deletions
173
cli/tests/testdata/run/textproto.ts
vendored
Normal file
173
cli/tests/testdata/run/textproto.ts
vendored
Normal file
|
@ -0,0 +1,173 @@
|
||||||
|
// Copyright 2018-2022 the Deno authors. All rights reserved. MIT license.
|
||||||
|
// Copyright 2009 The Go Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a BSD-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
/** **Deprecated**. Use `TextLineStream` from `std/steams` for line-by-line text reading instead.
|
||||||
|
*
|
||||||
|
* A reader for dealing with low level text based protocols.
|
||||||
|
*
|
||||||
|
* Based on
|
||||||
|
* [net/textproto](https://github.com/golang/go/tree/master/src/net/textproto).
|
||||||
|
*
|
||||||
|
* @deprecated (will be removed after 0.159.0) Use `TextLineStream` from `std/steams` for line-by-line text reading instead.
|
||||||
|
* @module
|
||||||
|
*/
|
||||||
|
|
||||||
|
import type {
|
||||||
|
BufReader,
|
||||||
|
ReadLineResult,
|
||||||
|
} from "../../../../test_util/std/io/buffer.ts";
|
||||||
|
import { concat } from "../../../../test_util/std/bytes/mod.ts";
|
||||||
|
|
||||||
|
// Constants created for DRY
|
||||||
|
const CHAR_SPACE: number = " ".charCodeAt(0);
|
||||||
|
const CHAR_TAB: number = "\t".charCodeAt(0);
|
||||||
|
const CHAR_COLON: number = ":".charCodeAt(0);
|
||||||
|
|
||||||
|
const WHITESPACES: Array<number> = [CHAR_SPACE, CHAR_TAB];
|
||||||
|
|
||||||
|
const decoder = new TextDecoder();
|
||||||
|
|
||||||
|
// FROM https://github.com/denoland/deno/blob/b34628a26ab0187a827aa4ebe256e23178e25d39/cli/js/web/headers.ts#L9
|
||||||
|
const invalidHeaderCharRegex = /[^\t\x20-\x7e\x80-\xff]/g;
|
||||||
|
|
||||||
|
function str(buf: Uint8Array | null | undefined): string {
|
||||||
|
return !buf ? "" : decoder.decode(buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated (will be removed after 0.159.0) Use `TextLineStream` from `std/steams` for line-by-line text reading instead.
|
||||||
|
*/
|
||||||
|
export class TextProtoReader {
|
||||||
|
constructor(readonly r: BufReader) {}
|
||||||
|
|
||||||
|
/** readLine() reads a single line from the TextProtoReader,
|
||||||
|
* eliding the final \n or \r\n from the returned string.
|
||||||
|
*/
|
||||||
|
async readLine(): Promise<string | null> {
|
||||||
|
const s = await this.readLineSlice();
|
||||||
|
return s === null ? null : str(s);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** ReadMimeHeader reads a MIME-style header from r.
|
||||||
|
* The header is a sequence of possibly continued Key: Value lines
|
||||||
|
* ending in a blank line.
|
||||||
|
* The returned map m maps CanonicalMIMEHeaderKey(key) to a
|
||||||
|
* sequence of values in the same order encountered in the input.
|
||||||
|
*
|
||||||
|
* For example, consider this input:
|
||||||
|
*
|
||||||
|
* My-Key: Value 1
|
||||||
|
* Long-Key: Even
|
||||||
|
* Longer Value
|
||||||
|
* My-Key: Value 2
|
||||||
|
*
|
||||||
|
* Given that input, ReadMIMEHeader returns the map:
|
||||||
|
*
|
||||||
|
* map[string][]string{
|
||||||
|
* "My-Key": {"Value 1", "Value 2"},
|
||||||
|
* "Long-Key": {"Even Longer Value"},
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
async readMimeHeader(): Promise<Headers | null> {
|
||||||
|
const m = new Headers();
|
||||||
|
let line: Uint8Array | undefined;
|
||||||
|
|
||||||
|
// The first line cannot start with a leading space.
|
||||||
|
let buf = await this.r.peek(1);
|
||||||
|
if (buf === null) {
|
||||||
|
return null;
|
||||||
|
} else if (WHITESPACES.includes(buf[0])) {
|
||||||
|
line = (await this.readLineSlice()) as Uint8Array;
|
||||||
|
}
|
||||||
|
|
||||||
|
buf = await this.r.peek(1);
|
||||||
|
if (buf === null) {
|
||||||
|
throw new Deno.errors.UnexpectedEof();
|
||||||
|
} else if (WHITESPACES.includes(buf[0])) {
|
||||||
|
throw new Deno.errors.InvalidData(
|
||||||
|
`malformed MIME header initial line: ${str(line)}`,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
const kv = await this.readLineSlice(); // readContinuedLineSlice
|
||||||
|
if (kv === null) throw new Deno.errors.UnexpectedEof();
|
||||||
|
if (kv.byteLength === 0) return m;
|
||||||
|
|
||||||
|
// Key ends at first colon
|
||||||
|
let i = kv.indexOf(CHAR_COLON);
|
||||||
|
if (i < 0) {
|
||||||
|
throw new Deno.errors.InvalidData(
|
||||||
|
`malformed MIME header line: ${str(kv)}`,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
//let key = canonicalMIMEHeaderKey(kv.subarray(0, endKey));
|
||||||
|
const key = str(kv.subarray(0, i));
|
||||||
|
|
||||||
|
// As per RFC 7230 field-name is a token,
|
||||||
|
// tokens consist of one or more chars.
|
||||||
|
// We could throw `Deno.errors.InvalidData` here,
|
||||||
|
// but better to be liberal in what we
|
||||||
|
// accept, so if we get an empty key, skip it.
|
||||||
|
if (key == "") {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Skip initial spaces in value.
|
||||||
|
i++; // skip colon
|
||||||
|
while (
|
||||||
|
i < kv.byteLength &&
|
||||||
|
(WHITESPACES.includes(kv[i]))
|
||||||
|
) {
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
const value = str(kv.subarray(i)).replace(
|
||||||
|
invalidHeaderCharRegex,
|
||||||
|
encodeURI,
|
||||||
|
);
|
||||||
|
|
||||||
|
// In case of invalid header we swallow the error
|
||||||
|
// example: "Audio Mode" => invalid due to space in the key
|
||||||
|
try {
|
||||||
|
m.append(key, value);
|
||||||
|
} catch {
|
||||||
|
// Pass
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async readLineSlice(): Promise<Uint8Array | null> {
|
||||||
|
let line = new Uint8Array(0);
|
||||||
|
let r: ReadLineResult | null = null;
|
||||||
|
|
||||||
|
do {
|
||||||
|
r = await this.r.readLine();
|
||||||
|
// TODO(ry):
|
||||||
|
// This skipSpace() is definitely misplaced, but I don't know where it
|
||||||
|
// comes from nor how to fix it.
|
||||||
|
|
||||||
|
//TODO(SmashingQuasar): Kept skipSpace to preserve behavior but it should be looked into to check if it makes sense when this is used.
|
||||||
|
|
||||||
|
if (r !== null && this.skipSpace(r.line) !== 0) {
|
||||||
|
line = concat(line, r.line);
|
||||||
|
}
|
||||||
|
} while (r !== null && r.more);
|
||||||
|
|
||||||
|
return r === null ? null : line;
|
||||||
|
}
|
||||||
|
|
||||||
|
skipSpace(l: Uint8Array): number {
|
||||||
|
let n = 0;
|
||||||
|
|
||||||
|
for (const val of l) {
|
||||||
|
if (!WHITESPACES.includes(val)) {
|
||||||
|
n++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
}
|
6
cli/tests/testdata/run/tls_connecttls.js
vendored
6
cli/tests/testdata/run/tls_connecttls.js
vendored
|
@ -3,8 +3,8 @@ import {
|
||||||
assert,
|
assert,
|
||||||
assertEquals,
|
assertEquals,
|
||||||
} from "../../../../test_util/std/testing/asserts.ts";
|
} from "../../../../test_util/std/testing/asserts.ts";
|
||||||
import { BufReader, BufWriter } from "../../../../test_util/std/io/bufio.ts";
|
import { BufReader, BufWriter } from "../../../../test_util/std/io/buffer.ts";
|
||||||
import { TextProtoReader } from "../../../../test_util/std/textproto/mod.ts";
|
import { TextProtoReader } from "./textproto.ts";
|
||||||
|
|
||||||
const encoder = new TextEncoder();
|
const encoder = new TextEncoder();
|
||||||
const decoder = new TextDecoder();
|
const decoder = new TextDecoder();
|
||||||
|
@ -57,7 +57,7 @@ const [_, proto, status, ok] = m;
|
||||||
assertEquals(proto, "HTTP/1.1");
|
assertEquals(proto, "HTTP/1.1");
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
assertEquals(ok, "OK");
|
assertEquals(ok, "OK");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
const contentLength = parseInt(headers.get("content-length"));
|
const contentLength = parseInt(headers.get("content-length"));
|
||||||
const bodyBuf = new Uint8Array(contentLength);
|
const bodyBuf = new Uint8Array(contentLength);
|
||||||
|
|
6
cli/tests/testdata/run/tls_starttls.js
vendored
6
cli/tests/testdata/run/tls_starttls.js
vendored
|
@ -3,8 +3,8 @@ import {
|
||||||
assert,
|
assert,
|
||||||
assertEquals,
|
assertEquals,
|
||||||
} from "../../../../test_util/std/testing/asserts.ts";
|
} from "../../../../test_util/std/testing/asserts.ts";
|
||||||
import { BufReader, BufWriter } from "../../../../test_util/std/io/bufio.ts";
|
import { BufReader, BufWriter } from "../../../../test_util/std/io/buffer.ts";
|
||||||
import { TextProtoReader } from "../../../../test_util/std/textproto/mod.ts";
|
import { TextProtoReader } from "./textproto.ts";
|
||||||
|
|
||||||
const encoder = new TextEncoder();
|
const encoder = new TextEncoder();
|
||||||
const decoder = new TextDecoder();
|
const decoder = new TextDecoder();
|
||||||
|
@ -55,7 +55,7 @@ const [_, proto, status, ok] = m;
|
||||||
assertEquals(proto, "HTTP/1.1");
|
assertEquals(proto, "HTTP/1.1");
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
assertEquals(ok, "OK");
|
assertEquals(ok, "OK");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
const contentLength = parseInt(headers.get("content-length"));
|
const contentLength = parseInt(headers.get("content-length"));
|
||||||
const bodyBuf = new Uint8Array(contentLength);
|
const bodyBuf = new Uint8Array(contentLength);
|
||||||
|
|
|
@ -8,7 +8,7 @@ import {
|
||||||
assertRejects,
|
assertRejects,
|
||||||
assertThrows,
|
assertThrows,
|
||||||
} from "./test_util.ts";
|
} from "./test_util.ts";
|
||||||
import { copy } from "../../../test_util/std/io/util.ts";
|
import { copy } from "../../../test_util/std/streams/conversion.ts";
|
||||||
|
|
||||||
Deno.test(function filesStdioFileDescriptors() {
|
Deno.test(function filesStdioFileDescriptors() {
|
||||||
assertEquals(Deno.stdin.rid, 0);
|
assertEquals(Deno.stdin.rid, 0);
|
||||||
|
|
|
@ -7,7 +7,7 @@ import {
|
||||||
BufReader,
|
BufReader,
|
||||||
BufWriter,
|
BufWriter,
|
||||||
} from "../../../test_util/std/io/buffer.ts";
|
} from "../../../test_util/std/io/buffer.ts";
|
||||||
import { TextProtoReader } from "../../../test_util/std/textproto/mod.ts";
|
import { TextProtoReader } from "../testdata/run/textproto.ts";
|
||||||
import {
|
import {
|
||||||
assert,
|
assert,
|
||||||
assertEquals,
|
assertEquals,
|
||||||
|
@ -763,7 +763,7 @@ Deno.test(
|
||||||
const tpr = new TextProtoReader(r);
|
const tpr = new TextProtoReader(r);
|
||||||
const statusLine = await tpr.readLine();
|
const statusLine = await tpr.readLine();
|
||||||
assert(statusLine !== null);
|
assert(statusLine !== null);
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
|
|
||||||
const chunkedReader = chunkedBodyReader(headers, r);
|
const chunkedReader = chunkedBodyReader(headers, r);
|
||||||
|
@ -920,7 +920,7 @@ Deno.test(
|
||||||
assert(m !== null, "must be matched");
|
assert(m !== null, "must be matched");
|
||||||
const [_, _proto, status, _ok] = m;
|
const [_, _proto, status, _ok] = m;
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2342,7 +2342,7 @@ async function readTrailers(
|
||||||
if (trailers == null) return;
|
if (trailers == null) return;
|
||||||
const trailerNames = [...trailers.keys()];
|
const trailerNames = [...trailers.keys()];
|
||||||
const tp = new TextProtoReader(r);
|
const tp = new TextProtoReader(r);
|
||||||
const result = await tp.readMIMEHeader();
|
const result = await tp.readMimeHeader();
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
throw new Deno.errors.InvalidData("Missing trailer header.");
|
throw new Deno.errors.InvalidData("Missing trailer header.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import {
|
||||||
BufReader,
|
BufReader,
|
||||||
BufWriter,
|
BufWriter,
|
||||||
} from "../../../test_util/std/io/buffer.ts";
|
} from "../../../test_util/std/io/buffer.ts";
|
||||||
import { TextProtoReader } from "../../../test_util/std/textproto/mod.ts";
|
import { TextProtoReader } from "../testdata/run/textproto.ts";
|
||||||
import { serve, serveTls } from "../../../test_util/std/http/server.ts";
|
import { serve, serveTls } from "../../../test_util/std/http/server.ts";
|
||||||
import {
|
import {
|
||||||
assert,
|
assert,
|
||||||
|
@ -30,7 +30,7 @@ async function writeRequestAndReadResponse(conn: Deno.Conn): Promise<string> {
|
||||||
const tpr = new TextProtoReader(r);
|
const tpr = new TextProtoReader(r);
|
||||||
const statusLine = await tpr.readLine();
|
const statusLine = await tpr.readLine();
|
||||||
assert(statusLine !== null);
|
assert(statusLine !== null);
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
|
|
||||||
const chunkedReader = chunkedBodyReader(headers, r);
|
const chunkedReader = chunkedBodyReader(headers, r);
|
||||||
|
@ -605,7 +605,7 @@ Deno.test(
|
||||||
const tpr = new TextProtoReader(r);
|
const tpr = new TextProtoReader(r);
|
||||||
const statusLine = await tpr.readLine();
|
const statusLine = await tpr.readLine();
|
||||||
assert(statusLine !== null);
|
assert(statusLine !== null);
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
|
|
||||||
const chunkedReader = chunkedBodyReader(headers, r);
|
const chunkedReader = chunkedBodyReader(headers, r);
|
||||||
|
@ -751,7 +751,7 @@ Deno.test(
|
||||||
assert(m !== null, "must be matched");
|
assert(m !== null, "must be matched");
|
||||||
const [_, _proto, status, _ok] = m;
|
const [_, _proto, status, _ok] = m;
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2459,7 +2459,7 @@ async function readTrailers(
|
||||||
if (trailers == null) return;
|
if (trailers == null) return;
|
||||||
const trailerNames = [...trailers.keys()];
|
const trailerNames = [...trailers.keys()];
|
||||||
const tp = new TextProtoReader(r);
|
const tp = new TextProtoReader(r);
|
||||||
const result = await tp.readMIMEHeader();
|
const result = await tp.readMimeHeader();
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
throw new Deno.errors.InvalidData("Missing trailer header.");
|
throw new Deno.errors.InvalidData("Missing trailer header.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -95,18 +95,16 @@ Deno.test(
|
||||||
async function readFileWithAbortSignal() {
|
async function readFileWithAbortSignal() {
|
||||||
const ac = new AbortController();
|
const ac = new AbortController();
|
||||||
queueMicrotask(() => ac.abort());
|
queueMicrotask(() => ac.abort());
|
||||||
await assertRejects(
|
const error = await assertRejects(
|
||||||
async () => {
|
async () => {
|
||||||
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
||||||
signal: ac.signal,
|
signal: ac.signal,
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
(error: Error) => {
|
);
|
||||||
assert(error instanceof DOMException);
|
assert(error instanceof DOMException);
|
||||||
assertEquals(error.name, "AbortError");
|
assertEquals(error.name, "AbortError");
|
||||||
},
|
},
|
||||||
);
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
|
|
||||||
Deno.test(
|
Deno.test(
|
||||||
|
@ -115,16 +113,14 @@ Deno.test(
|
||||||
const ac = new AbortController();
|
const ac = new AbortController();
|
||||||
const abortReason = new Error();
|
const abortReason = new Error();
|
||||||
queueMicrotask(() => ac.abort(abortReason));
|
queueMicrotask(() => ac.abort(abortReason));
|
||||||
await assertRejects(
|
const error = await assertRejects(
|
||||||
async () => {
|
async () => {
|
||||||
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
||||||
signal: ac.signal,
|
signal: ac.signal,
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
(error: Error) => {
|
|
||||||
assertEquals(error, abortReason);
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
|
assertEquals(error, abortReason);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -91,18 +91,16 @@ Deno.test(
|
||||||
async function readTextFileWithAbortSignal() {
|
async function readTextFileWithAbortSignal() {
|
||||||
const ac = new AbortController();
|
const ac = new AbortController();
|
||||||
queueMicrotask(() => ac.abort());
|
queueMicrotask(() => ac.abort());
|
||||||
await assertRejects(
|
const error = await assertRejects(
|
||||||
async () => {
|
async () => {
|
||||||
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
||||||
signal: ac.signal,
|
signal: ac.signal,
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
(error: Error) => {
|
);
|
||||||
assert(error instanceof DOMException);
|
assert(error instanceof DOMException);
|
||||||
assertEquals(error.name, "AbortError");
|
assertEquals(error.name, "AbortError");
|
||||||
},
|
},
|
||||||
);
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
|
|
||||||
Deno.test(
|
Deno.test(
|
||||||
|
@ -111,16 +109,14 @@ Deno.test(
|
||||||
const ac = new AbortController();
|
const ac = new AbortController();
|
||||||
const abortReason = new Error();
|
const abortReason = new Error();
|
||||||
queueMicrotask(() => ac.abort(abortReason));
|
queueMicrotask(() => ac.abort(abortReason));
|
||||||
await assertRejects(
|
const error = await assertRejects(
|
||||||
async () => {
|
async () => {
|
||||||
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
await Deno.readFile("cli/tests/testdata/assets/fixture.json", {
|
||||||
signal: ac.signal,
|
signal: ac.signal,
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
(error: Error) => {
|
|
||||||
assertEquals(error, abortReason);
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
|
assertEquals(error, abortReason);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@ export {
|
||||||
export { deferred } from "../../../test_util/std/async/deferred.ts";
|
export { deferred } from "../../../test_util/std/async/deferred.ts";
|
||||||
export type { Deferred } from "../../../test_util/std/async/deferred.ts";
|
export type { Deferred } from "../../../test_util/std/async/deferred.ts";
|
||||||
export { delay } from "../../../test_util/std/async/delay.ts";
|
export { delay } from "../../../test_util/std/async/delay.ts";
|
||||||
export { readLines } from "../../../test_util/std/io/bufio.ts";
|
export { readLines } from "../../../test_util/std/io/buffer.ts";
|
||||||
export { parse as parseArgs } from "../../../test_util/std/flags/mod.ts";
|
export { parse as parseArgs } from "../../../test_util/std/flags/mod.ts";
|
||||||
|
|
||||||
export function pathToAbsoluteFileUrl(path: string): URL {
|
export function pathToAbsoluteFileUrl(path: string): URL {
|
||||||
|
|
|
@ -9,9 +9,9 @@ import {
|
||||||
Deferred,
|
Deferred,
|
||||||
deferred,
|
deferred,
|
||||||
} from "./test_util.ts";
|
} from "./test_util.ts";
|
||||||
import { BufReader, BufWriter } from "../../../test_util/std/io/bufio.ts";
|
import { BufReader, BufWriter } from "../../../test_util/std/io/buffer.ts";
|
||||||
import { readAll } from "../../../test_util/std/io/util.ts";
|
import { readAll } from "../../../test_util/std/streams/conversion.ts";
|
||||||
import { TextProtoReader } from "../../../test_util/std/textproto/mod.ts";
|
import { TextProtoReader } from "../testdata/run/textproto.ts";
|
||||||
|
|
||||||
const encoder = new TextEncoder();
|
const encoder = new TextEncoder();
|
||||||
const decoder = new TextDecoder();
|
const decoder = new TextDecoder();
|
||||||
|
@ -195,7 +195,7 @@ Deno.test(
|
||||||
assertEquals(proto, "HTTP/1.1");
|
assertEquals(proto, "HTTP/1.1");
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
assertEquals(ok, "OK");
|
assertEquals(ok, "OK");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
const contentLength = parseInt(headers.get("content-length")!);
|
const contentLength = parseInt(headers.get("content-length")!);
|
||||||
const bodyBuf = new Uint8Array(contentLength);
|
const bodyBuf = new Uint8Array(contentLength);
|
||||||
|
@ -248,7 +248,7 @@ Deno.test(
|
||||||
assertEquals(proto, "HTTP/1.1");
|
assertEquals(proto, "HTTP/1.1");
|
||||||
assertEquals(status, "200");
|
assertEquals(status, "200");
|
||||||
assertEquals(ok, "OK");
|
assertEquals(ok, "OK");
|
||||||
const headers = await tpr.readMIMEHeader();
|
const headers = await tpr.readMimeHeader();
|
||||||
assert(headers !== null);
|
assert(headers !== null);
|
||||||
const contentLength = parseInt(headers.get("content-length")!);
|
const contentLength = parseInt(headers.get("content-length")!);
|
||||||
const bodyBuf = new Uint8Array(contentLength);
|
const bodyBuf = new Uint8Array(contentLength);
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 28956f795762e8dd9b6213687ce32665319fa98a
|
Subproject commit 0ce558fec1a1beeda3ed7710c6507b9e991829c9
|
Loading…
Add table
Reference in a new issue