alpic 0.0.0-dev.f2f58a6 → 0.0.0-dev.f330b89

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 (178) hide show
  1. package/dist/__tests__/auth.e2e.test.d.ts +1 -0
  2. package/dist/__tests__/auth.e2e.test.js +158 -0
  3. package/dist/__tests__/auth.e2e.test.js.map +1 -0
  4. package/dist/__tests__/deploy-flags.e2e.test.d.ts +1 -0
  5. package/dist/__tests__/deploy-flags.e2e.test.js +111 -0
  6. package/dist/__tests__/deploy-flags.e2e.test.js.map +1 -0
  7. package/dist/__tests__/deploy.e2e.test.js +51 -150
  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 +113 -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.d.ts +1 -0
  19. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js +260 -0
  20. package/dist/__tests__/environment-variable/environment-variable-add.e2e.test.js.map +1 -0
  21. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.d.ts +1 -0
  22. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js +140 -0
  23. package/dist/__tests__/environment-variable/environment-variable-list.e2e.test.js.map +1 -0
  24. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.d.ts +1 -0
  25. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js +151 -0
  26. package/dist/__tests__/environment-variable/environment-variable-remove.e2e.test.js.map +1 -0
  27. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.d.ts +1 -0
  28. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js +343 -0
  29. package/dist/__tests__/environment-variable/environment-variable-update.e2e.test.js.map +1 -0
  30. package/dist/__tests__/environment-variable/environment-variable-validation.test.d.ts +1 -0
  31. package/dist/__tests__/environment-variable/environment-variable-validation.test.js +20 -0
  32. package/dist/__tests__/environment-variable/environment-variable-validation.test.js.map +1 -0
  33. package/dist/__tests__/fixtures/demo-project/index.js +1 -1
  34. package/dist/__tests__/fixtures/demo-project/index.js.map +1 -1
  35. package/dist/__tests__/git-flags.e2e.test.d.ts +1 -0
  36. package/dist/__tests__/git-flags.e2e.test.js +124 -0
  37. package/dist/__tests__/git-flags.e2e.test.js.map +1 -0
  38. package/dist/__tests__/git.e2e.test.d.ts +1 -0
  39. package/dist/__tests__/git.e2e.test.js +221 -0
  40. package/dist/__tests__/git.e2e.test.js.map +1 -0
  41. package/dist/__tests__/logs.e2e.test.d.ts +1 -0
  42. package/dist/__tests__/logs.e2e.test.js +227 -0
  43. package/dist/__tests__/logs.e2e.test.js.map +1 -0
  44. package/dist/__tests__/mock-server.d.ts +16 -0
  45. package/dist/__tests__/mock-server.js +440 -25
  46. package/dist/__tests__/mock-server.js.map +1 -1
  47. package/dist/__tests__/publish.e2e.test.d.ts +1 -0
  48. package/dist/__tests__/publish.e2e.test.js +505 -0
  49. package/dist/__tests__/publish.e2e.test.js.map +1 -0
  50. package/dist/__tests__/tunnel.e2e.test.d.ts +1 -0
  51. package/dist/__tests__/tunnel.e2e.test.js +64 -0
  52. package/dist/__tests__/tunnel.e2e.test.js.map +1 -0
  53. package/dist/__tests__/utils.d.ts +44 -1
  54. package/dist/__tests__/utils.js +195 -11
  55. package/dist/__tests__/utils.js.map +1 -1
  56. package/dist/api.d.ts +1 -2
  57. package/dist/api.js +6 -10
  58. package/dist/api.js.map +1 -1
  59. package/dist/commands/deploy.d.ts +7 -4
  60. package/dist/commands/deploy.js +47 -28
  61. package/dist/commands/deploy.js.map +1 -1
  62. package/dist/commands/deployment/inspect.d.ts +11 -0
  63. package/dist/commands/deployment/inspect.js +91 -0
  64. package/dist/commands/deployment/inspect.js.map +1 -0
  65. package/dist/commands/deployment/list.d.ts +11 -0
  66. package/dist/commands/deployment/list.js +97 -0
  67. package/dist/commands/deployment/list.js.map +1 -0
  68. package/dist/commands/deployment/logs.d.ts +12 -0
  69. package/dist/commands/deployment/logs.js +50 -0
  70. package/dist/commands/deployment/logs.js.map +1 -0
  71. package/dist/commands/environment-variable/add.d.ts +14 -0
  72. package/dist/commands/environment-variable/add.js +46 -0
  73. package/dist/commands/environment-variable/add.js.map +1 -0
  74. package/dist/commands/environment-variable/list.d.ts +9 -0
  75. package/dist/commands/environment-variable/list.js +44 -0
  76. package/dist/commands/environment-variable/list.js.map +1 -0
  77. package/dist/commands/environment-variable/remove.d.ts +11 -0
  78. package/dist/commands/environment-variable/remove.js +32 -0
  79. package/dist/commands/environment-variable/remove.js.map +1 -0
  80. package/dist/commands/environment-variable/update.d.ts +13 -0
  81. package/dist/commands/environment-variable/update.js +40 -0
  82. package/dist/commands/environment-variable/update.js.map +1 -0
  83. package/dist/commands/git/connect.d.ts +10 -0
  84. package/dist/commands/git/connect.js +60 -0
  85. package/dist/commands/git/connect.js.map +1 -0
  86. package/dist/commands/git/disconnect.d.ts +9 -0
  87. package/dist/commands/git/disconnect.js +45 -0
  88. package/dist/commands/git/disconnect.js.map +1 -0
  89. package/dist/commands/git.d.ts +6 -0
  90. package/dist/commands/git.js +17 -0
  91. package/dist/commands/git.js.map +1 -0
  92. package/dist/commands/login.d.ts +6 -0
  93. package/dist/commands/login.js +34 -0
  94. package/dist/commands/login.js.map +1 -0
  95. package/dist/commands/logout.d.ts +6 -0
  96. package/dist/commands/logout.js +20 -0
  97. package/dist/commands/logout.js.map +1 -0
  98. package/dist/commands/logs.d.ts +16 -0
  99. package/dist/commands/logs.js +96 -0
  100. package/dist/commands/logs.js.map +1 -0
  101. package/dist/commands/publish.d.ts +15 -0
  102. package/dist/commands/publish.js +51 -0
  103. package/dist/commands/publish.js.map +1 -0
  104. package/dist/commands/tunnel.d.ts +9 -0
  105. package/dist/commands/tunnel.js +53 -0
  106. package/dist/commands/tunnel.js.map +1 -0
  107. package/dist/commands/whoami.d.ts +6 -0
  108. package/dist/commands/whoami.js +13 -0
  109. package/dist/commands/whoami.js.map +1 -0
  110. package/dist/env.d.ts +4 -0
  111. package/dist/env.js +10 -0
  112. package/dist/env.js.map +1 -0
  113. package/dist/lib/alpic-command.d.ts +6 -0
  114. package/dist/lib/alpic-command.js +27 -0
  115. package/dist/lib/alpic-command.js.map +1 -0
  116. package/dist/lib/archive.d.ts +3 -3
  117. package/dist/lib/archive.js +11 -15
  118. package/dist/lib/archive.js.map +1 -1
  119. package/dist/lib/auth/auth.d.ts +2 -0
  120. package/dist/lib/auth/auth.js +21 -0
  121. package/dist/lib/auth/auth.js.map +1 -0
  122. package/dist/lib/auth/oauth/client.d.ts +28 -0
  123. package/dist/lib/auth/oauth/client.js +110 -0
  124. package/dist/lib/auth/oauth/client.js.map +1 -0
  125. package/dist/lib/auth/oauth/constants.d.ts +2 -0
  126. package/dist/lib/auth/oauth/constants.js +3 -0
  127. package/dist/lib/auth/oauth/constants.js.map +1 -0
  128. package/dist/lib/auth/oauth/server/assets/alpic-mountain.png +0 -0
  129. package/dist/lib/auth/oauth/server/assets/authorize.html +195 -0
  130. package/dist/lib/auth/oauth/server/assets/callback.html +88 -0
  131. package/dist/lib/auth/oauth/server/index.d.ts +8 -0
  132. package/dist/lib/auth/oauth/server/index.js +105 -0
  133. package/dist/lib/auth/oauth/server/index.js.map +1 -0
  134. package/dist/lib/auth/whoami.d.ts +1 -0
  135. package/dist/lib/auth/whoami.js +41 -0
  136. package/dist/lib/auth/whoami.js.map +1 -0
  137. package/dist/lib/base-workflow.d.ts +10 -0
  138. package/dist/lib/base-workflow.js +22 -0
  139. package/dist/lib/base-workflow.js.map +1 -0
  140. package/dist/lib/config.d.ts +2 -2
  141. package/dist/lib/config.js +7 -7
  142. package/dist/lib/config.js.map +1 -1
  143. package/dist/lib/deployment.d.ts +70 -3
  144. package/dist/lib/deployment.js +121 -10
  145. package/dist/lib/deployment.js.map +1 -1
  146. package/dist/lib/environment-variable.d.ts +41 -0
  147. package/dist/lib/environment-variable.js +311 -0
  148. package/dist/lib/environment-variable.js.map +1 -0
  149. package/dist/lib/git.d.ts +22 -0
  150. package/dist/lib/git.js +131 -0
  151. package/dist/lib/git.js.map +1 -0
  152. package/dist/lib/global-store.d.ts +28 -0
  153. package/dist/lib/global-store.js +76 -0
  154. package/dist/lib/global-store.js.map +1 -0
  155. package/dist/lib/logs.d.ts +20 -0
  156. package/dist/lib/logs.js +86 -0
  157. package/dist/lib/logs.js.map +1 -0
  158. package/dist/lib/project.d.ts +68 -61
  159. package/dist/lib/project.js +275 -250
  160. package/dist/lib/project.js.map +1 -1
  161. package/dist/lib/publish.d.ts +22 -0
  162. package/dist/lib/publish.js +188 -0
  163. package/dist/lib/publish.js.map +1 -0
  164. package/dist/lib/table.d.ts +8 -0
  165. package/dist/lib/table.js +27 -0
  166. package/dist/lib/table.js.map +1 -0
  167. package/dist/lib/telemetry.js +7 -7
  168. package/dist/lib/telemetry.js.map +1 -1
  169. package/dist/lib/utils.d.ts +4 -0
  170. package/dist/lib/utils.js +45 -0
  171. package/dist/lib/utils.js.map +1 -0
  172. package/dist/lib/utils.test.d.ts +1 -0
  173. package/dist/lib/utils.test.js +27 -0
  174. package/dist/lib/utils.test.js.map +1 -0
  175. package/package.json +35 -31
  176. package/dist/lib/global-config.d.ts +0 -9
  177. package/dist/lib/global-config.js +0 -48
  178. package/dist/lib/global-config.js.map +0 -1
@@ -0,0 +1,221 @@
1
+ import { rmSync } from "node:fs";
2
+ import { join } from "node:path";
3
+ import { afterEach, beforeEach, describe, expect, it } from "vitest";
4
+ import { MockApiServer } from "./mock-server.js";
5
+ import { buildMockProject, cliSession, createConfigFile, createOAuthEnv, expectSuccessfulApiCall, runGit, setupTestDirectory, } from "./utils.js";
6
+ describe("alpic git connect/disconnect (E2E)", () => {
7
+ let mockServer;
8
+ let serverUrl;
9
+ let cwd;
10
+ let binPath;
11
+ const projectId = "project-id";
12
+ const teamId = "team-id";
13
+ const environmentId = "env-id";
14
+ function setupProject(overrides) {
15
+ mockServer.addProject(buildMockProject({
16
+ projectId,
17
+ teamId,
18
+ projectName: "demo",
19
+ environmentId,
20
+ environmentName: "production",
21
+ sourceRepository: null,
22
+ sourceBranch: "main",
23
+ ...overrides,
24
+ }));
25
+ createConfigFile(cwd, projectId, teamId, "demo", environmentId, "production");
26
+ }
27
+ beforeEach(async () => {
28
+ mockServer = new MockApiServer();
29
+ serverUrl = await mockServer.start();
30
+ const setup = await setupTestDirectory({ initGit: true });
31
+ cwd = setup.cwd;
32
+ binPath = setup.binPath;
33
+ });
34
+ afterEach(async () => {
35
+ await mockServer.stop();
36
+ if (cwd) {
37
+ rmSync(cwd, { recursive: true, force: true });
38
+ }
39
+ });
40
+ it("connects using selected remote source when multiple remotes are available", async () => {
41
+ setupProject();
42
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
43
+ cwd,
44
+ env: {
45
+ ALPIC_API_BASE_URL: serverUrl,
46
+ ALPIC_API_KEY: "test-api-key",
47
+ },
48
+ }, async (cli) => {
49
+ await cli.expect("Choose the remote source to connect");
50
+ await cli.send("\u001B[B"); // Move down one option (select acme/backend)
51
+ await cli.send("");
52
+ await cli.expect("✅ Connected");
53
+ });
54
+ expect(exitCode).toBe(0);
55
+ expect(output).toMatch(/Connected .*acme\/backend.* to project .*demo.*\./);
56
+ expect(output).toContain("make sure to install the Alpic GitHub App on this repository.");
57
+ const updateCall = mockServer.getLastCall("PATCH", `/v1/projects/${projectId}`);
58
+ expectSuccessfulApiCall(updateCall, (call) => {
59
+ expect(call.input).toMatchObject({
60
+ sourceRepository: "acme/backend",
61
+ });
62
+ });
63
+ });
64
+ it("requires linked Alpic project config", async () => {
65
+ rmSync(join(cwd, ".alpic"), { recursive: true, force: true });
66
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
67
+ cwd,
68
+ env: {
69
+ ALPIC_API_BASE_URL: serverUrl,
70
+ ALPIC_API_KEY: "test-api-key",
71
+ },
72
+ }, async (cli) => {
73
+ await cli.expect("This directory is not linked to an Alpic project. Link it first using `alpic deploy`.");
74
+ });
75
+ expect(exitCode).toBe(1);
76
+ expect(output).toContain("This directory is not linked to an Alpic project. Link it first using `alpic deploy`.");
77
+ });
78
+ it("shows git setup instructions when directory is not a git repository", async () => {
79
+ setupProject();
80
+ rmSync(join(cwd, ".git"), { recursive: true, force: true });
81
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
82
+ cwd,
83
+ env: {
84
+ ALPIC_API_BASE_URL: serverUrl,
85
+ ALPIC_API_KEY: "test-api-key",
86
+ },
87
+ }, async (cli) => {
88
+ await cli.expect("This directory is not a git repository.");
89
+ await cli.expect("To set up a git repository");
90
+ await cli.expect("git init");
91
+ });
92
+ expect(exitCode).toBe(0);
93
+ expect(output).toContain("This directory is not a git repository.");
94
+ expect(output).toContain("To set up a git repository");
95
+ expect(output).toContain("git init");
96
+ });
97
+ it("shows git setup instructions when repository has no remotes", async () => {
98
+ setupProject();
99
+ runGit(["remote", "remove", "origin"], cwd);
100
+ runGit(["remote", "remove", "upstream"], cwd);
101
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
102
+ cwd,
103
+ env: {
104
+ ALPIC_API_BASE_URL: serverUrl,
105
+ ALPIC_API_KEY: "test-api-key",
106
+ },
107
+ }, async (cli) => {
108
+ await cli.expect("This git repository has no remotes configured.");
109
+ await cli.expect("To set up a git repository");
110
+ await cli.expect("git init");
111
+ });
112
+ expect(exitCode).toBe(0);
113
+ expect(output).toContain("This git repository has no remotes configured.");
114
+ expect(output).toContain("To set up a git repository");
115
+ expect(output).toContain("git init");
116
+ });
117
+ it("when project is already connected, prompts to link another and exits if user declines", async () => {
118
+ setupProject({ sourceRepository: "acme/backend" });
119
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
120
+ cwd,
121
+ env: {
122
+ ALPIC_API_BASE_URL: serverUrl,
123
+ ALPIC_API_KEY: "test-api-key",
124
+ },
125
+ }, async (cli) => {
126
+ await cli.expect(/Project .*demo.* is already connected to .*acme\/backend.*\./);
127
+ await cli.expect("Do you want to link another repository?");
128
+ await cli.send(""); // accept default (No)
129
+ await cli.expect("Git connect cancelled");
130
+ });
131
+ expect(exitCode).toBe(1);
132
+ expect(output).toMatch(/Project .*demo.* is already connected to .*acme\/backend.*\./);
133
+ expect(output).toContain("Git connect cancelled");
134
+ expect(mockServer.getCalls("PATCH", "/v1/projects/")).toHaveLength(0);
135
+ });
136
+ it("disconnect fails with clear message when project is not connected", async () => {
137
+ setupProject(); // sourceRepository is null by default
138
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "disconnect"], {
139
+ cwd,
140
+ env: {
141
+ ALPIC_API_BASE_URL: serverUrl,
142
+ ALPIC_API_KEY: "test-api-key",
143
+ },
144
+ }, async (cli) => {
145
+ await cli.expect(/Project .*demo.* is not connected to any repository\./);
146
+ });
147
+ expect(exitCode).toBe(1);
148
+ expect(output).toMatch(/Project .*demo.* is not connected to any repository\./);
149
+ expect(mockServer.getCalls("PATCH", "/v1/projects/")).toHaveLength(0);
150
+ });
151
+ it("disconnects an already connected project repository", async () => {
152
+ setupProject({ sourceRepository: "acme/frontend" });
153
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "disconnect"], {
154
+ cwd,
155
+ env: {
156
+ ALPIC_API_BASE_URL: serverUrl,
157
+ ALPIC_API_KEY: "test-api-key",
158
+ },
159
+ }, async (cli) => {
160
+ await cli.expect(/Are you sure you want to disconnect .*acme\/frontend.* from project .*demo.*\?/);
161
+ await cli.send("\u001B[A"); // arrow up to select Yes
162
+ await cli.send("");
163
+ await cli.expect(/Disconnected .*acme\/frontend.* from project .*demo.*\./);
164
+ });
165
+ expect(exitCode).toBe(0);
166
+ expect(output).toMatch(/Disconnected .*acme\/frontend.* from project .*demo.*\./);
167
+ const updateCall = mockServer.getLastCall("PATCH", `/v1/projects/${projectId}`);
168
+ expectSuccessfulApiCall(updateCall, (call) => {
169
+ expect(call.input).toMatchObject({
170
+ sourceRepository: null,
171
+ });
172
+ });
173
+ });
174
+ it("git connect works with OAuth auth (no API key)", async () => {
175
+ setupProject();
176
+ const oauthEnv = createOAuthEnv(cwd, serverUrl);
177
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "connect"], {
178
+ cwd,
179
+ env: {
180
+ ...oauthEnv,
181
+ },
182
+ }, async (cli) => {
183
+ await cli.expect("Choose the remote source to connect");
184
+ await cli.send("\u001B[B"); // Move down one option (select acme/backend)
185
+ await cli.send("");
186
+ await cli.expect("✅ Connected");
187
+ });
188
+ expect(exitCode).toBe(0);
189
+ expect(output).toMatch(/Connected .*acme\/backend.* to project .*demo.*\./);
190
+ const updateCall = mockServer.getLastCall("PATCH", `/v1/projects/${projectId}`);
191
+ expectSuccessfulApiCall(updateCall, (call) => {
192
+ expect(call.input).toMatchObject({
193
+ sourceRepository: "acme/backend",
194
+ });
195
+ });
196
+ });
197
+ it("git disconnect works with OAuth auth (no API key)", async () => {
198
+ setupProject({ sourceRepository: "acme/frontend" });
199
+ const oauthEnv = createOAuthEnv(cwd, serverUrl);
200
+ const { exitCode, output } = await cliSession(process.execPath, [binPath, "git", "disconnect"], {
201
+ cwd,
202
+ env: {
203
+ ...oauthEnv,
204
+ },
205
+ }, async (cli) => {
206
+ await cli.expect(/Are you sure you want to disconnect .*acme\/frontend.* from project .*demo.*\?/);
207
+ await cli.send("\u001B[A"); // arrow up to select Yes
208
+ await cli.send("");
209
+ await cli.expect(/Disconnected .*acme\/frontend.* from project .*demo.*\./);
210
+ });
211
+ expect(exitCode).toBe(0);
212
+ expect(output).toMatch(/Disconnected .*acme\/frontend.* from project .*demo.*\./);
213
+ const updateCall = mockServer.getLastCall("PATCH", `/v1/projects/${projectId}`);
214
+ expectSuccessfulApiCall(updateCall, (call) => {
215
+ expect(call.input).toMatchObject({
216
+ sourceRepository: null,
217
+ });
218
+ });
219
+ });
220
+ }, 20_000);
221
+ //# sourceMappingURL=git.e2e.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git.e2e.test.js","sourceRoot":"","sources":["../../src/__tests__/git.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).toMatch(/error|not found/i);
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).toMatch(/not authenticated|alpic login|ALPIC_API_KEY/i);
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":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAGrE,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,EACL,gBAAgB,EAChB,UAAU,EACV,gBAAgB,EAChB,uBAAuB,EACvB,kBAAkB,GACnB,MAAM,YAAY,CAAC;AAEpB,MAAM,MAAM,GAAG,eAAe,CAAC;AAC/B,MAAM,UAAU,GAAG,eAAe,CAAC;AACnC,MAAM,OAAO,GAAG,cAAc,CAAC;AAE/B,SAAS,KAAK,CAAC,EAAU;IACvB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC;AAED,SAAS,QAAQ;IACf,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAClD,OAAO;QACL;YACE,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACvC,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,OAAO;YAClB,OAAO,EAAE,gBAAgB;SAC1B;QACD;YACE,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACvC,IAAI,EAAE,SAAS;YACf,SAAS,EAAE,OAAO;YAClB,OAAO,EAAE,YAAY;SACtB;QACD;YACE,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACvC,IAAI,EAAE,OAAO;YACb,SAAS,EAAE,OAAO;YAClB,OAAO,EAAE,aAAa;SACvB;QACD;YACE,SAAS,EAAE,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;YACvC,IAAI,EAAE,OAAO;YACb,SAAS,EAAE,OAAO;YAClB,OAAO,EAAE,YAAY;SACtB;KACF,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,IAAI,UAAyB,CAAC;IAC9B,IAAI,SAAiB,CAAC;IACtB,IAAI,GAAW,CAAC;IAChB,IAAI,OAAe,CAAC;IAEpB,UAAU,CAAC,KAAK,IAAI,EAAE;QACpB,UAAU,GAAG,IAAI,aAAa,EAAE,CAAC;QACjC,SAAS,GAAG,MAAM,UAAU,CAAC,KAAK,EAAE,CAAC;QACrC,MAAM,KAAK,GAAG,MAAM,kBAAkB,EAAE,CAAC;QACzC,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QAChB,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAExB,UAAU,CAAC,UAAU,CACnB,gBAAgB,CAAC;YACf,SAAS,EAAE,UAAU;YACrB,MAAM,EAAE,OAAO;YACf,WAAW,EAAE,cAAc;YAC3B,aAAa,EAAE,MAAM;YACrB,eAAe,EAAE,YAAY;SAC9B,CAAC,CACH,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,KAAK,IAAI,EAAE;QACnB,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;QACxB,IAAI,GAAG;YAAE,MAAM,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0DAA0D,EAAE,KAAK,IAAI,EAAE;QACxE,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE;YACjF,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAC3C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAEvC,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAE9C,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,CAAC,EAAE;YACrG,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACtC,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE;YAC1F,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,CAAC,IAAI,EAAE,KAAiC,CAAA,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,KAAK,IAAI,EAAE;QACzC,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACtC,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,sBAAsB,CAAC,EAAE;YAC5G,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,CAAC,IAAI,EAAE,KAAiC,CAAA,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACtF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QAC1C,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACtC,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,CAAC,EAAE;YAChG,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,CAAC,IAAI,EAAE,KAAiC,CAAA,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;QACvE,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE;YACrG,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAC3C,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QAE3C,MAAM,IAAI,GAAG,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QAC3E,uBAAuB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAC3C,OAAO,CAAC,QAAQ,EAChB,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,EAC3D;YACE,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CACF,CAAC;QAEF,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACvC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACnD,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE;YACrG,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE;YAC/F,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;QAClD,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;QAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,oBAAoB,CAAC,CAAC;QAC/C,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,EAAE;YAC9G,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,uCAAuC,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;QAC9C,UAAU,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC9C,gBAAgB,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;QAEjF,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CACjC,OAAO,CAAC,QAAQ,EAChB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,EAC7B;YACE,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;YACrE,SAAS,EAAE,MAAM;SAClB,EACD,KAAK,EAAE,GAAG,EAAE,EAAE;YACZ,MAAM,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;YACnC,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC;YACnB,GAAG,CAAC,IAAI,EAAE,CAAC;QACb,CAAC,CACF,CAAC;QAEF,6EAA6E;QAC7E,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAE3C,MAAM,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,EAAE,8BAA8B,CAAC,CAAC;QACzE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3B,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;QAChC,MAAM,CAAC,UAAU,CAAC,CAAC,WAAW,EAAE,CAAC;QACjC,MAAM,CAAC,CAAC,SAAS,EAAE,KAAiC,CAAA,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxE,MAAM,CAAC,CAAC,UAAU,EAAE,KAAiC,CAAA,CAAC,KAAK,CAAC,CAAC,OAAO,CAClE,+CAA+C,CAChD,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAC3C,OAAO,CAAC,QAAQ,EAChB,CAAC,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,iBAAiB,CAAC,EACxD;YACE,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE;SACtE,CACF,CAAC;QAEF,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,CAAC,EAAE;YAC7G,GAAG;YACH,GAAG,EAAE,EAAE,kBAAkB,EAAE,SAAS,EAAE;SACvC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,8CAA8C,CAAC,CAAC;IACzE,CAAC,CAAC,CAAC;AACL,CAAC,EAAE,MAAM,CAAC,CAAC"}
@@ -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"]["info"]["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,5 +27,12 @@ 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
+ addEnvironmentVariables(environmentId: string, variables: RouterOutput["environmentVariables"]["list"]["v1"]): void;
31
+ setRuntimeLogs(environmentId: string, logs: MockRuntimeLog[]): void;
32
+ setRuntimeLogPages(environmentId: string, pages: MockRuntimeLog[][]): void;
33
+ setPublishedServer(projectId: string, domain: string, server: PublishedServer): void;
34
+ addDeployments(deployments: RouterOutput["deployments"]["list"]["v1"]): void;
35
+ setDeploymentLogPages(deploymentId: string, pages: MockDeploymentLogPage[]): void;
21
36
  addProject(project: RouterOutput["projects"]["get"]["v1"]): void;
22
37
  }
38
+ export {};