blob: bda1031add16225602014bea2380032b632a9145 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
import { it, test, expect } from "bun:test";
import { spawn } from "bun";
import { bunExe } from "./bunExe";
import { gcTick } from "gc";
import { closeSync, openSync } from "fs";
import { bunEnv } from "./bunEnv";
test("spawn can read from stdout multiple chunks", async () => {
gcTick(true);
const maxFD = openSync("/dev/null", "w");
closeSync(maxFD);
for (let i = 0; i < 10; i++)
await (async function () {
var exited;
const proc = spawn({
cmd: [bunExe(), import.meta.dir + "/spawn-streaming-stdout-repro.js"],
stdin: "ignore",
stdout: "pipe",
stderr: "ignore",
env: bunEnv,
});
var chunks = [];
let counter = 0;
try {
for await (var chunk of proc.stdout) {
chunks.push(chunk);
counter++;
if (counter > 3) break;
}
} catch (e) {
console.log(e.stack);
throw e;
}
expect(counter).toBe(4);
// TODO: fix bug with returning SIGHUP instead of exit code 1
proc.kill();
expect(Buffer.concat(chunks).toString()).toBe("Wrote to stdout\n".repeat(4));
})();
const newMaxFD = openSync("/dev/null", "w");
closeSync(newMaxFD);
expect(newMaxFD).toBe(maxFD);
});
|