alpic 0.0.0-dev.ff13ae5 → 0.0.0-dev.ff4302e
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/README.md +40 -0
- package/bin/run.js +5 -0
- package/dist/__tests__/auth.e2e.test.js +18 -3
- package/dist/__tests__/auth.e2e.test.js.map +1 -1
- package/dist/__tests__/deploy-flags.e2e.test.js +79 -2
- package/dist/__tests__/deploy-flags.e2e.test.js.map +1 -1
- package/dist/__tests__/deploy.e2e.test.js +22 -10
- package/dist/__tests__/deploy.e2e.test.js.map +1 -1
- package/dist/__tests__/deployment-inspect.e2e.test.d.ts +1 -0
- package/dist/__tests__/deployment-inspect.e2e.test.js +114 -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 +116 -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 +255 -0
- package/dist/__tests__/deployment-logs.e2e.test.js.map +1 -0
- package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +13 -4
- package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -1
- package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +24 -6
- package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -1
- package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +15 -4
- package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -1
- package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +30 -7
- package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -1
- package/dist/__tests__/link.e2e.test.d.ts +1 -0
- package/dist/__tests__/link.e2e.test.js +279 -0
- package/dist/__tests__/link.e2e.test.js.map +1 -0
- package/dist/__tests__/logs.e2e.test.d.ts +1 -0
- package/dist/__tests__/logs.e2e.test.js +227 -0
- package/dist/__tests__/logs.e2e.test.js.map +1 -0
- package/dist/__tests__/mock-server.d.ts +19 -0
- package/dist/__tests__/mock-server.js +178 -22
- package/dist/__tests__/mock-server.js.map +1 -1
- package/dist/__tests__/publish.e2e.test.d.ts +1 -0
- package/dist/__tests__/publish.e2e.test.js +505 -0
- package/dist/__tests__/publish.e2e.test.js.map +1 -0
- package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
- package/dist/__tests__/tunnel.e2e.test.js +61 -0
- package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
- package/dist/__tests__/utils.d.ts +8 -2
- package/dist/__tests__/utils.js +32 -9
- package/dist/__tests__/utils.js.map +1 -1
- package/dist/api.d.ts +1 -1
- package/dist/api.js +10 -3
- package/dist/api.js.map +1 -1
- package/dist/commands/deploy.d.ts +3 -0
- package/dist/commands/deploy.js +32 -11
- package/dist/commands/deploy.js.map +1 -1
- package/dist/commands/deployment/inspect.d.ts +11 -0
- package/dist/commands/deployment/inspect.js +91 -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 +97 -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 +50 -0
- package/dist/commands/deployment/logs.js.map +1 -0
- package/dist/commands/environment-variable/add.js +2 -1
- package/dist/commands/environment-variable/add.js.map +1 -1
- package/dist/commands/environment-variable/list.js +2 -1
- package/dist/commands/environment-variable/list.js.map +1 -1
- package/dist/commands/environment-variable/remove.js +2 -1
- package/dist/commands/environment-variable/remove.js.map +1 -1
- package/dist/commands/environment-variable/update.js +2 -1
- package/dist/commands/environment-variable/update.js.map +1 -1
- package/dist/commands/git/connect.js +4 -2
- package/dist/commands/git/connect.js.map +1 -1
- package/dist/commands/git/disconnect.js +6 -2
- package/dist/commands/git/disconnect.js.map +1 -1
- package/dist/commands/link.d.ts +17 -0
- package/dist/commands/link.js +101 -0
- package/dist/commands/link.js.map +1 -0
- package/dist/commands/login.js +2 -13
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/logs.d.ts +16 -0
- package/dist/commands/logs.js +96 -0
- package/dist/commands/logs.js.map +1 -0
- package/dist/commands/publish.d.ts +15 -0
- package/dist/commands/publish.js +51 -0
- package/dist/commands/publish.js.map +1 -0
- package/dist/commands/tunnel.d.ts +9 -0
- package/dist/commands/tunnel.js +96 -0
- package/dist/commands/tunnel.js.map +1 -0
- package/dist/lib/auth/auth.d.ts +1 -0
- package/dist/lib/auth/auth.js +18 -0
- package/dist/lib/auth/auth.js.map +1 -1
- package/dist/lib/auth/oauth/server/index.js +5 -2
- package/dist/lib/auth/oauth/server/index.js.map +1 -1
- package/dist/lib/auth/whoami.js +6 -2
- package/dist/lib/auth/whoami.js.map +1 -1
- package/dist/lib/config.d.ts +1 -0
- package/dist/lib/config.js +1 -0
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/deployment.d.ts +68 -0
- package/dist/lib/deployment.js +111 -3
- package/dist/lib/deployment.js.map +1 -1
- package/dist/lib/environment-variable.d.ts +0 -4
- package/dist/lib/environment-variable.js +12 -17
- package/dist/lib/environment-variable.js.map +1 -1
- package/dist/lib/git.js +1 -1
- package/dist/lib/git.js.map +1 -1
- package/dist/lib/global-store.js +2 -2
- package/dist/lib/global-store.js.map +1 -1
- package/dist/lib/{project.d.ts → link.d.ts} +22 -10
- package/dist/lib/{project.js → link.js} +174 -82
- package/dist/lib/link.js.map +1 -0
- package/dist/lib/logs.d.ts +20 -0
- package/dist/lib/logs.js +86 -0
- package/dist/lib/logs.js.map +1 -0
- package/dist/lib/publish.d.ts +22 -0
- package/dist/lib/publish.js +185 -0
- package/dist/lib/publish.js.map +1 -0
- package/dist/lib/resolve.d.ts +6 -0
- package/dist/lib/resolve.js +26 -0
- package/dist/lib/resolve.js.map +1 -0
- package/dist/lib/table.js +1 -1
- package/dist/lib/table.js.map +1 -1
- package/dist/lib/telemetry.js +1 -1
- package/dist/lib/telemetry.js.map +1 -1
- package/dist/lib/utils.d.ts +4 -1
- package/dist/lib/utils.js +40 -12
- package/dist/lib/utils.js.map +1 -1
- package/dist/lib/utils.test.js +19 -6
- package/dist/lib/utils.test.js.map +1 -1
- package/dist/types.d.ts +1 -0
- package/package.json +22 -17
- package/dist/lib/project.js.map +0 -1
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
import { rmSync } from "node:fs";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { MockApiServer } from "./mock-server.js";
|
|
4
|
+
import { buildMockProject, cliSession, expectSuccessfulApiCall, setupTestDirectory, verifyConfigFile, } from "./utils.js";
|
|
5
|
+
describe("alpic link (E2E)", () => {
|
|
6
|
+
let mockServer;
|
|
7
|
+
let serverUrl;
|
|
8
|
+
let cwd;
|
|
9
|
+
let binPath;
|
|
10
|
+
let extraCwd;
|
|
11
|
+
beforeEach(async () => {
|
|
12
|
+
mockServer = new MockApiServer();
|
|
13
|
+
serverUrl = await mockServer.start();
|
|
14
|
+
const setup = await setupTestDirectory();
|
|
15
|
+
cwd = setup.cwd;
|
|
16
|
+
binPath = setup.binPath;
|
|
17
|
+
});
|
|
18
|
+
afterEach(async () => {
|
|
19
|
+
await mockServer.stop();
|
|
20
|
+
if (extraCwd) {
|
|
21
|
+
rmSync(extraCwd, { recursive: true, force: true });
|
|
22
|
+
extraCwd = undefined;
|
|
23
|
+
}
|
|
24
|
+
if (cwd) {
|
|
25
|
+
rmSync(cwd, { recursive: true, force: true });
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
it("creates a new project via prompts", async () => {
|
|
29
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "link"], {
|
|
30
|
+
cwd,
|
|
31
|
+
env: {
|
|
32
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
33
|
+
ALPIC_API_KEY: "test-api-key",
|
|
34
|
+
},
|
|
35
|
+
}, async (cli) => {
|
|
36
|
+
await cli.expect("Use the current directory?");
|
|
37
|
+
await cli.send("");
|
|
38
|
+
await cli.expect("Choose a team");
|
|
39
|
+
await cli.send("");
|
|
40
|
+
await cli.expect("Link to existing project?");
|
|
41
|
+
await cli.send("n");
|
|
42
|
+
await cli.expect("Project name");
|
|
43
|
+
await cli.send("my-new-project");
|
|
44
|
+
await cli.expect("Runtime");
|
|
45
|
+
await cli.send("");
|
|
46
|
+
await cli.expect("Root directory");
|
|
47
|
+
await cli.send("");
|
|
48
|
+
await cli.expect("Project created.");
|
|
49
|
+
await cli.expect("Linked to project");
|
|
50
|
+
});
|
|
51
|
+
expect(exitCode).toBe(0);
|
|
52
|
+
const createProjectCall = mockServer.getLastCall("POST", "/v1/projects");
|
|
53
|
+
expectSuccessfulApiCall(createProjectCall, (call) => {
|
|
54
|
+
expect(call.input).toMatchObject({
|
|
55
|
+
name: "my-new-project",
|
|
56
|
+
runtime: "node24",
|
|
57
|
+
teamId: "mock-team-id",
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
await verifyConfigFile(cwd, {
|
|
61
|
+
projectName: "my-new-project",
|
|
62
|
+
teamName: "Mock Team",
|
|
63
|
+
environmentName: "production",
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
it("links to an existing project via prompts", async () => {
|
|
67
|
+
const existingProjectId = "existing-project-id";
|
|
68
|
+
const existingTeamId = "mock-team-id";
|
|
69
|
+
const existingEnvId = "existing-env-id";
|
|
70
|
+
const existingEnvName = "production";
|
|
71
|
+
mockServer.addProject(buildMockProject({
|
|
72
|
+
projectId: existingProjectId,
|
|
73
|
+
teamId: existingTeamId,
|
|
74
|
+
projectName: "existing-project",
|
|
75
|
+
environmentId: existingEnvId,
|
|
76
|
+
environmentName: existingEnvName,
|
|
77
|
+
}));
|
|
78
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "link"], {
|
|
79
|
+
cwd,
|
|
80
|
+
env: {
|
|
81
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
82
|
+
ALPIC_API_KEY: "test-api-key",
|
|
83
|
+
},
|
|
84
|
+
}, async (cli) => {
|
|
85
|
+
await cli.expect("Use the current directory?");
|
|
86
|
+
await cli.send("");
|
|
87
|
+
await cli.expect("Choose a team");
|
|
88
|
+
await cli.send("");
|
|
89
|
+
await cli.expect("Link to existing project?");
|
|
90
|
+
await cli.send("y");
|
|
91
|
+
await cli.expect("Choose a project");
|
|
92
|
+
await cli.send("");
|
|
93
|
+
await cli.expect("Choose an environment to deploy to");
|
|
94
|
+
await cli.send("");
|
|
95
|
+
await cli.expect("Linked to project");
|
|
96
|
+
});
|
|
97
|
+
expect(exitCode).toBe(0);
|
|
98
|
+
await verifyConfigFile(cwd, {
|
|
99
|
+
projectName: "existing-project",
|
|
100
|
+
projectId: existingProjectId,
|
|
101
|
+
teamId: existingTeamId,
|
|
102
|
+
teamName: "Mock Team",
|
|
103
|
+
environmentId: existingEnvId,
|
|
104
|
+
environmentName: existingEnvName,
|
|
105
|
+
});
|
|
106
|
+
});
|
|
107
|
+
it("shows team select when multiple teams exist", async () => {
|
|
108
|
+
mockServer.setTeams([
|
|
109
|
+
{ id: "team-alpha", name: "Team Alpha" },
|
|
110
|
+
{ id: "team-beta", name: "Team Beta" },
|
|
111
|
+
]);
|
|
112
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "link"], {
|
|
113
|
+
cwd,
|
|
114
|
+
env: {
|
|
115
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
116
|
+
ALPIC_API_KEY: "test-api-key",
|
|
117
|
+
},
|
|
118
|
+
}, async (cli) => {
|
|
119
|
+
await cli.expect("Use the current directory?");
|
|
120
|
+
await cli.send("");
|
|
121
|
+
await cli.expect("Choose a team");
|
|
122
|
+
await cli.send("");
|
|
123
|
+
await cli.expect("Link to existing project?");
|
|
124
|
+
await cli.send("n");
|
|
125
|
+
await cli.expect("Project name");
|
|
126
|
+
await cli.send("demo");
|
|
127
|
+
await cli.expect("Runtime");
|
|
128
|
+
await cli.send("");
|
|
129
|
+
await cli.expect("Root directory");
|
|
130
|
+
await cli.send("");
|
|
131
|
+
await cli.expect("Project created.");
|
|
132
|
+
await cli.expect("Linked to project");
|
|
133
|
+
});
|
|
134
|
+
expect(exitCode).toBe(0);
|
|
135
|
+
const createProjectCall = mockServer.getLastCall("POST", "/v1/projects");
|
|
136
|
+
expectSuccessfulApiCall(createProjectCall, (call) => {
|
|
137
|
+
expect(call.input).toMatchObject({
|
|
138
|
+
teamId: "team-alpha",
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
await verifyConfigFile(cwd, {
|
|
142
|
+
projectName: "demo",
|
|
143
|
+
teamName: "Team Alpha",
|
|
144
|
+
environmentName: "production",
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
it("errors when no teams exist", async () => {
|
|
148
|
+
mockServer.setTeams([]);
|
|
149
|
+
const { output } = await cliSession(process.execPath, [binPath, "link"], {
|
|
150
|
+
cwd,
|
|
151
|
+
env: {
|
|
152
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
153
|
+
ALPIC_API_KEY: "test-api-key",
|
|
154
|
+
},
|
|
155
|
+
}, async (cli) => {
|
|
156
|
+
await cli.expect("Use the current directory?");
|
|
157
|
+
await cli.send("");
|
|
158
|
+
await cli.expect("No teams found");
|
|
159
|
+
});
|
|
160
|
+
expect(output).toContain("No teams found");
|
|
161
|
+
});
|
|
162
|
+
it("creates a project with --non-interactive flags", async () => {
|
|
163
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "link", "--non-interactive", "--project-name", "demo", "--runtime", "node24"], {
|
|
164
|
+
cwd,
|
|
165
|
+
env: {
|
|
166
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
167
|
+
ALPIC_API_KEY: "test-api-key",
|
|
168
|
+
},
|
|
169
|
+
}, async (cli) => {
|
|
170
|
+
await cli.expect("Project created.");
|
|
171
|
+
await cli.expect("Linked to project");
|
|
172
|
+
});
|
|
173
|
+
expect(exitCode).toBe(0);
|
|
174
|
+
const createProjectCall = mockServer.getLastCall("POST", "/v1/projects");
|
|
175
|
+
expectSuccessfulApiCall(createProjectCall, (call) => {
|
|
176
|
+
expect(call.input).toMatchObject({
|
|
177
|
+
name: "demo",
|
|
178
|
+
runtime: "node24",
|
|
179
|
+
teamId: "mock-team-id",
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
await verifyConfigFile(cwd, {
|
|
183
|
+
projectName: "demo",
|
|
184
|
+
teamName: "Mock Team",
|
|
185
|
+
environmentName: "production",
|
|
186
|
+
});
|
|
187
|
+
});
|
|
188
|
+
it("exits cleanly when Ctrl+C is pressed", async () => {
|
|
189
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "link"], {
|
|
190
|
+
cwd,
|
|
191
|
+
env: {
|
|
192
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
193
|
+
ALPIC_API_KEY: "test-api-key",
|
|
194
|
+
},
|
|
195
|
+
}, async (cli) => {
|
|
196
|
+
await cli.expect("Use the current directory?");
|
|
197
|
+
cli.write("\x03");
|
|
198
|
+
});
|
|
199
|
+
expect(exitCode).toBeLessThanOrEqual(1);
|
|
200
|
+
expect(output).not.toContain("Error:");
|
|
201
|
+
});
|
|
202
|
+
it("offers GitHub connect after project creation in git repo", async () => {
|
|
203
|
+
const setup = await setupTestDirectory({ initGit: true });
|
|
204
|
+
extraCwd = setup.cwd;
|
|
205
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "link"], {
|
|
206
|
+
cwd: extraCwd,
|
|
207
|
+
env: {
|
|
208
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
209
|
+
ALPIC_API_KEY: "test-api-key",
|
|
210
|
+
},
|
|
211
|
+
}, async (cli) => {
|
|
212
|
+
await cli.expect("Use the current directory?");
|
|
213
|
+
await cli.send("");
|
|
214
|
+
await cli.expect("Choose a team");
|
|
215
|
+
await cli.send("");
|
|
216
|
+
await cli.expect("Link to existing project?");
|
|
217
|
+
await cli.send("n");
|
|
218
|
+
await cli.expect("Project name");
|
|
219
|
+
await cli.send("demo");
|
|
220
|
+
await cli.expect("Runtime");
|
|
221
|
+
await cli.send("");
|
|
222
|
+
await cli.expect("Root directory");
|
|
223
|
+
await cli.send("");
|
|
224
|
+
await cli.expect("Project created.");
|
|
225
|
+
await cli.expect("Connect this project to a GitHub repository?");
|
|
226
|
+
await cli.send("y");
|
|
227
|
+
await cli.expect("Choose the remote source to connect");
|
|
228
|
+
await cli.send("");
|
|
229
|
+
await cli.expect("Connected to");
|
|
230
|
+
await cli.expect("Linked to project");
|
|
231
|
+
});
|
|
232
|
+
expect(exitCode).toBe(0);
|
|
233
|
+
expect(output).toContain("Alpic GitHub App");
|
|
234
|
+
const updateCall = mockServer.getLastCall("PATCH", /\/v1\/projects\//);
|
|
235
|
+
expectSuccessfulApiCall(updateCall, (call) => {
|
|
236
|
+
expect(call.input).toHaveProperty("sourceRepository");
|
|
237
|
+
});
|
|
238
|
+
});
|
|
239
|
+
it("skips GitHub connect when linked project already has a source repository", async () => {
|
|
240
|
+
const existingProjectId = "existing-project-id";
|
|
241
|
+
const existingTeamId = "mock-team-id";
|
|
242
|
+
const existingEnvId = "existing-env-id";
|
|
243
|
+
const existingEnvName = "production";
|
|
244
|
+
mockServer.addProject(buildMockProject({
|
|
245
|
+
projectId: existingProjectId,
|
|
246
|
+
teamId: existingTeamId,
|
|
247
|
+
projectName: "existing-project",
|
|
248
|
+
environmentId: existingEnvId,
|
|
249
|
+
environmentName: existingEnvName,
|
|
250
|
+
sourceRepository: "acme/frontend",
|
|
251
|
+
}));
|
|
252
|
+
const setup = await setupTestDirectory({ initGit: true });
|
|
253
|
+
extraCwd = setup.cwd;
|
|
254
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "link"], {
|
|
255
|
+
cwd: extraCwd,
|
|
256
|
+
env: {
|
|
257
|
+
ALPIC_API_BASE_URL: serverUrl,
|
|
258
|
+
ALPIC_API_KEY: "test-api-key",
|
|
259
|
+
},
|
|
260
|
+
}, async (cli) => {
|
|
261
|
+
await cli.expect("Use the current directory?");
|
|
262
|
+
await cli.send("");
|
|
263
|
+
await cli.expect("Choose a team");
|
|
264
|
+
await cli.send("");
|
|
265
|
+
await cli.expect("Link to existing project?");
|
|
266
|
+
await cli.send("y");
|
|
267
|
+
await cli.expect("Choose a project");
|
|
268
|
+
await cli.send("");
|
|
269
|
+
await cli.expect("Choose an environment to deploy to");
|
|
270
|
+
await cli.send("");
|
|
271
|
+
await cli.expect('already connected to "acme/frontend"');
|
|
272
|
+
await cli.expect("Linked to project");
|
|
273
|
+
});
|
|
274
|
+
expect(exitCode).toBe(0);
|
|
275
|
+
expect(output).not.toContain("Connect this project to a GitHub repository?");
|
|
276
|
+
expect(mockServer.getCalls("PATCH", `/v1/projects/${existingProjectId}`)).toHaveLength(0);
|
|
277
|
+
});
|
|
278
|
+
}, 15_000);
|
|
279
|
+
//# sourceMappingURL=link.e2e.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"link.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/link.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
import { rmSync } from "node:fs";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
3
|
+
import { MockApiServer } from "./mock-server.js";
|
|
4
|
+
import { buildMockProject, cliSession, createConfigFile, expectSuccessfulApiCall, setupTestDirectory, } from "./utils.js";
|
|
5
|
+
const ENV_ID = "env-logs-test";
|
|
6
|
+
const PROJECT_ID = "prj-logs-test";
|
|
7
|
+
const TEAM_ID = "mock-team-id";
|
|
8
|
+
function sleep(ms) {
|
|
9
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
10
|
+
}
|
|
11
|
+
function makeLogs() {
|
|
12
|
+
const base = new Date("2024-06-01T12:00:00.000Z");
|
|
13
|
+
return [
|
|
14
|
+
{
|
|
15
|
+
timestamp: new Date(base.getTime() + 0),
|
|
16
|
+
type: "INFO",
|
|
17
|
+
requestId: "req-1",
|
|
18
|
+
content: "server started",
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
timestamp: new Date(base.getTime() + 1),
|
|
22
|
+
type: "WARNING",
|
|
23
|
+
requestId: "req-1",
|
|
24
|
+
content: "cache miss",
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
timestamp: new Date(base.getTime() + 2),
|
|
28
|
+
type: "ERROR",
|
|
29
|
+
requestId: "req-1",
|
|
30
|
+
content: "tool failed",
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
timestamp: new Date(base.getTime() + 3),
|
|
34
|
+
type: "DEBUG",
|
|
35
|
+
requestId: "req-2",
|
|
36
|
+
content: "trace info",
|
|
37
|
+
},
|
|
38
|
+
];
|
|
39
|
+
}
|
|
40
|
+
describe("alpic logs (E2E)", () => {
|
|
41
|
+
let mockServer;
|
|
42
|
+
let serverUrl;
|
|
43
|
+
let cwd;
|
|
44
|
+
let binPath;
|
|
45
|
+
beforeEach(async () => {
|
|
46
|
+
mockServer = new MockApiServer();
|
|
47
|
+
serverUrl = await mockServer.start();
|
|
48
|
+
const setup = await setupTestDirectory();
|
|
49
|
+
cwd = setup.cwd;
|
|
50
|
+
binPath = setup.binPath;
|
|
51
|
+
mockServer.addProject(buildMockProject({
|
|
52
|
+
projectId: PROJECT_ID,
|
|
53
|
+
teamId: TEAM_ID,
|
|
54
|
+
projectName: "logs-project",
|
|
55
|
+
environmentId: ENV_ID,
|
|
56
|
+
environmentName: "production",
|
|
57
|
+
}));
|
|
58
|
+
});
|
|
59
|
+
afterEach(async () => {
|
|
60
|
+
await mockServer.stop();
|
|
61
|
+
if (cwd)
|
|
62
|
+
rmSync(cwd, { recursive: true, force: true });
|
|
63
|
+
});
|
|
64
|
+
it("fetches and prints logs using environment-id from config", async () => {
|
|
65
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
66
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
67
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs"], {
|
|
68
|
+
cwd,
|
|
69
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
70
|
+
});
|
|
71
|
+
expect(exitCode).toBe(0);
|
|
72
|
+
expect(output).toContain("server started");
|
|
73
|
+
expect(output).toContain("cache miss");
|
|
74
|
+
expect(output).toContain("tool failed");
|
|
75
|
+
expect(output).toContain("trace info");
|
|
76
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
77
|
+
expectSuccessfulApiCall(call);
|
|
78
|
+
});
|
|
79
|
+
it("fetches logs using --environment-id flag", async () => {
|
|
80
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
81
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "logs", "--environment-id", ENV_ID], {
|
|
82
|
+
cwd,
|
|
83
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
84
|
+
});
|
|
85
|
+
expect(exitCode).toBe(0);
|
|
86
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
87
|
+
expectSuccessfulApiCall(call);
|
|
88
|
+
});
|
|
89
|
+
it("passes --since to the API", async () => {
|
|
90
|
+
mockServer.setRuntimeLogs(ENV_ID, []);
|
|
91
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
92
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "logs", "--since", "2h"], {
|
|
93
|
+
cwd,
|
|
94
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
95
|
+
});
|
|
96
|
+
expect(exitCode).toBe(0);
|
|
97
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
98
|
+
expectSuccessfulApiCall(call);
|
|
99
|
+
expect((call?.input).since).toBe("2h");
|
|
100
|
+
});
|
|
101
|
+
it("passes --until to the API", async () => {
|
|
102
|
+
mockServer.setRuntimeLogs(ENV_ID, []);
|
|
103
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
104
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "logs", "--until", "2024-06-01T12:00:00Z"], {
|
|
105
|
+
cwd,
|
|
106
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
107
|
+
});
|
|
108
|
+
expect(exitCode).toBe(0);
|
|
109
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
110
|
+
expectSuccessfulApiCall(call);
|
|
111
|
+
expect((call?.input).until).toBe("2024-06-01T12:00:00Z");
|
|
112
|
+
});
|
|
113
|
+
it("passes --search to the API", async () => {
|
|
114
|
+
mockServer.setRuntimeLogs(ENV_ID, []);
|
|
115
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
116
|
+
const { exitCode } = await cliSession(process.execPath, [binPath, "logs", "--search", "timeout"], {
|
|
117
|
+
cwd,
|
|
118
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
119
|
+
});
|
|
120
|
+
expect(exitCode).toBe(0);
|
|
121
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
122
|
+
expectSuccessfulApiCall(call);
|
|
123
|
+
expect((call?.input).search).toBe("timeout");
|
|
124
|
+
});
|
|
125
|
+
it("filters by --level ERROR — only error logs are returned", async () => {
|
|
126
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
127
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
128
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--level", "ERROR"], {
|
|
129
|
+
cwd,
|
|
130
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
131
|
+
});
|
|
132
|
+
expect(exitCode).toBe(0);
|
|
133
|
+
expect(output).toContain("tool failed");
|
|
134
|
+
expect(output).not.toContain("server started");
|
|
135
|
+
expect(output).not.toContain("cache miss");
|
|
136
|
+
expect(output).not.toContain("trace info");
|
|
137
|
+
const call = mockServer.getLastCall("GET", /\/v1\/environments\/.*\/logs/);
|
|
138
|
+
expectSuccessfulApiCall(call);
|
|
139
|
+
});
|
|
140
|
+
it("accepts multiple --level values", async () => {
|
|
141
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
142
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
143
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--level", "ERROR", "--level", "WARNING"], {
|
|
144
|
+
cwd,
|
|
145
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
146
|
+
});
|
|
147
|
+
expect(exitCode).toBe(0);
|
|
148
|
+
expect(output).toContain("tool failed");
|
|
149
|
+
expect(output).toContain("cache miss");
|
|
150
|
+
expect(output).not.toContain("server started");
|
|
151
|
+
expect(output).not.toContain("trace info");
|
|
152
|
+
});
|
|
153
|
+
it("normalises lowercase --level values", async () => {
|
|
154
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
155
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
156
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--level", "error"], {
|
|
157
|
+
cwd,
|
|
158
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
159
|
+
});
|
|
160
|
+
expect(exitCode).toBe(0);
|
|
161
|
+
expect(output).toContain("tool failed");
|
|
162
|
+
expect(output).not.toContain("server started");
|
|
163
|
+
});
|
|
164
|
+
it("shows log level text with --no-color", async () => {
|
|
165
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
166
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
167
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--no-color"], {
|
|
168
|
+
cwd,
|
|
169
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
170
|
+
});
|
|
171
|
+
expect(exitCode).toBe(0);
|
|
172
|
+
expect(output).toContain("INFO server started");
|
|
173
|
+
expect(output).toContain("WARN cache miss");
|
|
174
|
+
expect(output).toContain("ERROR tool failed");
|
|
175
|
+
expect(output).toContain("DEBUG trace info");
|
|
176
|
+
});
|
|
177
|
+
it("exits with error when --limit is used with --follow", async () => {
|
|
178
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
179
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
180
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--follow", "--limit", "10"], {
|
|
181
|
+
cwd,
|
|
182
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
183
|
+
});
|
|
184
|
+
expect(exitCode).toBe(1);
|
|
185
|
+
expect(output).toMatch(/--limit cannot be used with --follow/i);
|
|
186
|
+
});
|
|
187
|
+
it("polls repeatedly with --follow", async () => {
|
|
188
|
+
mockServer.setRuntimeLogs(ENV_ID, makeLogs());
|
|
189
|
+
createConfigFile(cwd, PROJECT_ID, TEAM_ID, "logs-project", ENV_ID, "production");
|
|
190
|
+
const { output } = await cliSession(process.execPath, [binPath, "logs", "--follow"], {
|
|
191
|
+
cwd,
|
|
192
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
193
|
+
timeoutMs: 12_000,
|
|
194
|
+
}, async (cli) => {
|
|
195
|
+
await cli.expect("server started");
|
|
196
|
+
await sleep(3_300);
|
|
197
|
+
cli.stop();
|
|
198
|
+
});
|
|
199
|
+
// We stop the process manually after verifying follow mode had time to poll.
|
|
200
|
+
expect(output).toContain("server started");
|
|
201
|
+
const calls = mockServer.getCalls("GET", /\/v1\/environments\/.*\/logs/);
|
|
202
|
+
expect(calls.length).toBeGreaterThanOrEqual(2);
|
|
203
|
+
const firstCall = calls[0];
|
|
204
|
+
const secondCall = calls[1];
|
|
205
|
+
expect(firstCall).toBeDefined();
|
|
206
|
+
expect(secondCall).toBeDefined();
|
|
207
|
+
expect((firstCall?.input).since).toBe("10m");
|
|
208
|
+
expect((secondCall?.input).since).toMatch(/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z$/);
|
|
209
|
+
});
|
|
210
|
+
it("exits with error when environment not found", async () => {
|
|
211
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--environment-id", "nonexistent-env"], {
|
|
212
|
+
cwd,
|
|
213
|
+
env: { ALPIC_API_BASE_URL: serverUrl, ALPIC_API_KEY: "test-api-key" },
|
|
214
|
+
});
|
|
215
|
+
expect(exitCode).toBe(1);
|
|
216
|
+
expect(output).toContain("An error occurred while connecting to Alpic: Environment not found");
|
|
217
|
+
});
|
|
218
|
+
it("exits with error when not authenticated", async () => {
|
|
219
|
+
const { exitCode, output } = await cliSession(process.execPath, [binPath, "logs", "--environment-id", ENV_ID], {
|
|
220
|
+
cwd,
|
|
221
|
+
env: { ALPIC_API_BASE_URL: serverUrl },
|
|
222
|
+
});
|
|
223
|
+
expect(exitCode).toBe(1);
|
|
224
|
+
expect(output).toContain("Not authenticated. Run `alpic login` or set ALPIC_API_KEY. Get an API key from Team settings in the Alpic dashboard.");
|
|
225
|
+
});
|
|
226
|
+
}, 30_000);
|
|
227
|
+
//# sourceMappingURL=logs.e2e.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/logs.e2e.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
import { type RouterOutput } from "@alpic-ai/api";
|
|
2
|
+
export type MockRuntimeLog = RouterOutput["environments"]["getLogs"]["v1"]["logs"][number];
|
|
3
|
+
type PublishedServer = RouterOutput["distribution"]["get"]["v1"]["serverFields"];
|
|
4
|
+
export type MockDeploymentLogPage = {
|
|
5
|
+
logs: {
|
|
6
|
+
timestamp?: Date;
|
|
7
|
+
content?: string;
|
|
8
|
+
}[];
|
|
9
|
+
hasMoreLogs: boolean;
|
|
10
|
+
};
|
|
2
11
|
export type ApiCall = {
|
|
3
12
|
method: string;
|
|
4
13
|
path: string;
|
|
@@ -18,6 +27,16 @@ export declare class MockApiServer {
|
|
|
18
27
|
stop(): Promise<void>;
|
|
19
28
|
getCalls(method?: string, pathPattern?: string | RegExp): ApiCall[];
|
|
20
29
|
getLastCall(method?: string, pathPattern?: string | RegExp): ApiCall | undefined;
|
|
30
|
+
setTeams(teams: {
|
|
31
|
+
id: string;
|
|
32
|
+
name: string;
|
|
33
|
+
}[]): void;
|
|
21
34
|
addEnvironmentVariables(environmentId: string, variables: RouterOutput["environmentVariables"]["list"]["v1"]): void;
|
|
35
|
+
setRuntimeLogs(environmentId: string, logs: MockRuntimeLog[]): void;
|
|
36
|
+
setRuntimeLogPages(environmentId: string, pages: MockRuntimeLog[][]): void;
|
|
37
|
+
setPublishedServer(projectId: string, domain: string, server: PublishedServer): void;
|
|
38
|
+
addDeployments(deployments: RouterOutput["deployments"]["list"]["v1"]): void;
|
|
39
|
+
setDeploymentLogPages(deploymentId: string, pages: MockDeploymentLogPage[]): void;
|
|
22
40
|
addProject(project: RouterOutput["projects"]["get"]["v1"]): void;
|
|
23
41
|
}
|
|
42
|
+
export {};
|