mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 04:52:26 -05:00
fix(streams): reject string
in ReadableStream.from
type (#25116)
WebIDL `async iterable<T>` type rejects `string` Ref https://github.com/whatwg/webidl/pull/1397, #24623
This commit is contained in:
parent
115a306656
commit
4330ef553f
8 changed files with 18 additions and 6 deletions
2
cli/tsc/dts/lib.dom.d.ts
vendored
2
cli/tsc/dts/lib.dom.d.ts
vendored
|
@ -18277,7 +18277,7 @@ declare var ReadableStream: {
|
||||||
new(underlyingSource: UnderlyingByteSource, strategy?: { highWaterMark?: number }): ReadableStream<Uint8Array>;
|
new(underlyingSource: UnderlyingByteSource, strategy?: { highWaterMark?: number }): ReadableStream<Uint8Array>;
|
||||||
new<R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>;
|
new<R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>;
|
||||||
new<R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>;
|
new<R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>;
|
||||||
from<R>(asyncIterable: AsyncIterable<R> | Iterable<R | PromiseLike<R>>): ReadableStream<R>;
|
from<R>(asyncIterable: AsyncIterable<R> | Iterable<R | PromiseLike<R>> & object): ReadableStream<R>;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** [MDN Reference](https://developer.mozilla.org/docs/Web/API/ReadableStreamBYOBReader) */
|
/** [MDN Reference](https://developer.mozilla.org/docs/Web/API/ReadableStreamBYOBReader) */
|
||||||
|
|
|
@ -2922,7 +2922,7 @@ function readableStreamPipeTo(
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param {ReadableStreamGenericReader<any> | ReadableStreamBYOBReader} reader
|
* @param {ReadableStreamGenericReader | ReadableStreamBYOBReader} reader
|
||||||
* @param {any} reason
|
* @param {any} reason
|
||||||
* @returns {Promise<void>}
|
* @returns {Promise<void>}
|
||||||
*/
|
*/
|
||||||
|
@ -2955,7 +2955,7 @@ function readableStreamReaderGenericInitialize(reader, stream) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @template R
|
* @template R
|
||||||
* @param {ReadableStreamGenericReader<R> | ReadableStreamBYOBReader} reader
|
* @param {ReadableStreamGenericReader | ReadableStreamBYOBReader} reader
|
||||||
*/
|
*/
|
||||||
function readableStreamReaderGenericRelease(reader) {
|
function readableStreamReaderGenericRelease(reader) {
|
||||||
const stream = reader[_stream];
|
const stream = reader[_stream];
|
||||||
|
|
4
ext/web/06_streams_types.d.ts
vendored
4
ext/web/06_streams_types.d.ts
vendored
|
@ -60,8 +60,8 @@ interface VoidFunction {
|
||||||
(): void;
|
(): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface ReadableStreamGenericReader<T> {
|
interface ReadableStreamGenericReader {
|
||||||
readonly closed: Promise<void>;
|
readonly closed: Promise<undefined>;
|
||||||
// deno-lint-ignore no-explicit-any
|
// deno-lint-ignore no-explicit-any
|
||||||
cancel(reason?: any): Promise<void>;
|
cancel(reason?: any): Promise<void>;
|
||||||
}
|
}
|
||||||
|
|
2
ext/web/lib.deno_web.d.ts
vendored
2
ext/web/lib.deno_web.d.ts
vendored
|
@ -882,7 +882,7 @@ declare var ReadableStream: {
|
||||||
strategy?: QueuingStrategy<R>,
|
strategy?: QueuingStrategy<R>,
|
||||||
): ReadableStream<R>;
|
): ReadableStream<R>;
|
||||||
from<R>(
|
from<R>(
|
||||||
asyncIterable: AsyncIterable<R> | Iterable<R | PromiseLike<R>>,
|
asyncIterable: AsyncIterable<R> | Iterable<R | PromiseLike<R>> & object,
|
||||||
): ReadableStream<R>;
|
): ReadableStream<R>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"args": "check ./main.ts",
|
||||||
|
"output": "main.out",
|
||||||
|
"exitCode": 1
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
Check [WILDCARD]/main.ts
|
||||||
|
error: TS2345 [ERROR]: Argument of type 'string' is not assignable to parameter of type 'AsyncIterable<string> | (Iterable<string | PromiseLike<string>> & object)'.
|
||||||
|
ReadableStream.from("string");
|
||||||
|
~~~~~~~~
|
||||||
|
at [WILDCARD]/main.ts:1:21
|
|
@ -0,0 +1 @@
|
||||||
|
ReadableStream.from("string");
|
|
@ -541,6 +541,7 @@ Deno.test(async function decompressionStreamInvalidGzipStillReported() {
|
||||||
|
|
||||||
Deno.test(function readableStreamFromWithStringThrows() {
|
Deno.test(function readableStreamFromWithStringThrows() {
|
||||||
assertThrows(
|
assertThrows(
|
||||||
|
// @ts-expect-error: primitives are not acceptable
|
||||||
() => ReadableStream.from("string"),
|
() => ReadableStream.from("string"),
|
||||||
TypeError,
|
TypeError,
|
||||||
"Failed to execute 'ReadableStream.from': Argument 1 can not be converted to async iterable.",
|
"Failed to execute 'ReadableStream.from': Argument 1 can not be converted to async iterable.",
|
||||||
|
|
Loading…
Add table
Reference in a new issue