2019-10-25 19:23:16 +02:00
|
|
|
import {
|
|
|
|
assert,
|
|
|
|
assertEquals,
|
|
|
|
assertMatch,
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest,
|
2020-03-29 04:03:49 +11:00
|
|
|
unreachable,
|
2019-10-25 19:23:16 +02:00
|
|
|
} from "./test_util.ts";
|
|
|
|
|
|
|
|
const readErrorStackPattern = new RegExp(
|
|
|
|
`^.*
|
|
|
|
at unwrapResponse \\(.*dispatch_minimal\\.ts:.*\\)
|
2020-02-05 08:23:23 +00:00
|
|
|
at Object.sendAsyncMinimal \\(.*dispatch_minimal\\.ts:.*\\)
|
2020-03-09 15:18:02 +01:00
|
|
|
at async Object\\.read \\(.*io\\.ts:.*\\).*$`,
|
2019-10-25 19:23:16 +02:00
|
|
|
"ms"
|
|
|
|
);
|
|
|
|
|
2020-03-04 17:31:14 +01:00
|
|
|
unitTest(async function sendAsyncStackTrace(): Promise<void> {
|
2019-10-25 19:23:16 +02:00
|
|
|
const buf = new Uint8Array(10);
|
2020-02-25 09:14:27 -05:00
|
|
|
const rid = 10;
|
2020-02-05 08:23:23 +00:00
|
|
|
try {
|
2020-02-25 09:14:27 -05:00
|
|
|
await Deno.read(rid, buf);
|
2020-02-05 08:23:23 +00:00
|
|
|
unreachable();
|
|
|
|
} catch (error) {
|
|
|
|
assertMatch(error.stack, readErrorStackPattern);
|
|
|
|
}
|
2019-10-25 19:23:16 +02:00
|
|
|
});
|
2020-02-05 08:23:23 +00:00
|
|
|
|
2020-03-20 14:38:34 +01:00
|
|
|
unitTest(function malformedMinimalControlBuffer(): void {
|
2019-10-25 19:23:16 +02:00
|
|
|
// @ts-ignore
|
2020-02-25 09:14:27 -05:00
|
|
|
const readOpId = Deno.core.ops()["op_read"];
|
2020-02-05 08:23:23 +00:00
|
|
|
// @ts-ignore
|
|
|
|
const res = Deno.core.send(readOpId, new Uint8Array([1, 2, 3, 4, 5]));
|
2019-10-25 19:23:16 +02:00
|
|
|
const header = res.slice(0, 12);
|
|
|
|
const buf32 = new Int32Array(
|
|
|
|
header.buffer,
|
|
|
|
header.byteOffset,
|
|
|
|
header.byteLength / 4
|
|
|
|
);
|
|
|
|
const arg = buf32[1];
|
2020-02-05 08:23:23 +00:00
|
|
|
const message = new TextDecoder().decode(res.slice(12)).trim();
|
2019-10-25 19:23:16 +02:00
|
|
|
assert(arg < 0);
|
|
|
|
assertEquals(message, "Unparsable control buffer");
|
|
|
|
});
|