Merge pull request #84 from coder/missing-tests
commit
c7c9fa9279
@ -0,0 +1,12 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import { runTerraformInit, testRequiredVariables } from "../test";
|
||||||
|
|
||||||
|
describe("code-server", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
|
||||||
|
// More tests depend on shebang refactors
|
||||||
|
});
|
@ -0,0 +1,21 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
testRequiredVariables,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
describe("dotfiles", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
|
||||||
|
it("default output", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
expect(state.outputs.dotfiles_uri.value).toBe("");
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,43 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
testRequiredVariables,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
describe("gcp-region", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {});
|
||||||
|
|
||||||
|
it("default output", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {});
|
||||||
|
expect(state.outputs.value.value).toBe("");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("customized default", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
regions: '["asia"]',
|
||||||
|
default: "asia-east1-a",
|
||||||
|
});
|
||||||
|
expect(state.outputs.value.value).toBe("asia-east1-a");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("gpu only invalid default", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
regions: '["us-west2"]',
|
||||||
|
default: "us-west2-a",
|
||||||
|
gpu_only: "true",
|
||||||
|
});
|
||||||
|
expect(state.outputs.value.value).toBe("");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("gpu only valid default", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
regions: '["us-west2"]',
|
||||||
|
default: "us-west2-b",
|
||||||
|
gpu_only: "true",
|
||||||
|
});
|
||||||
|
expect(state.outputs.value.value).toBe("us-west2-b");
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,63 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
executeScriptInContainer,
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
testRequiredVariables,
|
||||||
|
findResourceInstance,
|
||||||
|
runContainer,
|
||||||
|
TerraformState,
|
||||||
|
execContainer,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
// executes the coder script after installing pip
|
||||||
|
const executeScriptInContainerWithPip = async (
|
||||||
|
state: TerraformState,
|
||||||
|
image: string,
|
||||||
|
shell: string = "sh",
|
||||||
|
): Promise<{
|
||||||
|
exitCode: number;
|
||||||
|
stdout: string[];
|
||||||
|
stderr: string[];
|
||||||
|
}> => {
|
||||||
|
const instance = findResourceInstance(state, "coder_script");
|
||||||
|
const id = await runContainer(image);
|
||||||
|
const respPip = await execContainer(id, [shell, "-c", "apk add py3-pip"]);
|
||||||
|
const resp = await execContainer(id, [shell, "-c", instance.script]);
|
||||||
|
const stdout = resp.stdout.trim().split("\n");
|
||||||
|
const stderr = resp.stderr.trim().split("\n");
|
||||||
|
return {
|
||||||
|
exitCode: resp.exitCode,
|
||||||
|
stdout,
|
||||||
|
stderr,
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
describe("jupyterlab", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
|
||||||
|
it("fails without pip3", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
const output = await executeScriptInContainer(state, "alpine");
|
||||||
|
expect(output.exitCode).toBe(1);
|
||||||
|
expect(output.stdout).toEqual([
|
||||||
|
"\u001B[0;1mInstalling jupyterlab!",
|
||||||
|
"pip3 is not installed",
|
||||||
|
"Please install pip3 in your Dockerfile/VM image before running this script",
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: Add faster test to run with pip3.
|
||||||
|
// currently times out.
|
||||||
|
// it("runs with pip3", async () => {
|
||||||
|
// ...
|
||||||
|
// const output = await executeScriptInContainerWithPip(state, "alpine");
|
||||||
|
// ...
|
||||||
|
// });
|
||||||
|
});
|
@ -0,0 +1,33 @@
|
|||||||
|
import { readableStreamToText, spawn } from "bun";
|
||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
executeScriptInContainer,
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
testRequiredVariables,
|
||||||
|
runContainer,
|
||||||
|
execContainer,
|
||||||
|
findResourceInstance,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
describe("personalize", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
|
||||||
|
it("warns without personalize script", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
const output = await executeScriptInContainer(state, "alpine");
|
||||||
|
expect(output.exitCode).toBe(0);
|
||||||
|
expect(output.stdout).toEqual([
|
||||||
|
"✨ \u001b[0;1mYou don't have a personalize script!",
|
||||||
|
"",
|
||||||
|
"Run \u001b[36;40;1mtouch ~/personalize && chmod +x ~/personalize\u001b[0m to create one.",
|
||||||
|
"It will run every time your workspace starts. Use it to install personal packages!",
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,24 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
executeScriptInContainer,
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
testRequiredVariables,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
describe("vscode-desktop", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
testRequiredVariables(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
|
||||||
|
it("default output", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
expect(state.outputs.vscode_url.value).toBe(
|
||||||
|
"vscode://coder.coder-remote/open?owner=default&workspace=default&token=$SESSION_TOKEN",
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,63 @@
|
|||||||
|
import { describe, expect, it } from "bun:test";
|
||||||
|
import {
|
||||||
|
executeScriptInContainer,
|
||||||
|
runTerraformApply,
|
||||||
|
runTerraformInit,
|
||||||
|
} from "../test";
|
||||||
|
|
||||||
|
describe("vscode-web", async () => {
|
||||||
|
await runTerraformInit(import.meta.dir);
|
||||||
|
|
||||||
|
// replaces testRequiredVariables due to license variable
|
||||||
|
// may add a testRequiredVariablesWithLicense function later
|
||||||
|
it("missing agent_id", async () => {
|
||||||
|
try {
|
||||||
|
await runTerraformApply(import.meta.dir, {
|
||||||
|
accept_license: "true",
|
||||||
|
});
|
||||||
|
} catch (ex) {
|
||||||
|
expect(ex.message).toContain('input variable "agent_id" is not set');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
it("invalid license_agreement", async () => {
|
||||||
|
try {
|
||||||
|
await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
});
|
||||||
|
} catch (ex) {
|
||||||
|
expect(ex.message).toContain(
|
||||||
|
"You must accept the VS Code license agreement by setting accept_license=true",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
it("fails without curl", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
accept_license: "true",
|
||||||
|
});
|
||||||
|
const output = await executeScriptInContainer(state, "alpine");
|
||||||
|
expect(output.exitCode).toBe(1);
|
||||||
|
expect(output.stdout).toEqual([
|
||||||
|
"\u001b[0;1mInstalling vscode-cli!",
|
||||||
|
"Failed to install vscode-cli:", // TODO: manually test error log
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("runs with curl", async () => {
|
||||||
|
const state = await runTerraformApply(import.meta.dir, {
|
||||||
|
agent_id: "foo",
|
||||||
|
accept_license: "true",
|
||||||
|
});
|
||||||
|
const output = await executeScriptInContainer(state, "alpine/curl");
|
||||||
|
expect(output.exitCode).toBe(0);
|
||||||
|
expect(output.stdout).toEqual([
|
||||||
|
"\u001b[0;1mInstalling vscode-cli!",
|
||||||
|
"🥳 vscode-cli has been installed.",
|
||||||
|
"",
|
||||||
|
"👷 Running /tmp/vscode-cli/bin/code serve-web --port 13338 --without-connection-token --accept-server-license-terms in the background...",
|
||||||
|
"Check logs at /tmp/vscode-web.log!",
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in New Issue