summaryrefslogtreecommitdiff
path: root/cli/tests/testdata/run/stdout_write_all.ts
diff options
context:
space:
mode:
authorDavid Sherret <dsherret@users.noreply.github.com>2022-07-13 11:16:42 -0400
committerGitHub <noreply@github.com>2022-07-13 11:16:42 -0400
commit667812a297a538863695c20bf5d8228301298db5 (patch)
treed6f884ee4f0102831283f077ffd5d797a9eada5e /cli/tests/testdata/run/stdout_write_all.ts
parent7470b2d2a765396a283bfd169b5fa9bacf0c01d0 (diff)
fix(cli): synchronize async stdio/file reads and writes (#15092)
Fixes a regression where async writes and reads could get out of order.
Diffstat (limited to 'cli/tests/testdata/run/stdout_write_all.ts')
-rw-r--r--cli/tests/testdata/run/stdout_write_all.ts13
1 files changed, 13 insertions, 0 deletions
diff --git a/cli/tests/testdata/run/stdout_write_all.ts b/cli/tests/testdata/run/stdout_write_all.ts
new file mode 100644
index 000000000..cfb2981e4
--- /dev/null
+++ b/cli/tests/testdata/run/stdout_write_all.ts
@@ -0,0 +1,13 @@
+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 < 100; i++) {
+ pending.push(Deno.stdout.write(encoder.encode("Hello, ")));
+ pending.push(Deno.stdout.write(encoder.encode(`world! ${i}`)));
+ pending.push(Deno.stdout.write(encoder.encode("\n")));
+}
+
+await Promise.all(pending);