mirror of
https://github.com/denoland/deno.git
synced 2025-01-09 23:58:23 -05:00
92ebf4afe5
This commit adds unstable "Deno.openKv()" API that allows to open a key-value database at a specified path. --------- Co-authored-by: Luca Casonato <hello@lcas.dev> Co-authored-by: Bartek Iwańczuk <biwanczuk@gmail.com>
83 lines
2.2 KiB
TypeScript
83 lines
2.2 KiB
TypeScript
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
|
|
import * as colors from "../../../test_util/std/fmt/colors.ts";
|
|
export { colors };
|
|
import { resolve } from "../../../test_util/std/path/mod.ts";
|
|
export {
|
|
assert,
|
|
assertEquals,
|
|
assertFalse,
|
|
AssertionError,
|
|
assertMatch,
|
|
assertNotEquals,
|
|
assertNotStrictEquals,
|
|
assertRejects,
|
|
assertStrictEquals,
|
|
assertStringIncludes,
|
|
assertThrows,
|
|
fail,
|
|
unimplemented,
|
|
unreachable,
|
|
} from "../../../test_util/std/testing/asserts.ts";
|
|
export { deferred } from "../../../test_util/std/async/deferred.ts";
|
|
export type { Deferred } from "../../../test_util/std/async/deferred.ts";
|
|
export { delay } from "../../../test_util/std/async/delay.ts";
|
|
export { readLines } from "../../../test_util/std/io/read_lines.ts";
|
|
export { parse as parseArgs } from "../../../test_util/std/flags/mod.ts";
|
|
|
|
export function pathToAbsoluteFileUrl(path: string): URL {
|
|
path = resolve(path);
|
|
|
|
return new URL(`file://${Deno.build.os === "windows" ? "/" : ""}${path}`);
|
|
}
|
|
|
|
export function execCode(code: string): Promise<readonly [number, string]> {
|
|
return execCode2(code).finished();
|
|
}
|
|
|
|
export function execCode2(code: string) {
|
|
const command = new Deno.Command(Deno.execPath(), {
|
|
args: [
|
|
"eval",
|
|
"--unstable",
|
|
"--no-check",
|
|
code,
|
|
],
|
|
stdout: "piped",
|
|
stderr: "inherit",
|
|
});
|
|
|
|
const child = command.spawn();
|
|
const stdout = child.stdout.pipeThrough(new TextDecoderStream()).getReader();
|
|
let output = "";
|
|
|
|
return {
|
|
async waitStdoutText(text: string) {
|
|
while (true) {
|
|
const readData = await stdout.read();
|
|
if (readData.value) {
|
|
output += readData.value;
|
|
if (output.includes(text)) {
|
|
return;
|
|
}
|
|
}
|
|
if (readData.done) {
|
|
throw new Error(`Did not find text '${text}' in stdout.`);
|
|
}
|
|
}
|
|
},
|
|
async finished() {
|
|
while (true) {
|
|
const readData = await stdout.read();
|
|
if (readData.value) {
|
|
output += readData.value;
|
|
}
|
|
if (readData.done) {
|
|
break;
|
|
}
|
|
}
|
|
const status = await child.status;
|
|
return [status.code, output] as const;
|
|
},
|
|
};
|
|
}
|