@arcadialdev/arcality 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/.agents/skills/e2e-testing-expert/SKILL.md +28 -0
  2. package/.agents/skills/frontend-design/LICENSE.txt +177 -0
  3. package/.agents/skills/frontend-design/SKILL.md +42 -0
  4. package/.agents/skills/nodejs-backend-patterns/SKILL.md +639 -0
  5. package/.agents/skills/nodejs-backend-patterns/references/advanced-patterns.md +430 -0
  6. package/.agents/skills/playwright-best-practices/LICENSE.md +7 -0
  7. package/.agents/skills/playwright-best-practices/README.md +147 -0
  8. package/.agents/skills/playwright-best-practices/SKILL.md +303 -0
  9. package/.agents/skills/playwright-best-practices/advanced/authentication-flows.md +360 -0
  10. package/.agents/skills/playwright-best-practices/advanced/authentication.md +871 -0
  11. package/.agents/skills/playwright-best-practices/advanced/clock-mocking.md +364 -0
  12. package/.agents/skills/playwright-best-practices/advanced/mobile-testing.md +409 -0
  13. package/.agents/skills/playwright-best-practices/advanced/multi-context.md +288 -0
  14. package/.agents/skills/playwright-best-practices/advanced/multi-user.md +393 -0
  15. package/.agents/skills/playwright-best-practices/advanced/network-advanced.md +452 -0
  16. package/.agents/skills/playwright-best-practices/advanced/third-party.md +464 -0
  17. package/.agents/skills/playwright-best-practices/architecture/pom-vs-fixtures.md +363 -0
  18. package/.agents/skills/playwright-best-practices/architecture/test-architecture.md +369 -0
  19. package/.agents/skills/playwright-best-practices/architecture/when-to-mock.md +383 -0
  20. package/.agents/skills/playwright-best-practices/browser-apis/browser-apis.md +391 -0
  21. package/.agents/skills/playwright-best-practices/browser-apis/iframes.md +403 -0
  22. package/.agents/skills/playwright-best-practices/browser-apis/service-workers.md +504 -0
  23. package/.agents/skills/playwright-best-practices/browser-apis/websockets.md +403 -0
  24. package/.agents/skills/playwright-best-practices/core/annotations.md +424 -0
  25. package/.agents/skills/playwright-best-practices/core/assertions-waiting.md +361 -0
  26. package/.agents/skills/playwright-best-practices/core/configuration.md +452 -0
  27. package/.agents/skills/playwright-best-practices/core/fixtures-hooks.md +417 -0
  28. package/.agents/skills/playwright-best-practices/core/global-setup.md +434 -0
  29. package/.agents/skills/playwright-best-practices/core/locators.md +242 -0
  30. package/.agents/skills/playwright-best-practices/core/page-object-model.md +315 -0
  31. package/.agents/skills/playwright-best-practices/core/projects-dependencies.md +453 -0
  32. package/.agents/skills/playwright-best-practices/core/test-data.md +492 -0
  33. package/.agents/skills/playwright-best-practices/core/test-suite-structure.md +361 -0
  34. package/.agents/skills/playwright-best-practices/core/test-tags.md +298 -0
  35. package/.agents/skills/playwright-best-practices/debugging/console-errors.md +420 -0
  36. package/.agents/skills/playwright-best-practices/debugging/debugging.md +504 -0
  37. package/.agents/skills/playwright-best-practices/debugging/error-testing.md +360 -0
  38. package/.agents/skills/playwright-best-practices/debugging/flaky-tests.md +496 -0
  39. package/.agents/skills/playwright-best-practices/frameworks/angular.md +530 -0
  40. package/.agents/skills/playwright-best-practices/frameworks/nextjs.md +469 -0
  41. package/.agents/skills/playwright-best-practices/frameworks/react.md +531 -0
  42. package/.agents/skills/playwright-best-practices/frameworks/vue.md +574 -0
  43. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/ci-cd.md +468 -0
  44. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/docker.md +283 -0
  45. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/github-actions.md +546 -0
  46. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/gitlab.md +397 -0
  47. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/other-providers.md +521 -0
  48. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/parallel-sharding.md +371 -0
  49. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/performance.md +453 -0
  50. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/reporting.md +424 -0
  51. package/.agents/skills/playwright-best-practices/infrastructure-ci-cd/test-coverage.md +497 -0
  52. package/.agents/skills/playwright-best-practices/testing-patterns/accessibility.md +359 -0
  53. package/.agents/skills/playwright-best-practices/testing-patterns/api-testing.md +719 -0
  54. package/.agents/skills/playwright-best-practices/testing-patterns/browser-extensions.md +506 -0
  55. package/.agents/skills/playwright-best-practices/testing-patterns/canvas-webgl.md +493 -0
  56. package/.agents/skills/playwright-best-practices/testing-patterns/component-testing.md +500 -0
  57. package/.agents/skills/playwright-best-practices/testing-patterns/drag-drop.md +576 -0
  58. package/.agents/skills/playwright-best-practices/testing-patterns/electron.md +509 -0
  59. package/.agents/skills/playwright-best-practices/testing-patterns/file-operations.md +377 -0
  60. package/.agents/skills/playwright-best-practices/testing-patterns/file-upload-download.md +562 -0
  61. package/.agents/skills/playwright-best-practices/testing-patterns/forms-validation.md +561 -0
  62. package/.agents/skills/playwright-best-practices/testing-patterns/graphql-testing.md +331 -0
  63. package/.agents/skills/playwright-best-practices/testing-patterns/i18n.md +508 -0
  64. package/.agents/skills/playwright-best-practices/testing-patterns/performance-testing.md +476 -0
  65. package/.agents/skills/playwright-best-practices/testing-patterns/security-testing.md +430 -0
  66. package/.agents/skills/playwright-best-practices/testing-patterns/visual-regression.md +634 -0
  67. package/.env.example +21 -0
  68. package/README.md +30 -0
  69. package/bin/arcality.mjs +86 -0
  70. package/package.json +66 -0
  71. package/playwright.config.ts +12 -0
  72. package/scripts/cleanup-qmsdev.mjs +63 -0
  73. package/scripts/discover-view.mjs +52 -0
  74. package/scripts/extract-view.mjs +64 -0
  75. package/scripts/gen-and-run.mjs +838 -0
  76. package/scripts/init.mjs +290 -0
  77. package/scripts/migrate-to-central-out.mjs +157 -0
  78. package/scripts/postinstall.mjs +63 -0
  79. package/scripts/rebrand-report.mjs +241 -0
  80. package/scripts/setup.mjs +166 -0
  81. package/src/KnowledgeService.ts +239 -0
  82. package/src/arcalityClient.mjs +266 -0
  83. package/src/configLoader.mjs +179 -0
  84. package/src/configManager.mjs +172 -0
  85. package/src/consoleBanner.ts +32 -0
  86. package/src/envSetup.ts +205 -0
  87. package/src/index.ts +25 -0
  88. package/src/projectInspector.ts +42 -0
  89. package/src/services/collectiveMemoryService.ts +178 -0
  90. package/src/testRunner.ts +201 -0
  91. package/tests/_helpers/ArcalityReporter.ts +490 -0
  92. package/tests/_helpers/agentic-runner.spec.ts +741 -0
  93. package/tests/_helpers/ai-agent-helper.ts +1573 -0
  94. package/tests/_helpers/discover-view.spec.ts +238 -0
  95. package/tests/_helpers/extract-view.spec.ts +118 -0
  96. package/tests/_helpers/qa-tools.ts +333 -0
  97. package/tests/_helpers/smart-action.spec.ts +1458 -0
@@ -0,0 +1,453 @@
1
+ # Projects & Dependencies
2
+
3
+ ## Table of Contents
4
+
5
+ 1. [Project Configuration](#project-configuration)
6
+ 2. [Project Dependencies](#project-dependencies)
7
+ 3. [Setup Projects](#setup-projects)
8
+ 4. [Filtering & Running Projects](#filtering--running-projects)
9
+ 5. [Sharing Configuration](#sharing-configuration)
10
+ 6. [Advanced Patterns](#advanced-patterns)
11
+
12
+ ## Project Configuration
13
+
14
+ ### Basic Multi-Browser Setup
15
+
16
+ ```typescript
17
+ // playwright.config.ts
18
+ import { defineConfig, devices } from "@playwright/test";
19
+
20
+ export default defineConfig({
21
+ projects: [
22
+ {
23
+ name: "chromium",
24
+ use: { ...devices["Desktop Chrome"] },
25
+ },
26
+ {
27
+ name: "firefox",
28
+ use: { ...devices["Desktop Firefox"] },
29
+ },
30
+ {
31
+ name: "webkit",
32
+ use: { ...devices["Desktop Safari"] },
33
+ },
34
+ ],
35
+ });
36
+ ```
37
+
38
+ ### Environment-Based Projects
39
+
40
+ ```typescript
41
+ export default defineConfig({
42
+ projects: [
43
+ {
44
+ name: "staging",
45
+ use: {
46
+ baseURL: "https://staging.example.com",
47
+ },
48
+ },
49
+ {
50
+ name: "production",
51
+ use: {
52
+ baseURL: "https://example.com",
53
+ },
54
+ },
55
+ {
56
+ name: "local",
57
+ use: {
58
+ baseURL: "http://localhost:3000",
59
+ },
60
+ },
61
+ ],
62
+ });
63
+ ```
64
+
65
+ ### Test Type Projects
66
+
67
+ ```typescript
68
+ export default defineConfig({
69
+ projects: [
70
+ {
71
+ name: "e2e",
72
+ testDir: "./tests/e2e",
73
+ use: { ...devices["Desktop Chrome"] },
74
+ },
75
+ {
76
+ name: "api",
77
+ testDir: "./tests/api",
78
+ use: { baseURL: "http://localhost:3000" },
79
+ },
80
+ {
81
+ name: "visual",
82
+ testDir: "./tests/visual",
83
+ use: {
84
+ ...devices["Desktop Chrome"],
85
+ viewport: { width: 1280, height: 720 },
86
+ },
87
+ },
88
+ ],
89
+ });
90
+ ```
91
+
92
+ ## Project Dependencies
93
+
94
+ ### Setup Dependency
95
+
96
+ ```typescript
97
+ export default defineConfig({
98
+ projects: [
99
+ // Setup project runs first
100
+ {
101
+ name: "setup",
102
+ testMatch: /.*\.setup\.ts/,
103
+ },
104
+
105
+ // Browser projects depend on setup
106
+ {
107
+ name: "chromium",
108
+ use: {
109
+ ...devices["Desktop Chrome"],
110
+ storageState: ".auth/user.json",
111
+ },
112
+ dependencies: ["setup"],
113
+ },
114
+ {
115
+ name: "firefox",
116
+ use: {
117
+ ...devices["Desktop Firefox"],
118
+ storageState: ".auth/user.json",
119
+ },
120
+ dependencies: ["setup"],
121
+ },
122
+ ],
123
+ });
124
+ ```
125
+
126
+ ### Multiple Auth States
127
+
128
+ ```typescript
129
+ export default defineConfig({
130
+ projects: [
131
+ // Auth setup projects
132
+ {
133
+ name: "setup-admin",
134
+ testMatch: /admin\.setup\.ts/,
135
+ },
136
+ {
137
+ name: "setup-user",
138
+ testMatch: /user\.setup\.ts/,
139
+ },
140
+
141
+ // Admin tests
142
+ {
143
+ name: "admin-tests",
144
+ testDir: "./tests/admin",
145
+ use: { storageState: ".auth/admin.json" },
146
+ dependencies: ["setup-admin"],
147
+ },
148
+
149
+ // User tests
150
+ {
151
+ name: "user-tests",
152
+ testDir: "./tests/user",
153
+ use: { storageState: ".auth/user.json" },
154
+ dependencies: ["setup-user"],
155
+ },
156
+
157
+ // Tests that need both
158
+ {
159
+ name: "integration-tests",
160
+ testDir: "./tests/integration",
161
+ dependencies: ["setup-admin", "setup-user"],
162
+ },
163
+ ],
164
+ });
165
+ ```
166
+
167
+ ### Chained Dependencies
168
+
169
+ ```typescript
170
+ export default defineConfig({
171
+ projects: [
172
+ // Step 1: Database setup
173
+ {
174
+ name: "db-setup",
175
+ testMatch: /db\.setup\.ts/,
176
+ },
177
+
178
+ // Step 2: Auth setup (needs DB)
179
+ {
180
+ name: "auth-setup",
181
+ testMatch: /auth\.setup\.ts/,
182
+ dependencies: ["db-setup"],
183
+ },
184
+
185
+ // Step 3: Seed data (needs auth)
186
+ {
187
+ name: "seed-setup",
188
+ testMatch: /seed\.setup\.ts/,
189
+ dependencies: ["auth-setup"],
190
+ },
191
+
192
+ // Tests (need everything)
193
+ {
194
+ name: "tests",
195
+ testDir: "./tests",
196
+ dependencies: ["seed-setup"],
197
+ },
198
+ ],
199
+ });
200
+ ```
201
+
202
+ ## Setup Projects
203
+
204
+ ### Authentication Setup
205
+
206
+ Setup projects are the recommended way to handle authentication. They run before your main test projects and can use Playwright fixtures.
207
+
208
+ > **For complete authentication patterns** (storage state, multiple auth states, auth fixtures), see [fixtures-hooks.md](fixtures-hooks.md#authentication-patterns).
209
+
210
+ ### Data Seeding Setup
211
+
212
+ ```typescript
213
+ // seed.setup.ts
214
+ import { test as setup } from "@playwright/test";
215
+
216
+ setup("seed test data", async ({ request }) => {
217
+ // Create test data via API
218
+ await request.post("/api/test/seed", {
219
+ data: {
220
+ users: 10,
221
+ products: 50,
222
+ orders: 100,
223
+ },
224
+ });
225
+ });
226
+ ```
227
+
228
+ ### Cleanup Setup
229
+
230
+ ```typescript
231
+ // cleanup.setup.ts
232
+ import { test as setup } from "@playwright/test";
233
+
234
+ setup("cleanup previous run", async ({ request }) => {
235
+ // Clean up data from previous test runs
236
+ await request.delete("/api/test/cleanup");
237
+ });
238
+ ```
239
+
240
+ ## Filtering & Running Projects
241
+
242
+ ### Run Specific Project
243
+
244
+ ```bash
245
+ # Run single project
246
+ npx playwright test --project=chromium
247
+
248
+ # Run multiple projects
249
+ npx playwright test --project=chromium --project=firefox
250
+ ```
251
+
252
+ ### Run by Grep
253
+
254
+ ```bash
255
+ # Run tests matching pattern
256
+ npx playwright test --grep @smoke
257
+
258
+ # Run project with grep
259
+ npx playwright test --project=chromium --grep @critical
260
+
261
+ # Exclude pattern
262
+ npx playwright test --grep-invert @slow
263
+ ```
264
+
265
+ ### Project-Specific Grep
266
+
267
+ ```typescript
268
+ export default defineConfig({
269
+ projects: [
270
+ {
271
+ name: "smoke",
272
+ grep: /@smoke/,
273
+ use: { ...devices["Desktop Chrome"] },
274
+ },
275
+ {
276
+ name: "regression",
277
+ grepInvert: /@smoke/,
278
+ use: { ...devices["Desktop Chrome"] },
279
+ },
280
+ ],
281
+ });
282
+ ```
283
+
284
+ ## Sharing Configuration
285
+
286
+ ### Base Configuration
287
+
288
+ ```typescript
289
+ // playwright.config.ts
290
+ const baseConfig = {
291
+ timeout: 30000,
292
+ expect: { timeout: 5000 },
293
+ use: {
294
+ trace: "on-first-retry",
295
+ screenshot: "only-on-failure",
296
+ },
297
+ };
298
+
299
+ export default defineConfig({
300
+ ...baseConfig,
301
+ projects: [
302
+ {
303
+ name: "chromium",
304
+ use: {
305
+ ...baseConfig.use,
306
+ ...devices["Desktop Chrome"],
307
+ },
308
+ },
309
+ {
310
+ name: "firefox",
311
+ use: {
312
+ ...baseConfig.use,
313
+ ...devices["Desktop Firefox"],
314
+ },
315
+ },
316
+ ],
317
+ });
318
+ ```
319
+
320
+ ### Shared Project Settings
321
+
322
+ ```typescript
323
+ const sharedBrowserConfig = {
324
+ timeout: 60000,
325
+ retries: 2,
326
+ use: {
327
+ video: "on-first-retry",
328
+ trace: "on-first-retry",
329
+ },
330
+ };
331
+
332
+ export default defineConfig({
333
+ projects: [
334
+ {
335
+ name: "chromium",
336
+ ...sharedBrowserConfig,
337
+ use: {
338
+ ...sharedBrowserConfig.use,
339
+ ...devices["Desktop Chrome"],
340
+ },
341
+ },
342
+ {
343
+ name: "firefox",
344
+ ...sharedBrowserConfig,
345
+ use: {
346
+ ...sharedBrowserConfig.use,
347
+ ...devices["Desktop Firefox"],
348
+ },
349
+ },
350
+ ],
351
+ });
352
+ ```
353
+
354
+ ## Advanced Patterns
355
+
356
+ ### Conditional Projects
357
+
358
+ ```typescript
359
+ const projects = [
360
+ {
361
+ name: "chromium",
362
+ use: { ...devices["Desktop Chrome"] },
363
+ },
364
+ ];
365
+
366
+ // Add Firefox only in CI
367
+ if (process.env.CI) {
368
+ projects.push({
369
+ name: "firefox",
370
+ use: { ...devices["Desktop Firefox"] },
371
+ });
372
+ }
373
+
374
+ // Add mobile only for specific test dirs
375
+ if (process.env.TEST_MOBILE) {
376
+ projects.push({
377
+ name: "mobile",
378
+ use: { ...devices["iPhone 14"] },
379
+ });
380
+ }
381
+
382
+ export default defineConfig({ projects });
383
+ ```
384
+
385
+ ### Project Metadata
386
+
387
+ ```typescript
388
+ export default defineConfig({
389
+ projects: [
390
+ {
391
+ name: "chromium",
392
+ use: { ...devices["Desktop Chrome"] },
393
+ metadata: {
394
+ platform: "desktop",
395
+ browser: "chromium",
396
+ priority: "high",
397
+ },
398
+ },
399
+ ],
400
+ });
401
+
402
+ // Access in test
403
+ test("example", async ({ page }, testInfo) => {
404
+ const { platform, priority } = testInfo.project.metadata;
405
+ console.log(`Running on ${platform} with ${priority} priority`);
406
+ });
407
+ ```
408
+
409
+ ### Teardown Projects
410
+
411
+ ```typescript
412
+ export default defineConfig({
413
+ projects: [
414
+ {
415
+ name: "setup",
416
+ testMatch: /.*\.setup\.ts/,
417
+ teardown: "teardown", // Run teardown after this completes
418
+ },
419
+ {
420
+ name: "teardown",
421
+ testMatch: /.*\.teardown\.ts/,
422
+ },
423
+ {
424
+ name: "tests",
425
+ dependencies: ["setup"],
426
+ },
427
+ ],
428
+ });
429
+ ```
430
+
431
+ ```typescript
432
+ // cleanup.teardown.ts
433
+ import { test as teardown } from "@playwright/test";
434
+
435
+ teardown("cleanup", async ({ request }) => {
436
+ await request.delete("/api/test/data");
437
+ });
438
+ ```
439
+
440
+ ## Anti-Patterns to Avoid
441
+
442
+ | Anti-Pattern | Problem | Solution |
443
+ | -------------------------- | ---------------------- | ----------------------------------- |
444
+ | Too many browser projects | Slow CI, expensive | Focus on critical browsers |
445
+ | Missing setup dependencies | Tests fail randomly | Declare all dependencies explicitly |
446
+ | Duplicated configuration | Hard to maintain | Extract shared config |
447
+ | Not using setup projects | Repeated auth in tests | Use setup project + storageState |
448
+
449
+ ## Related References
450
+
451
+ - **Global Setup**: See [global-setup.md](global-setup.md) for globalSetup vs setup projects
452
+ - **Fixtures**: See [fixtures-hooks.md](fixtures-hooks.md) for authentication patterns
453
+ - **CI/CD**: See [ci-cd.md](../infrastructure-ci-cd/ci-cd.md) for running projects in CI