alpic 1.96.0 → 1.97.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/deployment-inspect.e2e.test.d.ts +1 -0
- package/dist/__tests__/deployment-inspect.e2e.test.js +113 -0
- package/dist/__tests__/deployment-inspect.e2e.test.js.map +1 -0
- package/dist/__tests__/deployment-list.e2e.test.d.ts +1 -0
- package/dist/__tests__/deployment-list.e2e.test.js +108 -0
- package/dist/__tests__/deployment-list.e2e.test.js.map +1 -0
- package/dist/__tests__/deployment-logs.e2e.test.d.ts +1 -0
- package/dist/__tests__/deployment-logs.e2e.test.js +180 -0
- package/dist/__tests__/deployment-logs.e2e.test.js.map +1 -0
- package/dist/__tests__/mock-server.d.ts +9 -0
- package/dist/__tests__/mock-server.js +32 -2
- package/dist/__tests__/mock-server.js.map +1 -1
- package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
- package/dist/__tests__/tunnel.e2e.test.js +64 -0
- package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
- package/dist/__tests__/utils.d.ts +2 -0
- package/dist/__tests__/utils.js +17 -0
- package/dist/__tests__/utils.js.map +1 -1
- package/dist/commands/deployment/inspect.d.ts +11 -0
- package/dist/commands/deployment/inspect.js +68 -0
- package/dist/commands/deployment/inspect.js.map +1 -0
- package/dist/commands/deployment/list.d.ts +11 -0
- package/dist/commands/deployment/list.js +85 -0
- package/dist/commands/deployment/list.js.map +1 -0
- package/dist/commands/deployment/logs.d.ts +12 -0
- package/dist/commands/deployment/logs.js +48 -0
- package/dist/commands/deployment/logs.js.map +1 -0
- package/dist/commands/tunnel.d.ts +9 -0
- package/dist/commands/tunnel.js +45 -0
- package/dist/commands/tunnel.js.map +1 -0
- package/dist/lib/deployment.d.ts +68 -0
- package/dist/lib/deployment.js +102 -1
- package/dist/lib/deployment.js.map +1 -1
- package/dist/lib/logs.d.ts +1 -0
- package/dist/lib/logs.js +6 -3
- package/dist/lib/logs.js.map +1 -1
- package/dist/lib/project.d.ts +3 -0
- package/dist/lib/project.js +11 -0
- package/dist/lib/project.js.map +1 -1
- package/dist/lib/utils.d.ts +4 -1
- package/dist/lib/utils.js +16 -12
- package/dist/lib/utils.js.map +1 -1
- package/dist/lib/utils.test.js +13 -6
- package/dist/lib/utils.test.js.map +1 -1
- package/package.json +10 -9
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { rmSync } from "node:fs";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { MockApiServer } from "./mock-server.js";
|
|
4
|
+
import { buildMockDeployment, buildMockProject, cliSession, expectSuccessfulApiCall, setupTestDirectory, } from "./utils.js";
|
|
5
|
+
describe("alpic deployment inspect (E2E)", () => {
|
|
6
|
+
let mockServer;
|
|
7
|
+
let serverUrl;
|
|
8
|
+
let cwd;
|
|
9
|
+
let binPath;
|
|
10
|
+
const projectId = "test-project-id";
|
|
11
|
+
const teamId = "mock-team-id";
|
|
12
|
+
const environmentId = "test-env-id";
|
|
13
|
+
const environmentName = "production";
|
|
14
|
+
beforeEach(async () => {
|
|
15
|
+
mockServer = new MockApiServer();
|
|
16
|
+
serverUrl = await mockServer.start();
|
|
17
|
+
const setup = await setupTestDirectory();
|
|
18
|
+
cwd = setup.cwd;
|
|
19
|
+
binPath = setup.binPath;
|
|
20
|
+
mockServer.addProject(buildMockProject({
|
|
21
|
+
projectId,
|
|
22
|
+
teamId,
|
|
23
|
+
projectName: "test-project",
|
|
24
|
+
environmentId,
|
|
25
|
+
environmentName,
|
|
26
|
+
}));
|
|
27
|
+
});
|
|
28
|
+
afterEach(async () => {
|
|
29
|
+
await mockServer.stop();
|
|
30
|
+
if (cwd) {
|
|
31
|
+
rmSync(cwd, { recursive: true, force: true });
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
it("displays deployment details with --deployment-id", async () => {
|
|
35
|
+
const deploymentId = "dpl_inspect_test";
|
|
36
|
+
const startedAt = new Date(Date.now() - 120_000);
|
|
37
|
+
mockServer.addDeployments([
|
|
38
|
+
buildMockDeployment({
|
|
39
|
+
id: deploymentId,
|
|
40
|
+
sourceCommitMessage: "Fix production bug",
|
|
41
|
+
startedAt,
|
|
42
|
+
completedAt: new Date(startedAt.getTime() + 60_000),
|
|
43
|
+
environmentId,
|
|
44
|
+
environmentName,
|
|
45
|
+
}),
|
|
46
|
+
]);
|
|
47
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "inspect", "--deployment-id", deploymentId], {
|
|
48
|
+
cwd,
|
|
49
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
50
|
+
}, async (cli) => {
|
|
51
|
+
await cli.expect("deployed");
|
|
52
|
+
});
|
|
53
|
+
expect(exitCode).toBe(0);
|
|
54
|
+
const startIdx = output.indexOf("Deployment found");
|
|
55
|
+
expect(startIdx).toBeGreaterThanOrEqual(0);
|
|
56
|
+
expect(output.slice(startIdx)).toMatchSnapshot();
|
|
57
|
+
const getCall = mockServer.getLastCall("GET", `/v1/deployments/${deploymentId}`);
|
|
58
|
+
expectSuccessfulApiCall(getCall);
|
|
59
|
+
});
|
|
60
|
+
it("resolves latest deployment with --environment-id", async () => {
|
|
61
|
+
const deploymentId = "dpl_env_lookup";
|
|
62
|
+
mockServer.addDeployments([
|
|
63
|
+
buildMockDeployment({
|
|
64
|
+
id: deploymentId,
|
|
65
|
+
authorUsername: "bob",
|
|
66
|
+
environmentId,
|
|
67
|
+
environmentName,
|
|
68
|
+
}),
|
|
69
|
+
]);
|
|
70
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "inspect", "--environment-id", environmentId], {
|
|
71
|
+
cwd,
|
|
72
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
73
|
+
}, async (cli) => {
|
|
74
|
+
await cli.expect("deployed");
|
|
75
|
+
});
|
|
76
|
+
expect(exitCode).toBe(0);
|
|
77
|
+
expect(output).toContain(deploymentId);
|
|
78
|
+
expect(output).toContain(environmentName);
|
|
79
|
+
expect(output).toContain("bob");
|
|
80
|
+
});
|
|
81
|
+
it("waits for an ongoing deployment with --wait", async () => {
|
|
82
|
+
const deploymentId = "dpl_ongoing";
|
|
83
|
+
mockServer.addDeployments([
|
|
84
|
+
buildMockDeployment({
|
|
85
|
+
id: deploymentId,
|
|
86
|
+
status: "ongoing",
|
|
87
|
+
startedAt: new Date(),
|
|
88
|
+
completedAt: null,
|
|
89
|
+
isCurrent: false,
|
|
90
|
+
environmentId,
|
|
91
|
+
environmentName,
|
|
92
|
+
}),
|
|
93
|
+
]);
|
|
94
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "inspect", "--deployment-id", deploymentId, "--wait"], {
|
|
95
|
+
cwd,
|
|
96
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
97
|
+
}, async (cli) => {
|
|
98
|
+
await cli.expect("deployed");
|
|
99
|
+
});
|
|
100
|
+
expect(exitCode).toBe(0);
|
|
101
|
+
expect(output).toContain("deployed");
|
|
102
|
+
});
|
|
103
|
+
it("exits with error when deployment is not found", async () => {
|
|
104
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "deployment", "inspect", "--deployment-id", "dpl_does_not_exist"], {
|
|
105
|
+
cwd,
|
|
106
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
107
|
+
}, async (cli) => {
|
|
108
|
+
await cli.expect(/error|not found/i);
|
|
109
|
+
});
|
|
110
|
+
expect(exitCode).not.toBe(0);
|
|
111
|
+
});
|
|
112
|
+
}, 15_000);
|
|
113
|
+
//# sourceMappingURL=deployment-inspect.e2e.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deployment-inspect.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/deployment-inspect.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { rmSync } from "node:fs";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { MockApiServer } from "./mock-server.js";
|
|
4
|
+
import { buildMockDeployment, buildMockProject, cliSession, expectSuccessfulApiCall, setupTestDirectory, } from "./utils.js";
|
|
5
|
+
describe("alpic deployment list (E2E)", () => {
|
|
6
|
+
let mockServer;
|
|
7
|
+
let serverUrl;
|
|
8
|
+
let cwd;
|
|
9
|
+
let binPath;
|
|
10
|
+
const projectId = "test-project-id";
|
|
11
|
+
const teamId = "mock-team-id";
|
|
12
|
+
const environmentId = "test-env-id";
|
|
13
|
+
const environmentName = "production";
|
|
14
|
+
beforeEach(async () => {
|
|
15
|
+
mockServer = new MockApiServer();
|
|
16
|
+
serverUrl = await mockServer.start();
|
|
17
|
+
const setup = await setupTestDirectory();
|
|
18
|
+
cwd = setup.cwd;
|
|
19
|
+
binPath = setup.binPath;
|
|
20
|
+
mockServer.addProject(buildMockProject({
|
|
21
|
+
projectId,
|
|
22
|
+
teamId,
|
|
23
|
+
projectName: "test-project",
|
|
24
|
+
environmentId,
|
|
25
|
+
environmentName,
|
|
26
|
+
}));
|
|
27
|
+
});
|
|
28
|
+
afterEach(async () => {
|
|
29
|
+
await mockServer.stop();
|
|
30
|
+
if (cwd) {
|
|
31
|
+
rmSync(cwd, { recursive: true, force: true });
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
it("renders deployment rows correctly", async () => {
|
|
35
|
+
const sevenDaysAgo = new Date(Date.now() - 7 * 24 * 60 * 60 * 1000);
|
|
36
|
+
const thirteenDaysAgo = new Date(Date.now() - 13 * 24 * 60 * 60 * 1000);
|
|
37
|
+
mockServer.addDeployments([
|
|
38
|
+
buildMockDeployment({
|
|
39
|
+
id: "dpl_test_deployed",
|
|
40
|
+
startedAt: sevenDaysAgo,
|
|
41
|
+
completedAt: new Date(sevenDaysAgo.getTime() + 116_000),
|
|
42
|
+
environmentId,
|
|
43
|
+
environmentName,
|
|
44
|
+
}),
|
|
45
|
+
buildMockDeployment({
|
|
46
|
+
id: "dpl_test_canceled",
|
|
47
|
+
status: "canceled",
|
|
48
|
+
sourceCommitId: "def5678",
|
|
49
|
+
sourceCommitMessage: "Cancel deployment",
|
|
50
|
+
authorUsername: null,
|
|
51
|
+
startedAt: thirteenDaysAgo,
|
|
52
|
+
completedAt: new Date(thirteenDaysAgo.getTime() + 12_000),
|
|
53
|
+
isCurrent: false,
|
|
54
|
+
environmentId,
|
|
55
|
+
environmentName,
|
|
56
|
+
}),
|
|
57
|
+
]);
|
|
58
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "list", "--project-id", projectId], {
|
|
59
|
+
cwd,
|
|
60
|
+
env: {
|
|
61
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
62
|
+
ALPIC_API_KEY: "test-api-key",
|
|
63
|
+
},
|
|
64
|
+
}, async (cli) => {
|
|
65
|
+
await cli.expect("Found 2 deployments");
|
|
66
|
+
});
|
|
67
|
+
expect(exitCode).toBe(0);
|
|
68
|
+
const normalizedOutput = output.replace(/^.*Fetching deployments\.\.\.\r?\n?/gm, "");
|
|
69
|
+
expect(normalizedOutput).toMatchSnapshot();
|
|
70
|
+
const listCall = mockServer.getLastCall("GET", `/v1/projects/${projectId}/deployments`);
|
|
71
|
+
expectSuccessfulApiCall(listCall);
|
|
72
|
+
});
|
|
73
|
+
it("passes environment-id filter to the API server-side", async () => {
|
|
74
|
+
const otherEnvironmentId = "other-env-id";
|
|
75
|
+
mockServer.addDeployments([
|
|
76
|
+
buildMockDeployment({ environmentId, environmentName, id: "dpl_env_match" }),
|
|
77
|
+
buildMockDeployment({ environmentId: otherEnvironmentId, environmentName: "staging", id: "dpl_env_other" }),
|
|
78
|
+
]);
|
|
79
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "list", "--project-id", projectId, "--environment-id", environmentId], {
|
|
80
|
+
cwd,
|
|
81
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
82
|
+
}, async (cli) => {
|
|
83
|
+
await cli.expect("Found 1 deployment");
|
|
84
|
+
});
|
|
85
|
+
expect(exitCode).toBe(0);
|
|
86
|
+
expect(output).toContain("dpl_env_match");
|
|
87
|
+
expect(output).not.toContain("dpl_env_other");
|
|
88
|
+
const listCall = mockServer.getLastCall("GET", `/v1/projects/${projectId}/deployments`);
|
|
89
|
+
expectSuccessfulApiCall(listCall);
|
|
90
|
+
expect(listCall?.input).toMatchObject({ environmentId });
|
|
91
|
+
});
|
|
92
|
+
it("passes status filter to the API", async () => {
|
|
93
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "deployment", "list", "--project-id", projectId, "--status", "deployed", "--status", "failed"], {
|
|
94
|
+
cwd,
|
|
95
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
96
|
+
}, async (cli) => {
|
|
97
|
+
await cli.expect("Found 0 deployments");
|
|
98
|
+
});
|
|
99
|
+
expect(exitCode).toBe(0);
|
|
100
|
+
const listCall = mockServer.getLastCall("GET", `/v1/projects/${projectId}/deployments`);
|
|
101
|
+
expectSuccessfulApiCall(listCall);
|
|
102
|
+
expect(listCall?.input).toMatchObject({
|
|
103
|
+
"status[0]": "deployed",
|
|
104
|
+
"status[1]": "failed",
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
}, 15_000);
|
|
108
|
+
//# sourceMappingURL=deployment-list.e2e.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deployment-list.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/deployment-list.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { rmSync } from "node:fs";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { MockApiServer } from "./mock-server.js";
|
|
4
|
+
import { buildMockDeployment, buildMockProject, cliSession, createConfigFile, expectSuccessfulApiCall, setupTestDirectory, } from "./utils.js";
|
|
5
|
+
const DEPLOYMENT_ID = "dpl_logs_test";
|
|
6
|
+
const PROJECT_ID = "prj-logs-test";
|
|
7
|
+
const TEAM_ID = "mock-team-id";
|
|
8
|
+
const ENVIRONMENT_ID = "env-logs-test";
|
|
9
|
+
describe("alpic deployment logs (E2E)", () => {
|
|
10
|
+
let mockServer;
|
|
11
|
+
let serverUrl;
|
|
12
|
+
let cwd;
|
|
13
|
+
let binPath;
|
|
14
|
+
beforeEach(async () => {
|
|
15
|
+
mockServer = new MockApiServer();
|
|
16
|
+
serverUrl = await mockServer.start();
|
|
17
|
+
const setup = await setupTestDirectory();
|
|
18
|
+
cwd = setup.cwd;
|
|
19
|
+
binPath = setup.binPath;
|
|
20
|
+
mockServer.addProject(buildMockProject({
|
|
21
|
+
projectId: PROJECT_ID,
|
|
22
|
+
teamId: TEAM_ID,
|
|
23
|
+
projectName: "logs-project",
|
|
24
|
+
environmentId: ENVIRONMENT_ID,
|
|
25
|
+
environmentName: "production",
|
|
26
|
+
}));
|
|
27
|
+
mockServer.addDeployments([
|
|
28
|
+
buildMockDeployment({
|
|
29
|
+
id: DEPLOYMENT_ID,
|
|
30
|
+
environmentId: ENVIRONMENT_ID,
|
|
31
|
+
environmentName: "production",
|
|
32
|
+
}),
|
|
33
|
+
]);
|
|
34
|
+
});
|
|
35
|
+
afterEach(async () => {
|
|
36
|
+
await mockServer.stop();
|
|
37
|
+
if (cwd)
|
|
38
|
+
rmSync(cwd, { recursive: true, force: true });
|
|
39
|
+
});
|
|
40
|
+
it("fetches and prints logs for a given --deployment-id", async () => {
|
|
41
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
42
|
+
{
|
|
43
|
+
logs: [
|
|
44
|
+
{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Installing dependencies..." },
|
|
45
|
+
{ timestamp: new Date("2024-06-01T12:00:01.000Z"), content: "Build succeeded" },
|
|
46
|
+
],
|
|
47
|
+
hasMoreLogs: false,
|
|
48
|
+
},
|
|
49
|
+
]);
|
|
50
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" } });
|
|
51
|
+
expect(exitCode).toBe(0);
|
|
52
|
+
expect(output).toContain("Installing dependencies...");
|
|
53
|
+
expect(output).toContain("Build succeeded");
|
|
54
|
+
const call = mockServer.getLastCall("GET", /\/v1\/deployments\/.*\/logs/);
|
|
55
|
+
expectSuccessfulApiCall(call);
|
|
56
|
+
});
|
|
57
|
+
it("polls and streams new logs with --follow, stops when hasMoreLogs is false", async () => {
|
|
58
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
59
|
+
{
|
|
60
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Step 1" }],
|
|
61
|
+
hasMoreLogs: true,
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
logs: [
|
|
65
|
+
{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Step 1" },
|
|
66
|
+
{ timestamp: new Date("2024-06-01T12:00:01.000Z"), content: "Step 2" },
|
|
67
|
+
],
|
|
68
|
+
hasMoreLogs: true,
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
logs: [
|
|
72
|
+
{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Step 1" },
|
|
73
|
+
{ timestamp: new Date("2024-06-01T12:00:01.000Z"), content: "Step 2" },
|
|
74
|
+
{ timestamp: new Date("2024-06-01T12:00:02.000Z"), content: "Step 3 - done" },
|
|
75
|
+
],
|
|
76
|
+
hasMoreLogs: false,
|
|
77
|
+
},
|
|
78
|
+
]);
|
|
79
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID, "--follow"], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" }, timeoutMs: 15_000 });
|
|
80
|
+
expect(exitCode).toBe(0);
|
|
81
|
+
expect(output).toContain("Step 1");
|
|
82
|
+
expect(output).toContain("Step 2");
|
|
83
|
+
expect(output).toContain("Step 3 - done");
|
|
84
|
+
const calls = mockServer.getCalls("GET", /\/v1\/deployments\/.*\/logs/);
|
|
85
|
+
expect(calls.length).toBe(3);
|
|
86
|
+
});
|
|
87
|
+
it("does not duplicate logs when polling with --follow", async () => {
|
|
88
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
89
|
+
{
|
|
90
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Only once" }],
|
|
91
|
+
hasMoreLogs: true,
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
logs: [
|
|
95
|
+
{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Only once" },
|
|
96
|
+
{ timestamp: new Date("2024-06-01T12:00:01.000Z"), content: "Second entry" },
|
|
97
|
+
],
|
|
98
|
+
hasMoreLogs: false,
|
|
99
|
+
},
|
|
100
|
+
]);
|
|
101
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID, "--follow"], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" }, timeoutMs: 15_000 });
|
|
102
|
+
expect(exitCode).toBe(0);
|
|
103
|
+
const occurrences = (output.match(/Only once/g) ?? []).length;
|
|
104
|
+
expect(occurrences).toBe(1);
|
|
105
|
+
});
|
|
106
|
+
it("exits immediately without --follow when hasMoreLogs is true", async () => {
|
|
107
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
108
|
+
{
|
|
109
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Partial build log" }],
|
|
110
|
+
hasMoreLogs: true,
|
|
111
|
+
},
|
|
112
|
+
]);
|
|
113
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" } });
|
|
114
|
+
expect(exitCode).toBe(0);
|
|
115
|
+
expect(output).toContain("Partial build log");
|
|
116
|
+
const calls = mockServer.getCalls("GET", /\/v1\/deployments\/.*\/logs/);
|
|
117
|
+
expect(calls.length).toBe(1);
|
|
118
|
+
});
|
|
119
|
+
it("strips ANSI codes from log content with --no-color", async () => {
|
|
120
|
+
// Content contains ANSI escape codes as CodeBuild tools (npm, tsc, etc.) often emit
|
|
121
|
+
const redText = "\x1b[31mBuild failed\x1b[0m";
|
|
122
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
123
|
+
{
|
|
124
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: redText }],
|
|
125
|
+
hasMoreLogs: false,
|
|
126
|
+
},
|
|
127
|
+
]);
|
|
128
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID, "--no-color"], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" } });
|
|
129
|
+
expect(exitCode).toBe(0);
|
|
130
|
+
expect(output).toContain("2024-06-01 12:00:00.000 Build failed");
|
|
131
|
+
expect(output).not.toContain("\x1b[31m");
|
|
132
|
+
});
|
|
133
|
+
it("exits with error when deployment is not found", async () => {
|
|
134
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", "dpl_does_not_exist"], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" } });
|
|
135
|
+
expect(exitCode).not.toBe(0);
|
|
136
|
+
expect(output).toMatch(/error|not found/i);
|
|
137
|
+
});
|
|
138
|
+
it("exits with error when not authenticated", async () => {
|
|
139
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--deployment-id", DEPLOYMENT_ID], { cwd, env: { ALPIC_API_BASE_URL: serverUrl } });
|
|
140
|
+
expect(exitCode).not.toBe(0);
|
|
141
|
+
expect(output).toMatch(/not authenticated|alpic login|ALPIC_API_KEY/i);
|
|
142
|
+
});
|
|
143
|
+
it("resolves deployment via --environment-id", async () => {
|
|
144
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
145
|
+
{
|
|
146
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Env lookup log" }],
|
|
147
|
+
hasMoreLogs: false,
|
|
148
|
+
},
|
|
149
|
+
]);
|
|
150
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs", "--environment-id", ENVIRONMENT_ID], { cwd, env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" } });
|
|
151
|
+
expect(exitCode).toBe(0);
|
|
152
|
+
expect(output).toContain("Env lookup log");
|
|
153
|
+
const call = mockServer.getLastCall("GET", /\/v1\/deployments\/.*\/logs/);
|
|
154
|
+
expectSuccessfulApiCall(call);
|
|
155
|
+
});
|
|
156
|
+
it("resolves deployment via environment-id from config file", async () => {
|
|
157
|
+
mockServer.setDeploymentLogPages(DEPLOYMENT_ID, [
|
|
158
|
+
{
|
|
159
|
+
logs: [{ timestamp: new Date("2024-06-01T12:00:00.000Z"), content: "Config file log" }],
|
|
160
|
+
hasMoreLogs: false,
|
|
161
|
+
},
|
|
162
|
+
]);
|
|
163
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENVIRONMENT_ID, "production");
|
|
164
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs"], {
|
|
165
|
+
cwd,
|
|
166
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
167
|
+
});
|
|
168
|
+
expect(exitCode).toBe(0);
|
|
169
|
+
expect(output).toContain("Config file log");
|
|
170
|
+
});
|
|
171
|
+
it("exits with error when no deployment-id or environment-id provided", async () => {
|
|
172
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "deployment", "logs"], {
|
|
173
|
+
cwd,
|
|
174
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
175
|
+
});
|
|
176
|
+
expect(exitCode).not.toBe(0);
|
|
177
|
+
expect(output).toMatch(/environment|deployment-id/i);
|
|
178
|
+
});
|
|
179
|
+
}, 30_000);
|
|
180
|
+
//# sourceMappingURL=deployment-logs.e2e.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deployment-logs.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/deployment-logs.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,12 @@
|
|
|
1
1
|
import { type RouterOutput } from "@alpic-ai/api";
|
|
2
2
|
export type MockRuntimeLog = RouterOutput["environments"]["getLogs"]["v1"]["logs"][number];
|
|
3
|
+
export type MockDeploymentLogPage = {
|
|
4
|
+
logs: {
|
|
5
|
+
timestamp?: Date;
|
|
6
|
+
content?: string;
|
|
7
|
+
}[];
|
|
8
|
+
hasMoreLogs: boolean;
|
|
9
|
+
};
|
|
3
10
|
export type ApiCall = {
|
|
4
11
|
method: string;
|
|
5
12
|
path: string;
|
|
@@ -22,5 +29,7 @@ export declare class MockApiServer {
|
|
|
22
29
|
addEnvironmentVariables(environmentId: string, variables: RouterOutput["environmentVariables"]["list"]["v1"]): void;
|
|
23
30
|
setRuntimeLogs(environmentId: string, logs: MockRuntimeLog[]): void;
|
|
24
31
|
setRuntimeLogPages(environmentId: string, pages: MockRuntimeLog[][]): void;
|
|
32
|
+
addDeployments(deployments: RouterOutput["deployments"]["list"]["v1"]): void;
|
|
33
|
+
setDeploymentLogPages(deploymentId: string, pages: MockDeploymentLogPage[]): void;
|
|
25
34
|
addProject(project: RouterOutput["projects"]["get"]["v1"]): void;
|
|
26
35
|
}
|
|
@@ -32,6 +32,8 @@ export class MockApiServer {
|
|
|
32
32
|
environmentVariables: new Map(),
|
|
33
33
|
runtimeLogs: new Map(),
|
|
34
34
|
runtimeLogPages: new Map(),
|
|
35
|
+
deploymentLogPages: new Map(),
|
|
36
|
+
deploymentLogCallCounts: new Map(),
|
|
35
37
|
};
|
|
36
38
|
}
|
|
37
39
|
async start() {
|
|
@@ -354,6 +356,9 @@ export class MockApiServer {
|
|
|
354
356
|
const deployment = {
|
|
355
357
|
id: deploymentId,
|
|
356
358
|
status: "ongoing",
|
|
359
|
+
environmentId: environment.id,
|
|
360
|
+
environmentName: environment.name,
|
|
361
|
+
isCurrent: false,
|
|
357
362
|
sourceRef: environment.sourceBranch,
|
|
358
363
|
sourceCommitId: randomUUID().slice(0, 7),
|
|
359
364
|
sourceCommitMessage: "Mock deployment",
|
|
@@ -438,10 +443,16 @@ export class MockApiServer {
|
|
|
438
443
|
if (!project) {
|
|
439
444
|
throw new ORPCError("NOT_FOUND", { message: "Project not found" });
|
|
440
445
|
}
|
|
441
|
-
|
|
446
|
+
let deployments = Array.from(this.mockData.deployments.values());
|
|
447
|
+
if (input.environmentId) {
|
|
448
|
+
deployments = deployments.filter((deployment) => deployment.environmentId === input.environmentId);
|
|
449
|
+
}
|
|
450
|
+
if (input.status?.length) {
|
|
451
|
+
deployments = deployments.filter((deployment) => input.status.includes(deployment.status));
|
|
452
|
+
}
|
|
453
|
+
return deployments.map((deployment) => ({
|
|
442
454
|
...deployment,
|
|
443
455
|
isCurrent: deployment.status === "deployed",
|
|
444
|
-
environmentId: project.productionEnvironment?.id ?? "",
|
|
445
456
|
}));
|
|
446
457
|
}),
|
|
447
458
|
},
|
|
@@ -470,6 +481,13 @@ export class MockApiServer {
|
|
|
470
481
|
if (!deployment) {
|
|
471
482
|
throw new ORPCError("NOT_FOUND", { message: "Deployment not found" });
|
|
472
483
|
}
|
|
484
|
+
const pages = this.mockData.deploymentLogPages.get(input.deploymentId);
|
|
485
|
+
if (pages !== undefined) {
|
|
486
|
+
const callCount = this.mockData.deploymentLogCallCounts.get(input.deploymentId) ?? 0;
|
|
487
|
+
const pageIndex = Math.min(callCount, pages.length - 1);
|
|
488
|
+
this.mockData.deploymentLogCallCounts.set(input.deploymentId, callCount + 1);
|
|
489
|
+
return pages[pageIndex] ?? { logs: [], hasMoreLogs: false };
|
|
490
|
+
}
|
|
473
491
|
return {
|
|
474
492
|
logs: [{ timestamp: new Date(), content: "Mock log entry" }],
|
|
475
493
|
hasMoreLogs: false,
|
|
@@ -585,6 +603,18 @@ export class MockApiServer {
|
|
|
585
603
|
this.mockData.runtimeLogPages.set(environmentId, pages);
|
|
586
604
|
this.mockData.runtimeLogs.delete(environmentId);
|
|
587
605
|
}
|
|
606
|
+
addDeployments(deployments) {
|
|
607
|
+
for (const deployment of deployments) {
|
|
608
|
+
this.mockData.deployments.set(deployment.id, {
|
|
609
|
+
...deployment,
|
|
610
|
+
deploymentPageUrl: null,
|
|
611
|
+
});
|
|
612
|
+
}
|
|
613
|
+
}
|
|
614
|
+
setDeploymentLogPages(deploymentId, pages) {
|
|
615
|
+
this.mockData.deploymentLogPages.set(deploymentId, pages);
|
|
616
|
+
this.mockData.deploymentLogCallCounts.set(deploymentId, 0);
|
|
617
|
+
}
|
|
588
618
|
addProject(project) {
|
|
589
619
|
this.mockData.projects.set(project.id, project);
|
|
590
620
|
if (project.productionEnvironment) {
|