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.
Files changed (128) hide show
  1. package/README.md +40 -0
  2. package/bin/run.js +5 -0
  3. package/dist/__tests__/auth.e2e.test.js +18 -3
  4. package/dist/__tests__/auth.e2e.test.js.map +1 -1
  5. package/dist/__tests__/deploy-flags.e2e.test.js +79 -2
  6. package/dist/__tests__/deploy-flags.e2e.test.js.map +1 -1
  7. package/dist/__tests__/deploy.e2e.test.js +22 -10
  8. package/dist/__tests__/deploy.e2e.test.js.map +1 -1
  9. package/dist/__tests__/deployment-inspect.e2e.test.d.ts +1 -0
  10. package/dist/__tests__/deployment-inspect.e2e.test.js +114 -0
  11. package/dist/__tests__/deployment-inspect.e2e.test.js.map +1 -0
  12. package/dist/__tests__/deployment-list.e2e.test.d.ts +1 -0
  13. package/dist/__tests__/deployment-list.e2e.test.js +116 -0
  14. package/dist/__tests__/deployment-list.e2e.test.js.map +1 -0
  15. package/dist/__tests__/deployment-logs.e2e.test.d.ts +1 -0
  16. package/dist/__tests__/deployment-logs.e2e.test.js +255 -0
  17. package/dist/__tests__/deployment-logs.e2e.test.js.map +1 -0
  18. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +13 -4
  19. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -1
  20. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +24 -6
  21. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -1
  22. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +15 -4
  23. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -1
  24. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +30 -7
  25. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -1
  26. package/dist/__tests__/link.e2e.test.d.ts +1 -0
  27. package/dist/__tests__/link.e2e.test.js +279 -0
  28. package/dist/__tests__/link.e2e.test.js.map +1 -0
  29. package/dist/__tests__/logs.e2e.test.d.ts +1 -0
  30. package/dist/__tests__/logs.e2e.test.js +227 -0
  31. package/dist/__tests__/logs.e2e.test.js.map +1 -0
  32. package/dist/__tests__/mock-server.d.ts +19 -0
  33. package/dist/__tests__/mock-server.js +178 -22
  34. package/dist/__tests__/mock-server.js.map +1 -1
  35. package/dist/__tests__/publish.e2e.test.d.ts +1 -0
  36. package/dist/__tests__/publish.e2e.test.js +505 -0
  37. package/dist/__tests__/publish.e2e.test.js.map +1 -0
  38. package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
  39. package/dist/__tests__/tunnel.e2e.test.js +61 -0
  40. package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
  41. package/dist/__tests__/utils.d.ts +8 -2
  42. package/dist/__tests__/utils.js +32 -9
  43. package/dist/__tests__/utils.js.map +1 -1
  44. package/dist/api.d.ts +1 -1
  45. package/dist/api.js +10 -3
  46. package/dist/api.js.map +1 -1
  47. package/dist/commands/deploy.d.ts +3 -0
  48. package/dist/commands/deploy.js +32 -11
  49. package/dist/commands/deploy.js.map +1 -1
  50. package/dist/commands/deployment/inspect.d.ts +11 -0
  51. package/dist/commands/deployment/inspect.js +91 -0
  52. package/dist/commands/deployment/inspect.js.map +1 -0
  53. package/dist/commands/deployment/list.d.ts +11 -0
  54. package/dist/commands/deployment/list.js +97 -0
  55. package/dist/commands/deployment/list.js.map +1 -0
  56. package/dist/commands/deployment/logs.d.ts +12 -0
  57. package/dist/commands/deployment/logs.js +50 -0
  58. package/dist/commands/deployment/logs.js.map +1 -0
  59. package/dist/commands/environment-variable/add.js +2 -1
  60. package/dist/commands/environment-variable/add.js.map +1 -1
  61. package/dist/commands/environment-variable/list.js +2 -1
  62. package/dist/commands/environment-variable/list.js.map +1 -1
  63. package/dist/commands/environment-variable/remove.js +2 -1
  64. package/dist/commands/environment-variable/remove.js.map +1 -1
  65. package/dist/commands/environment-variable/update.js +2 -1
  66. package/dist/commands/environment-variable/update.js.map +1 -1
  67. package/dist/commands/git/connect.js +4 -2
  68. package/dist/commands/git/connect.js.map +1 -1
  69. package/dist/commands/git/disconnect.js +6 -2
  70. package/dist/commands/git/disconnect.js.map +1 -1
  71. package/dist/commands/link.d.ts +17 -0
  72. package/dist/commands/link.js +101 -0
  73. package/dist/commands/link.js.map +1 -0
  74. package/dist/commands/login.js +2 -13
  75. package/dist/commands/login.js.map +1 -1
  76. package/dist/commands/logs.d.ts +16 -0
  77. package/dist/commands/logs.js +96 -0
  78. package/dist/commands/logs.js.map +1 -0
  79. package/dist/commands/publish.d.ts +15 -0
  80. package/dist/commands/publish.js +51 -0
  81. package/dist/commands/publish.js.map +1 -0
  82. package/dist/commands/tunnel.d.ts +9 -0
  83. package/dist/commands/tunnel.js +96 -0
  84. package/dist/commands/tunnel.js.map +1 -0
  85. package/dist/lib/auth/auth.d.ts +1 -0
  86. package/dist/lib/auth/auth.js +18 -0
  87. package/dist/lib/auth/auth.js.map +1 -1
  88. package/dist/lib/auth/oauth/server/index.js +5 -2
  89. package/dist/lib/auth/oauth/server/index.js.map +1 -1
  90. package/dist/lib/auth/whoami.js +6 -2
  91. package/dist/lib/auth/whoami.js.map +1 -1
  92. package/dist/lib/config.d.ts +1 -0
  93. package/dist/lib/config.js +1 -0
  94. package/dist/lib/config.js.map +1 -1
  95. package/dist/lib/deployment.d.ts +68 -0
  96. package/dist/lib/deployment.js +111 -3
  97. package/dist/lib/deployment.js.map +1 -1
  98. package/dist/lib/environment-variable.d.ts +0 -4
  99. package/dist/lib/environment-variable.js +12 -17
  100. package/dist/lib/environment-variable.js.map +1 -1
  101. package/dist/lib/git.js +1 -1
  102. package/dist/lib/git.js.map +1 -1
  103. package/dist/lib/global-store.js +2 -2
  104. package/dist/lib/global-store.js.map +1 -1
  105. package/dist/lib/{project.d.ts → link.d.ts} +22 -10
  106. package/dist/lib/{project.js → link.js} +174 -82
  107. package/dist/lib/link.js.map +1 -0
  108. package/dist/lib/logs.d.ts +20 -0
  109. package/dist/lib/logs.js +86 -0
  110. package/dist/lib/logs.js.map +1 -0
  111. package/dist/lib/publish.d.ts +22 -0
  112. package/dist/lib/publish.js +185 -0
  113. package/dist/lib/publish.js.map +1 -0
  114. package/dist/lib/resolve.d.ts +6 -0
  115. package/dist/lib/resolve.js +26 -0
  116. package/dist/lib/resolve.js.map +1 -0
  117. package/dist/lib/table.js +1 -1
  118. package/dist/lib/table.js.map +1 -1
  119. package/dist/lib/telemetry.js +1 -1
  120. package/dist/lib/telemetry.js.map +1 -1
  121. package/dist/lib/utils.d.ts +4 -1
  122. package/dist/lib/utils.js +40 -12
  123. package/dist/lib/utils.js.map +1 -1
  124. package/dist/lib/utils.test.js +19 -6
  125. package/dist/lib/utils.test.js.map +1 -1
  126. package/dist/types.d.ts +1 -0
  127. package/package.json +22 -17
  128. 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 {};