diff options
author | haturau <135221985+haturatu@users.noreply.github.com> | 2024-11-20 01:20:47 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-11-20 01:20:47 +0900 |
commit | 85719a67e59c7aa45bead26e4942d7df8b1b42d4 (patch) | |
tree | face0aecaac53e93ce2f23b53c48859bcf1a36ec /tests/specs/run/stdin_read_all | |
parent | 67697bc2e4a62a9670699fd18ad0dd8efc5bd955 (diff) | |
parent | 186b52731c6bb326c4d32905c5e732d082e83465 (diff) |
Merge branch 'denoland:main' into main
Diffstat (limited to 'tests/specs/run/stdin_read_all')
-rw-r--r-- | tests/specs/run/stdin_read_all/__test__.jsonc | 5 | ||||
-rw-r--r-- | tests/specs/run/stdin_read_all/stdin_read_all.out | 1 | ||||
-rw-r--r-- | tests/specs/run/stdin_read_all/stdin_read_all.ts | 17 |
3 files changed, 23 insertions, 0 deletions
diff --git a/tests/specs/run/stdin_read_all/__test__.jsonc b/tests/specs/run/stdin_read_all/__test__.jsonc new file mode 100644 index 000000000..6fc035aab --- /dev/null +++ b/tests/specs/run/stdin_read_all/__test__.jsonc @@ -0,0 +1,5 @@ +{ + "args": "run --quiet stdin_read_all.ts", + "output": "stdin_read_all.out", + "input": "01234567890123456789012345678901234567890123456789" +} diff --git a/tests/specs/run/stdin_read_all/stdin_read_all.out b/tests/specs/run/stdin_read_all/stdin_read_all.out new file mode 100644 index 000000000..2f0dfb71a --- /dev/null +++ b/tests/specs/run/stdin_read_all/stdin_read_all.out @@ -0,0 +1 @@ +01234567890123456789012345678901234567890123456789 diff --git a/tests/specs/run/stdin_read_all/stdin_read_all.ts b/tests/specs/run/stdin_read_all/stdin_read_all.ts new file mode 100644 index 000000000..d683a2bf6 --- /dev/null +++ b/tests/specs/run/stdin_read_all/stdin_read_all.ts @@ -0,0 +1,17 @@ +const encoder = new TextEncoder(); + +const pending = []; + +// do this a bunch of times to ensure it doesn't race +// and everything happens in order +for (let i = 0; i < 50; i++) { + const buf = new Uint8Array(1); + pending.push( + Deno.stdin.read(buf).then(() => { + return Deno.stdout.write(buf); + }), + ); +} + +await Promise.all(pending); +await Deno.stdout.write(encoder.encode("\n")); |