@pixelbyte-software/pixcode 1.51.2 → 1.51.4
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/CODE_OF_CONDUCT.md +41 -41
- package/CONTRIBUTING.md +155 -155
- package/LICENSE +718 -718
- package/README.de.md +169 -169
- package/README.ja.md +167 -167
- package/README.ko.md +167 -167
- package/README.md +419 -419
- package/README.ru.md +169 -169
- package/README.tr.md +298 -298
- package/README.zh-CN.md +167 -167
- package/SECURITY.md +46 -46
- package/dist/api-automation.html +110 -110
- package/dist/api-docs.html +548 -548
- package/dist/assets/index-B9N-gfOQ.css +32 -0
- package/dist/assets/{index-EN9ngyxf.js → index-HfGHXhD6.js} +175 -175
- package/dist/clear-cache.html +85 -85
- package/dist/convert-icons.md +52 -52
- package/dist/docs.html +308 -308
- package/dist/favicon.svg +8 -8
- package/dist/features.html +133 -133
- package/dist/generate-icons.js +48 -48
- package/dist/humans.txt +15 -15
- package/dist/icons/codex-white.svg +3 -3
- package/dist/icons/codex.svg +3 -3
- package/dist/icons/cursor-white.svg +11 -11
- package/dist/icons/icon-128x128.svg +9 -9
- package/dist/icons/icon-144x144.svg +9 -9
- package/dist/icons/icon-152x152.svg +9 -9
- package/dist/icons/icon-192x192.svg +9 -9
- package/dist/icons/icon-384x384.svg +9 -9
- package/dist/icons/icon-512x512.svg +9 -9
- package/dist/icons/icon-72x72.svg +9 -9
- package/dist/icons/icon-96x96.svg +9 -9
- package/dist/icons/icon-template.svg +9 -9
- package/dist/icons/qwen-logo.svg +14 -14
- package/dist/index.html +59 -59
- package/dist/landing.html +268 -268
- package/dist/llms-full.txt +119 -119
- package/dist/llms.txt +53 -53
- package/dist/logo.svg +12 -12
- package/dist/manifest.json +60 -60
- package/dist/openapi.yaml +1696 -1696
- package/dist/orchestration.html +125 -125
- package/dist/robots.txt +4 -4
- package/dist/site.css +692 -692
- package/dist/sitemap.xml +51 -51
- package/dist/sw.js +132 -132
- package/dist-server/server/cli.js +96 -96
- package/dist-server/server/daemon/manager.js +33 -33
- package/dist-server/server/daemon-manager.js +64 -64
- package/dist-server/server/database/db.js +14 -2
- package/dist-server/server/database/db.js.map +1 -1
- package/dist-server/server/index.js +191 -31
- package/dist-server/server/index.js.map +1 -1
- package/dist-server/server/middleware/auth.js +16 -5
- package/dist-server/server/middleware/auth.js.map +1 -1
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js +84 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.js.map +1 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js +43 -0
- package/dist-server/server/modules/orchestration/a2a/adapters/json-event.adapter.test.js.map +1 -0
- package/dist-server/server/modules/orchestration/hermes/hermes.routes.js +55 -1
- package/dist-server/server/modules/orchestration/hermes/hermes.routes.js.map +1 -1
- package/dist-server/server/modules/orchestration/index.js +1 -0
- package/dist-server/server/modules/orchestration/index.js.map +1 -1
- package/dist-server/server/routes/auth.js +12 -5
- package/dist-server/server/routes/auth.js.map +1 -1
- package/dist-server/server/routes/commands.js +25 -25
- package/dist-server/server/routes/git.js +29 -17
- package/dist-server/server/routes/git.js.map +1 -1
- package/dist-server/server/routes/live-view.js +46 -46
- package/dist-server/server/routes/platformization.js +7 -6
- package/dist-server/server/routes/platformization.js.map +1 -1
- package/dist-server/server/services/hermes-gateway.js +310 -0
- package/dist-server/server/services/hermes-gateway.js.map +1 -1
- package/dist-server/server/services/platformization.js +58 -2
- package/dist-server/server/services/platformization.js.map +1 -1
- package/dist-server/server/services/public-api-manifest.js +59 -51
- package/dist-server/server/services/public-api-manifest.js.map +1 -1
- package/package.json +222 -222
- package/scripts/fix-node-pty.js +67 -67
- package/scripts/github/create-v1.38-issues.mjs +351 -351
- package/scripts/github/create-vscode-workbench-issues.mjs +121 -121
- package/scripts/hermes/configure-pixcode-mcp.mjs +165 -163
- package/scripts/hermes/pixcode-mcp-server.mjs +1009 -958
- package/scripts/smoke/changes-panel-layout.mjs +48 -48
- package/scripts/smoke/chat-composer-fixed-layout.mjs +55 -55
- package/scripts/smoke/chat-message-timeline-order.mjs +41 -41
- package/scripts/smoke/chat-realtime-hydration.mjs +44 -44
- package/scripts/smoke/chat-session-provider-pools.mjs +35 -35
- package/scripts/smoke/chat-session-state.mjs +19 -19
- package/scripts/smoke/code-editor-theme.mjs +55 -55
- package/scripts/smoke/code-editor-vscode-engine.mjs +91 -91
- package/scripts/smoke/command-center-agent-writes.mjs +79 -79
- package/scripts/smoke/command-center-non-git.mjs +46 -46
- package/scripts/smoke/context-packet.mjs +43 -43
- package/scripts/smoke/control-room-ux-redesign.mjs +91 -91
- package/scripts/smoke/daemon-entrypoint.mjs +20 -20
- package/scripts/smoke/default-landing-routing.mjs +33 -33
- package/scripts/smoke/desktop-native-notifications.mjs +30 -30
- package/scripts/smoke/desktop-tray-icon.mjs +33 -33
- package/scripts/smoke/discord-release-workflow.mjs +24 -24
- package/scripts/smoke/git-install-update.mjs +255 -255
- package/scripts/smoke/handoff-artifact-protocol.mjs +50 -50
- package/scripts/smoke/hermes-api-install.mjs +56 -56
- package/scripts/smoke/hermes-gateway-persistence.mjs +104 -104
- package/scripts/smoke/hermes-mcp-pixcode-roundtrip.mjs +426 -367
- package/scripts/smoke/hermes-rest-chat-api.mjs +162 -162
- package/scripts/smoke/hermes-rest-chat-live.mjs +45 -45
- package/scripts/smoke/hermes-rest-codex-launch.mjs +209 -209
- package/scripts/smoke/hermes-rest-gateway.mjs +79 -70
- package/scripts/smoke/hermes-rest-live.mjs +42 -42
- package/scripts/smoke/hermes-roundtrip.mjs +167 -167
- package/scripts/smoke/hermes-settings-commands.mjs +349 -346
- package/scripts/smoke/hermes-smoke-launcher-guard.mjs +34 -34
- package/scripts/smoke/live-view-diagnostics.mjs +53 -53
- package/scripts/smoke/live-view-environment.mjs +92 -92
- package/scripts/smoke/live-view-integration.mjs +450 -450
- package/scripts/smoke/mac-desktop-runtime.mjs +37 -37
- package/scripts/smoke/mobile-tunnel-guidance.mjs +29 -29
- package/scripts/smoke/model-registry.mjs +36 -36
- package/scripts/smoke/multi-project-ui.mjs +45 -45
- package/scripts/smoke/multi-worker-slots.mjs +42 -42
- package/scripts/smoke/notification-center.mjs +87 -87
- package/scripts/smoke/notification-inapp-preference.mjs +23 -23
- package/scripts/smoke/notification-taxonomy.mjs +58 -58
- package/scripts/smoke/orchestration-api.mjs +172 -172
- package/scripts/smoke/orchestration-execution-dashboard.mjs +33 -33
- package/scripts/smoke/orchestration-live-run.mjs +176 -176
- package/scripts/smoke/orchestration-mobile-scroll.mjs +29 -29
- package/scripts/smoke/orchestration-model-sync.mjs +30 -30
- package/scripts/smoke/orchestration-permission-fallback.mjs +34 -34
- package/scripts/smoke/orchestration-runtime-guards.mjs +48 -48
- package/scripts/smoke/orchestration-user-facing-output.mjs +25 -25
- package/scripts/smoke/permission-policy.mjs +50 -50
- package/scripts/smoke/pixcode-workbench-1-48.mjs +167 -167
- package/scripts/smoke/provider-models-opencode-live.mjs +66 -66
- package/scripts/smoke/provider-rest-api.mjs +124 -124
- package/scripts/smoke/provider-selection-status.mjs +52 -52
- package/scripts/smoke/run-state-refresh.mjs +52 -52
- package/scripts/smoke/runtime-manager.mjs +99 -99
- package/scripts/smoke/shell-manual-disconnect.mjs +30 -30
- package/scripts/smoke/side-panel-editor-layout.mjs +34 -34
- package/scripts/smoke/static-root-routing.mjs +21 -21
- package/scripts/smoke/strict-handoff-compact.mjs +60 -60
- package/scripts/smoke/taskmaster-config.mjs +24 -24
- package/scripts/smoke/taskmaster-execution-telegram.mjs +3 -3
- package/scripts/smoke/taskmaster-onboarding.mjs +3 -3
- package/scripts/smoke/taskmaster-run-graph.mjs +3 -3
- package/scripts/smoke/telegram-control.mjs +242 -242
- package/scripts/smoke/tunnel-persistence.mjs +56 -56
- package/scripts/smoke/update-issue-progress.mjs +69 -69
- package/scripts/smoke/update-ux.mjs +55 -55
- package/scripts/smoke/v138-completion.mjs +132 -132
- package/scripts/smoke/v138-desktop-release-hardening.mjs +69 -69
- package/scripts/smoke/v138-diagnostics.mjs +63 -63
- package/scripts/smoke/v138-issue-planner.mjs +33 -33
- package/scripts/smoke/v143-remote-control.mjs +76 -76
- package/scripts/smoke/v144-production-loop.mjs +47 -47
- package/scripts/smoke/v145-platformization.mjs +46 -46
- package/scripts/smoke/v146-control-room-ui.mjs +150 -150
- package/scripts/smoke/version-modal-autoshow.mjs +29 -29
- package/scripts/smoke/vscode-workbench-layout.mjs +63 -63
- package/scripts/smoke/vscode-workbench-polish.mjs +461 -436
- package/scripts/smoke/workflow-fallback-replay.mjs +56 -56
- package/scripts/smoke/workflow-templates.mjs +43 -43
- package/scripts/smoke/workflow-trace-timeline.mjs +46 -46
- package/scripts/update-git-install.mjs +293 -293
- package/server/claude-sdk.js +920 -920
- package/server/cli.js +1039 -1039
- package/server/constants/config.js +4 -4
- package/server/cursor-cli.js +344 -344
- package/server/daemon/manager.js +563 -563
- package/server/daemon-manager.js +964 -964
- package/server/database/db.js +908 -895
- package/server/database/json-store.js +197 -197
- package/server/gemini-cli.js +550 -550
- package/server/gemini-response-handler.js +79 -79
- package/server/index.js +201 -30
- package/server/load-env.js +35 -35
- package/server/middleware/auth.js +171 -156
- package/server/modules/orchestration/a2a/adapter-registry.ts +108 -108
- package/server/modules/orchestration/a2a/adapters/abstract-a2a.adapter.ts +63 -63
- package/server/modules/orchestration/a2a/adapters/claude-code.adapter.ts +286 -286
- package/server/modules/orchestration/a2a/adapters/codex.adapter.ts +244 -244
- package/server/modules/orchestration/a2a/adapters/cursor.adapter.ts +249 -249
- package/server/modules/orchestration/a2a/adapters/gemini.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/adapters/json-event.adapter.test.ts +60 -0
- package/server/modules/orchestration/a2a/adapters/json-event.adapter.ts +101 -0
- package/server/modules/orchestration/a2a/adapters/opencode.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/adapters/qwen.adapter.ts +248 -248
- package/server/modules/orchestration/a2a/agent-card.ts +55 -55
- package/server/modules/orchestration/a2a/routes.ts +590 -590
- package/server/modules/orchestration/a2a/task-store.ts +178 -178
- package/server/modules/orchestration/a2a/types.ts +126 -126
- package/server/modules/orchestration/a2a/validator.ts +113 -113
- package/server/modules/orchestration/hermes/hermes.routes.ts +642 -583
- package/server/modules/orchestration/index.ts +101 -100
- package/server/modules/orchestration/preview/port-watcher.ts +112 -112
- package/server/modules/orchestration/preview/preview-proxy.ts +60 -60
- package/server/modules/orchestration/preview/types.ts +19 -19
- package/server/modules/orchestration/security/permission-policy.ts +401 -401
- package/server/modules/orchestration/tasks/orchestration-task-store.ts +41 -41
- package/server/modules/orchestration/tasks/orchestration-task.routes.ts +64 -64
- package/server/modules/orchestration/tasks/orchestration-task.service.ts +209 -209
- package/server/modules/orchestration/tasks/orchestration-task.types.ts +40 -40
- package/server/modules/orchestration/tasks/task-run-graph.ts +155 -155
- package/server/modules/orchestration/workflows/approval-queue.ts +106 -106
- package/server/modules/orchestration/workflows/built-in-workflows.ts +127 -127
- package/server/modules/orchestration/workflows/context-packet.ts +186 -186
- package/server/modules/orchestration/workflows/handoff-artifact.ts +175 -175
- package/server/modules/orchestration/workflows/workflow-fallback-policy.ts +161 -161
- package/server/modules/orchestration/workflows/workflow-replay.ts +254 -254
- package/server/modules/orchestration/workflows/workflow-runner.ts +2070 -2070
- package/server/modules/orchestration/workflows/workflow-store.ts +97 -97
- package/server/modules/orchestration/workflows/workflow-templates.ts +272 -272
- package/server/modules/orchestration/workflows/workflow-trace.ts +424 -424
- package/server/modules/orchestration/workflows/workflow.routes.ts +586 -586
- package/server/modules/orchestration/workflows/workflow.types.ts +111 -111
- package/server/modules/orchestration/workflows/workspace-target.ts +122 -122
- package/server/modules/orchestration/workspace/docker-workspace.ts +136 -136
- package/server/modules/orchestration/workspace/path-safety.ts +55 -55
- package/server/modules/orchestration/workspace/types.ts +52 -52
- package/server/modules/orchestration/workspace/workspace-manager.ts +102 -102
- package/server/modules/orchestration/workspace/worktree-workspace.ts +126 -126
- package/server/modules/providers/index.ts +2 -2
- package/server/modules/providers/list/claude/claude-auth.provider.ts +146 -146
- package/server/modules/providers/list/claude/claude-mcp.provider.ts +135 -135
- package/server/modules/providers/list/claude/claude-sessions.provider.ts +306 -306
- package/server/modules/providers/list/claude/claude.provider.ts +15 -15
- package/server/modules/providers/list/codex/codex-auth.provider.ts +117 -117
- package/server/modules/providers/list/codex/codex-mcp.provider.ts +135 -135
- package/server/modules/providers/list/codex/codex-sessions.provider.ts +319 -319
- package/server/modules/providers/list/codex/codex.provider.ts +15 -15
- package/server/modules/providers/list/cursor/cursor-auth.provider.ts +147 -147
- package/server/modules/providers/list/cursor/cursor-mcp.provider.ts +108 -108
- package/server/modules/providers/list/cursor/cursor-sessions.provider.ts +421 -421
- package/server/modules/providers/list/cursor/cursor.provider.ts +15 -15
- package/server/modules/providers/list/gemini/gemini-auth.provider.ts +173 -173
- package/server/modules/providers/list/gemini/gemini-mcp.provider.ts +110 -110
- package/server/modules/providers/list/gemini/gemini-sessions.provider.ts +227 -227
- package/server/modules/providers/list/gemini/gemini.provider.ts +15 -15
- package/server/modules/providers/list/opencode/opencode-auth.provider.ts +131 -131
- package/server/modules/providers/list/opencode/opencode-mcp.provider.ts +126 -126
- package/server/modules/providers/list/opencode/opencode-sessions.provider.ts +286 -286
- package/server/modules/providers/list/opencode/opencode.provider.ts +29 -29
- package/server/modules/providers/list/qwen/qwen-auth.provider.ts +146 -146
- package/server/modules/providers/list/qwen/qwen-mcp.provider.ts +114 -114
- package/server/modules/providers/list/qwen/qwen-sessions.provider.ts +265 -265
- package/server/modules/providers/list/qwen/qwen.provider.ts +21 -21
- package/server/modules/providers/provider.registry.ts +40 -40
- package/server/modules/providers/provider.routes.ts +944 -944
- package/server/modules/providers/services/mcp.service.ts +86 -86
- package/server/modules/providers/services/provider-auth.service.ts +26 -26
- package/server/modules/providers/services/sessions.service.ts +45 -45
- package/server/modules/providers/shared/base/abstract.provider.ts +20 -20
- package/server/modules/providers/shared/mcp/mcp.provider.ts +151 -151
- package/server/modules/providers/shared/provider-configs.ts +142 -142
- package/server/modules/providers/tests/mcp.test.ts +293 -293
- package/server/openai-codex.js +462 -462
- package/server/opencode-cli.js +491 -491
- package/server/opencode-response-handler.js +111 -111
- package/server/projects.js +3008 -3008
- package/server/qwen-code-cli.js +410 -410
- package/server/qwen-response-handler.js +73 -73
- package/server/routes/agent.js +1435 -1435
- package/server/routes/auth.js +154 -146
- package/server/routes/codex.js +20 -20
- package/server/routes/commands.js +570 -570
- package/server/routes/cursor.js +61 -61
- package/server/routes/diagnostics.js +41 -41
- package/server/routes/gemini.js +25 -25
- package/server/routes/git.js +1650 -1635
- package/server/routes/live-view.js +411 -411
- package/server/routes/mcp-utils.js +13 -13
- package/server/routes/messages.js +62 -62
- package/server/routes/network.js +125 -125
- package/server/routes/platformization.js +198 -197
- package/server/routes/plugins.js +320 -320
- package/server/routes/production-agent-loop.js +90 -90
- package/server/routes/projects.js +917 -917
- package/server/routes/public-api.js +34 -34
- package/server/routes/qwen.js +27 -27
- package/server/routes/remote.js +55 -55
- package/server/routes/settings.js +321 -321
- package/server/routes/telegram.js +140 -140
- package/server/routes/user.js +125 -125
- package/server/routes/webhooks.js +63 -63
- package/server/services/control-room.js +102 -102
- package/server/services/diagnostics.js +165 -165
- package/server/services/external-access.js +375 -375
- package/server/services/hermes-gateway.js +1562 -1247
- package/server/services/hermes-install-jobs.js +729 -729
- package/server/services/install-jobs.js +715 -715
- package/server/services/live-view.js +956 -956
- package/server/services/managed-runtimes.js +493 -493
- package/server/services/model-registry.js +144 -144
- package/server/services/notification-orchestrator.js +365 -365
- package/server/services/notification-taxonomy.js +204 -204
- package/server/services/platformization.js +844 -779
- package/server/services/production-agent-loop.js +248 -248
- package/server/services/provider-cli-versions.js +149 -149
- package/server/services/provider-credentials.js +189 -189
- package/server/services/provider-models.js +396 -396
- package/server/services/public-api-manifest.js +190 -182
- package/server/services/remote-connection.js +127 -127
- package/server/services/runtime-manager.js +323 -323
- package/server/services/startup-update.js +234 -234
- package/server/services/telegram/bot.js +331 -331
- package/server/services/telegram/control-center.js +979 -979
- package/server/services/telegram/telegram-http-client.js +151 -151
- package/server/services/telegram/translations.js +340 -340
- package/server/services/vapid-keys.js +36 -36
- package/server/services/webhooks.js +216 -216
- package/server/sessionManager.js +225 -225
- package/server/shared/interfaces.ts +54 -54
- package/server/shared/types.ts +172 -172
- package/server/shared/utils.ts +193 -193
- package/server/tsconfig.json +36 -36
- package/server/utils/colors.js +21 -21
- package/server/utils/commandParser.js +305 -305
- package/server/utils/frontmatter.js +18 -18
- package/server/utils/gitConfig.js +34 -34
- package/server/utils/plugin-loader.js +457 -457
- package/server/utils/plugin-process-manager.js +185 -185
- package/server/utils/port-access.js +209 -209
- package/server/utils/runtime-paths.js +37 -37
- package/server/utils/url-detection.js +71 -71
- package/server/vite-daemon.js +79 -79
- package/shared/modelConstants.js +161 -161
- package/shared/networkHosts.js +22 -22
- package/dist/assets/index-DMz0zv6T.css +0 -32
|
@@ -1,150 +1,150 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
import assert from 'node:assert/strict';
|
|
4
|
-
import fs from 'node:fs';
|
|
5
|
-
import path from 'node:path';
|
|
6
|
-
|
|
7
|
-
const root = process.cwd();
|
|
8
|
-
|
|
9
|
-
function read(relativePath) {
|
|
10
|
-
return fs.readFileSync(path.join(root, relativePath), 'utf8');
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
const controlRoom = read('src/components/control-room/ControlRoomPage.tsx');
|
|
14
|
-
for (const phrase of [
|
|
15
|
-
'CONTROL_ROOM_GROUPS',
|
|
16
|
-
'OVERVIEW_CARDS',
|
|
17
|
-
'overview-card-attention',
|
|
18
|
-
'overview-card-running',
|
|
19
|
-
'overview-card-reviews',
|
|
20
|
-
'overview-card-team-access',
|
|
21
|
-
'overview-card-security-secrets',
|
|
22
|
-
'overview-card-usage-evals',
|
|
23
|
-
'What needs attention',
|
|
24
|
-
'Running now',
|
|
25
|
-
'Team and access',
|
|
26
|
-
'Security and secrets',
|
|
27
|
-
'Usage and evaluations',
|
|
28
|
-
'Run timeline',
|
|
29
|
-
'AdvancedDisclosure',
|
|
30
|
-
'ContextDrawer',
|
|
31
|
-
'TimelineItem',
|
|
32
|
-
'ResponsiveDataList',
|
|
33
|
-
'/api/production-agent-loop/github/issue-to-pr',
|
|
34
|
-
'/api/platformization/admin/users',
|
|
35
|
-
'/api/platformization/project-collaborators',
|
|
36
|
-
]) {
|
|
37
|
-
assert.match(controlRoom, new RegExp(phrase.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Control room UI should include ${phrase}.`);
|
|
38
|
-
}
|
|
39
|
-
assert.doesNotMatch(controlRoom, /sections\.access|Self-hosted access|remote-access\/health/, 'Self-hosted access belongs in Settings, not inside Control Room.');
|
|
40
|
-
assert.doesNotMatch(controlRoom, /const sections\s*=/, 'Control Room should not return to the old flat feature-wall section list.');
|
|
41
|
-
|
|
42
|
-
assert.match(controlRoom, /lg:grid-cols-\[220px_minmax\(0,1fr\)_320px\]/, 'Control room must use a desktop master-detail layout.');
|
|
43
|
-
assert.match(controlRoom, /overflow-x-auto lg:hidden/, 'Control room must expose mobile-first grouped navigation.');
|
|
44
|
-
assert.match(controlRoom, /sm:grid-cols-2/, 'Control room must include mobile-first responsive grids.');
|
|
45
|
-
assert.match(controlRoom, /xl:grid-cols/, 'Control room must scale to wide screens.');
|
|
46
|
-
|
|
47
|
-
const appTypes = read('src/types/app.ts');
|
|
48
|
-
assert.match(appTypes, /controlRoom/, 'App tabs should include controlRoom.');
|
|
49
|
-
|
|
50
|
-
const tabSwitcher = read('src/components/main-content/view/subcomponents/MainContentTabSwitcher.tsx');
|
|
51
|
-
assert.doesNotMatch(tabSwitcher, /tabs\.controlRoom/, 'Control Room should not appear as a normal top tab.');
|
|
52
|
-
|
|
53
|
-
const mainContent = read('src/components/main-content/view/MainContent.tsx');
|
|
54
|
-
assert.match(mainContent, /ControlRoomPage/, 'Main content should render the Control Room page.');
|
|
55
|
-
assert.match(mainContent, /activeTab === 'controlRoom'/, 'Control Room should render as its own primary tab.');
|
|
56
|
-
assert.match(mainContent, /setActiveTab\('controlRoom'\)/, 'Empty-state users should have a direct Control Room launcher.');
|
|
57
|
-
|
|
58
|
-
const projectsState = read('src/hooks/useProjectsState.ts');
|
|
59
|
-
assert.match(projectsState, /'controlRoom'/, 'Control Room must be a persisted primary app tab.');
|
|
60
|
-
assert.match(projectsState, /onOpenControlRoom/, 'Sidebar should receive a direct Control Room launcher.');
|
|
61
|
-
|
|
62
|
-
const mainContentTypes = read('src/components/main-content/types/types.ts');
|
|
63
|
-
assert.match(mainContentTypes, /onOpenControlRoom/, 'Main content state should expose a direct Control Room launcher callback.');
|
|
64
|
-
assert.match(mainContentTypes, /selectedProject: Project \| null/, 'Control Room header should support server-level access without requiring a selected project.');
|
|
65
|
-
|
|
66
|
-
const mainContentHeader = read('src/components/main-content/view/subcomponents/MainContentHeader.tsx');
|
|
67
|
-
assert.doesNotMatch(mainContentHeader, /Open Control Room|openControlRoom/, 'Header should not carry the fixed Control Room launcher.');
|
|
68
|
-
assert.match(mainContentHeader, /activeTab !== 'controlRoom'/, 'Control Room should hide the normal project tab header.');
|
|
69
|
-
|
|
70
|
-
const sidebarFooter = read('src/components/sidebar/view/subcomponents/SidebarFooter.tsx');
|
|
71
|
-
assert.match(sidebarFooter, /controlRoom/, 'Expanded sidebar footer should show the Control Room launcher above Settings.');
|
|
72
|
-
assert.match(sidebarFooter, /onOpenControlRoom/, 'Expanded sidebar footer should open Control Room directly.');
|
|
73
|
-
|
|
74
|
-
const sidebarCollapsed = read('src/components/sidebar/view/subcomponents/SidebarCollapsed.tsx');
|
|
75
|
-
assert.match(sidebarCollapsed, /controlRoom/, 'Collapsed sidebar should expose Control Room above Settings.');
|
|
76
|
-
assert.match(sidebarCollapsed, /onOpenControlRoom/, 'Collapsed sidebar should open Control Room directly.');
|
|
77
|
-
|
|
78
|
-
const emptyState = read('src/components/main-content/view/subcomponents/MainContentStateView.tsx');
|
|
79
|
-
assert.match(emptyState, /Open Control Room/, 'Empty project state should include a visible Open Control Room button.');
|
|
80
|
-
|
|
81
|
-
const settingsTypes = read('src/components/settings/types/types.ts');
|
|
82
|
-
assert.match(settingsTypes, /'access'/, 'Settings should include a global Access tab.');
|
|
83
|
-
|
|
84
|
-
const settingsController = read('src/components/settings/hooks/useSettingsController.ts');
|
|
85
|
-
assert.match(settingsController, /'access'/, 'Settings controller should accept the Access tab.');
|
|
86
|
-
|
|
87
|
-
const settingsSidebar = read('src/components/settings/view/SettingsSidebar.tsx');
|
|
88
|
-
assert.match(settingsSidebar, /mainTabs\.access/, 'Settings sidebar should expose Access as a first-class system setting.');
|
|
89
|
-
|
|
90
|
-
const settings = read('src/components/settings/view/Settings.tsx');
|
|
91
|
-
assert.match(settings, /AccessSettingsTab/, 'Settings should render the Access settings tab.');
|
|
92
|
-
|
|
93
|
-
const accessSettings = read('src/components/settings/view/tabs/access-settings/AccessSettingsTab.tsx');
|
|
94
|
-
for (const phrase of [
|
|
95
|
-
'/api/network/endpoints',
|
|
96
|
-
'/api/network/external',
|
|
97
|
-
'/api/network/tunnel',
|
|
98
|
-
'/api/platformization/remote-access',
|
|
99
|
-
'/api/platformization/remote-access/configs',
|
|
100
|
-
'/api/platformization/remote-access/tailscale',
|
|
101
|
-
'/api/platformization/remote-access/health',
|
|
102
|
-
'QRCode',
|
|
103
|
-
'renderQrDataUrl',
|
|
104
|
-
'toggleTunnel',
|
|
105
|
-
'saveDetectedAccessPath',
|
|
106
|
-
'connectionOptions',
|
|
107
|
-
]) {
|
|
108
|
-
assert.match(accessSettings, new RegExp(phrase.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Access settings should use ${phrase}.`);
|
|
109
|
-
}
|
|
110
|
-
assert.match(accessSettings, /max-w-5xl/, 'Access settings should use a readable constrained content width.');
|
|
111
|
-
assert.match(accessSettings, /space-y-8/, 'Access settings should use generous vertical spacing.');
|
|
112
|
-
assert.doesNotMatch(accessSettings, /xl:grid-cols-\[minmax\(0,1fr\)_minmax\(0,1fr\)\]/, 'Access settings should not squeeze major setup panels into equal half-width columns.');
|
|
113
|
-
assert.doesNotMatch(accessSettings, /2xl:grid-cols-2/, 'Access QR sections should not re-split into cramped nested columns.');
|
|
114
|
-
|
|
115
|
-
assert.match(controlRoom, /useTranslation/, 'Control Room should use the app i18n system.');
|
|
116
|
-
assert.match(controlRoom, /controlRoom\./, 'Control Room copy should be loaded from translation keys.');
|
|
117
|
-
|
|
118
|
-
for (const locale of ['en', 'tr', 'de', 'it', 'ja', 'ko', 'ru', 'zh-CN']) {
|
|
119
|
-
const commonLocale = read(`src/i18n/locales/${locale}/common.json`);
|
|
120
|
-
assert.match(commonLocale, /"controlRoom"\s*:/, `${locale} common locale should include Control Room translations.`);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
const platformService = read('server/services/platformization.js');
|
|
124
|
-
for (const symbol of [
|
|
125
|
-
'createAdminUser',
|
|
126
|
-
'createProjectCollaborator',
|
|
127
|
-
'getAuditLog',
|
|
128
|
-
'saveRemoteAccessConfig',
|
|
129
|
-
'detectTailscaleStatus',
|
|
130
|
-
'checkRemoteAccessHealth',
|
|
131
|
-
'project_partner',
|
|
132
|
-
'project_worker',
|
|
133
|
-
]) {
|
|
134
|
-
assert.match(platformService, new RegExp(symbol), `Platformization service should include ${symbol}.`);
|
|
135
|
-
}
|
|
136
|
-
assert.doesNotMatch(platformService, /Tailscale CLI is not installed/, 'Tailscale missing state should be guidance, not a raw CLI error.');
|
|
137
|
-
|
|
138
|
-
const platformRoutes = read('server/routes/platformization.js');
|
|
139
|
-
for (const route of [
|
|
140
|
-
'/admin/users',
|
|
141
|
-
'/project-collaborators',
|
|
142
|
-
'/remote-access',
|
|
143
|
-
'/remote-access/tailscale',
|
|
144
|
-
'/remote-access/health',
|
|
145
|
-
'/audit-log/export',
|
|
146
|
-
]) {
|
|
147
|
-
assert.match(platformRoutes, new RegExp(route.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Platformization routes should expose ${route}.`);
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
console.log('v1.46 control room UI smoke passed');
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import assert from 'node:assert/strict';
|
|
4
|
+
import fs from 'node:fs';
|
|
5
|
+
import path from 'node:path';
|
|
6
|
+
|
|
7
|
+
const root = process.cwd();
|
|
8
|
+
|
|
9
|
+
function read(relativePath) {
|
|
10
|
+
return fs.readFileSync(path.join(root, relativePath), 'utf8');
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const controlRoom = read('src/components/control-room/ControlRoomPage.tsx');
|
|
14
|
+
for (const phrase of [
|
|
15
|
+
'CONTROL_ROOM_GROUPS',
|
|
16
|
+
'OVERVIEW_CARDS',
|
|
17
|
+
'overview-card-attention',
|
|
18
|
+
'overview-card-running',
|
|
19
|
+
'overview-card-reviews',
|
|
20
|
+
'overview-card-team-access',
|
|
21
|
+
'overview-card-security-secrets',
|
|
22
|
+
'overview-card-usage-evals',
|
|
23
|
+
'What needs attention',
|
|
24
|
+
'Running now',
|
|
25
|
+
'Team and access',
|
|
26
|
+
'Security and secrets',
|
|
27
|
+
'Usage and evaluations',
|
|
28
|
+
'Run timeline',
|
|
29
|
+
'AdvancedDisclosure',
|
|
30
|
+
'ContextDrawer',
|
|
31
|
+
'TimelineItem',
|
|
32
|
+
'ResponsiveDataList',
|
|
33
|
+
'/api/production-agent-loop/github/issue-to-pr',
|
|
34
|
+
'/api/platformization/admin/users',
|
|
35
|
+
'/api/platformization/project-collaborators',
|
|
36
|
+
]) {
|
|
37
|
+
assert.match(controlRoom, new RegExp(phrase.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Control room UI should include ${phrase}.`);
|
|
38
|
+
}
|
|
39
|
+
assert.doesNotMatch(controlRoom, /sections\.access|Self-hosted access|remote-access\/health/, 'Self-hosted access belongs in Settings, not inside Control Room.');
|
|
40
|
+
assert.doesNotMatch(controlRoom, /const sections\s*=/, 'Control Room should not return to the old flat feature-wall section list.');
|
|
41
|
+
|
|
42
|
+
assert.match(controlRoom, /lg:grid-cols-\[220px_minmax\(0,1fr\)_320px\]/, 'Control room must use a desktop master-detail layout.');
|
|
43
|
+
assert.match(controlRoom, /overflow-x-auto lg:hidden/, 'Control room must expose mobile-first grouped navigation.');
|
|
44
|
+
assert.match(controlRoom, /sm:grid-cols-2/, 'Control room must include mobile-first responsive grids.');
|
|
45
|
+
assert.match(controlRoom, /xl:grid-cols/, 'Control room must scale to wide screens.');
|
|
46
|
+
|
|
47
|
+
const appTypes = read('src/types/app.ts');
|
|
48
|
+
assert.match(appTypes, /controlRoom/, 'App tabs should include controlRoom.');
|
|
49
|
+
|
|
50
|
+
const tabSwitcher = read('src/components/main-content/view/subcomponents/MainContentTabSwitcher.tsx');
|
|
51
|
+
assert.doesNotMatch(tabSwitcher, /tabs\.controlRoom/, 'Control Room should not appear as a normal top tab.');
|
|
52
|
+
|
|
53
|
+
const mainContent = read('src/components/main-content/view/MainContent.tsx');
|
|
54
|
+
assert.match(mainContent, /ControlRoomPage/, 'Main content should render the Control Room page.');
|
|
55
|
+
assert.match(mainContent, /activeTab === 'controlRoom'/, 'Control Room should render as its own primary tab.');
|
|
56
|
+
assert.match(mainContent, /setActiveTab\('controlRoom'\)/, 'Empty-state users should have a direct Control Room launcher.');
|
|
57
|
+
|
|
58
|
+
const projectsState = read('src/hooks/useProjectsState.ts');
|
|
59
|
+
assert.match(projectsState, /'controlRoom'/, 'Control Room must be a persisted primary app tab.');
|
|
60
|
+
assert.match(projectsState, /onOpenControlRoom/, 'Sidebar should receive a direct Control Room launcher.');
|
|
61
|
+
|
|
62
|
+
const mainContentTypes = read('src/components/main-content/types/types.ts');
|
|
63
|
+
assert.match(mainContentTypes, /onOpenControlRoom/, 'Main content state should expose a direct Control Room launcher callback.');
|
|
64
|
+
assert.match(mainContentTypes, /selectedProject: Project \| null/, 'Control Room header should support server-level access without requiring a selected project.');
|
|
65
|
+
|
|
66
|
+
const mainContentHeader = read('src/components/main-content/view/subcomponents/MainContentHeader.tsx');
|
|
67
|
+
assert.doesNotMatch(mainContentHeader, /Open Control Room|openControlRoom/, 'Header should not carry the fixed Control Room launcher.');
|
|
68
|
+
assert.match(mainContentHeader, /activeTab !== 'controlRoom'/, 'Control Room should hide the normal project tab header.');
|
|
69
|
+
|
|
70
|
+
const sidebarFooter = read('src/components/sidebar/view/subcomponents/SidebarFooter.tsx');
|
|
71
|
+
assert.match(sidebarFooter, /controlRoom/, 'Expanded sidebar footer should show the Control Room launcher above Settings.');
|
|
72
|
+
assert.match(sidebarFooter, /onOpenControlRoom/, 'Expanded sidebar footer should open Control Room directly.');
|
|
73
|
+
|
|
74
|
+
const sidebarCollapsed = read('src/components/sidebar/view/subcomponents/SidebarCollapsed.tsx');
|
|
75
|
+
assert.match(sidebarCollapsed, /controlRoom/, 'Collapsed sidebar should expose Control Room above Settings.');
|
|
76
|
+
assert.match(sidebarCollapsed, /onOpenControlRoom/, 'Collapsed sidebar should open Control Room directly.');
|
|
77
|
+
|
|
78
|
+
const emptyState = read('src/components/main-content/view/subcomponents/MainContentStateView.tsx');
|
|
79
|
+
assert.match(emptyState, /Open Control Room/, 'Empty project state should include a visible Open Control Room button.');
|
|
80
|
+
|
|
81
|
+
const settingsTypes = read('src/components/settings/types/types.ts');
|
|
82
|
+
assert.match(settingsTypes, /'access'/, 'Settings should include a global Access tab.');
|
|
83
|
+
|
|
84
|
+
const settingsController = read('src/components/settings/hooks/useSettingsController.ts');
|
|
85
|
+
assert.match(settingsController, /'access'/, 'Settings controller should accept the Access tab.');
|
|
86
|
+
|
|
87
|
+
const settingsSidebar = read('src/components/settings/view/SettingsSidebar.tsx');
|
|
88
|
+
assert.match(settingsSidebar, /mainTabs\.access/, 'Settings sidebar should expose Access as a first-class system setting.');
|
|
89
|
+
|
|
90
|
+
const settings = read('src/components/settings/view/Settings.tsx');
|
|
91
|
+
assert.match(settings, /AccessSettingsTab/, 'Settings should render the Access settings tab.');
|
|
92
|
+
|
|
93
|
+
const accessSettings = read('src/components/settings/view/tabs/access-settings/AccessSettingsTab.tsx');
|
|
94
|
+
for (const phrase of [
|
|
95
|
+
'/api/network/endpoints',
|
|
96
|
+
'/api/network/external',
|
|
97
|
+
'/api/network/tunnel',
|
|
98
|
+
'/api/platformization/remote-access',
|
|
99
|
+
'/api/platformization/remote-access/configs',
|
|
100
|
+
'/api/platformization/remote-access/tailscale',
|
|
101
|
+
'/api/platformization/remote-access/health',
|
|
102
|
+
'QRCode',
|
|
103
|
+
'renderQrDataUrl',
|
|
104
|
+
'toggleTunnel',
|
|
105
|
+
'saveDetectedAccessPath',
|
|
106
|
+
'connectionOptions',
|
|
107
|
+
]) {
|
|
108
|
+
assert.match(accessSettings, new RegExp(phrase.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Access settings should use ${phrase}.`);
|
|
109
|
+
}
|
|
110
|
+
assert.match(accessSettings, /max-w-5xl/, 'Access settings should use a readable constrained content width.');
|
|
111
|
+
assert.match(accessSettings, /space-y-8/, 'Access settings should use generous vertical spacing.');
|
|
112
|
+
assert.doesNotMatch(accessSettings, /xl:grid-cols-\[minmax\(0,1fr\)_minmax\(0,1fr\)\]/, 'Access settings should not squeeze major setup panels into equal half-width columns.');
|
|
113
|
+
assert.doesNotMatch(accessSettings, /2xl:grid-cols-2/, 'Access QR sections should not re-split into cramped nested columns.');
|
|
114
|
+
|
|
115
|
+
assert.match(controlRoom, /useTranslation/, 'Control Room should use the app i18n system.');
|
|
116
|
+
assert.match(controlRoom, /controlRoom\./, 'Control Room copy should be loaded from translation keys.');
|
|
117
|
+
|
|
118
|
+
for (const locale of ['en', 'tr', 'de', 'it', 'ja', 'ko', 'ru', 'zh-CN']) {
|
|
119
|
+
const commonLocale = read(`src/i18n/locales/${locale}/common.json`);
|
|
120
|
+
assert.match(commonLocale, /"controlRoom"\s*:/, `${locale} common locale should include Control Room translations.`);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
const platformService = read('server/services/platformization.js');
|
|
124
|
+
for (const symbol of [
|
|
125
|
+
'createAdminUser',
|
|
126
|
+
'createProjectCollaborator',
|
|
127
|
+
'getAuditLog',
|
|
128
|
+
'saveRemoteAccessConfig',
|
|
129
|
+
'detectTailscaleStatus',
|
|
130
|
+
'checkRemoteAccessHealth',
|
|
131
|
+
'project_partner',
|
|
132
|
+
'project_worker',
|
|
133
|
+
]) {
|
|
134
|
+
assert.match(platformService, new RegExp(symbol), `Platformization service should include ${symbol}.`);
|
|
135
|
+
}
|
|
136
|
+
assert.doesNotMatch(platformService, /Tailscale CLI is not installed/, 'Tailscale missing state should be guidance, not a raw CLI error.');
|
|
137
|
+
|
|
138
|
+
const platformRoutes = read('server/routes/platformization.js');
|
|
139
|
+
for (const route of [
|
|
140
|
+
'/admin/users',
|
|
141
|
+
'/project-collaborators',
|
|
142
|
+
'/remote-access',
|
|
143
|
+
'/remote-access/tailscale',
|
|
144
|
+
'/remote-access/health',
|
|
145
|
+
'/audit-log/export',
|
|
146
|
+
]) {
|
|
147
|
+
assert.match(platformRoutes, new RegExp(route.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')), `Platformization routes should expose ${route}.`);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
console.log('v1.46 control room UI smoke passed');
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
import assert from 'node:assert/strict';
|
|
4
|
-
import { readFileSync } from 'node:fs';
|
|
5
|
-
|
|
6
|
-
const source = readFileSync('src/components/sidebar/view/Sidebar.tsx', 'utf8');
|
|
7
|
-
|
|
8
|
-
assert.ok(
|
|
9
|
-
source.includes('VERSION_RELEASE_NOTES_SEEN_KEY'),
|
|
10
|
-
'Sidebar should persist the latest equal-version release notes it auto-showed.',
|
|
11
|
-
);
|
|
12
|
-
assert.ok(
|
|
13
|
-
source.includes('localStorage.getItem(VERSION_RELEASE_NOTES_SEEN_KEY)'),
|
|
14
|
-
'Sidebar should read the seen release-notes version from localStorage.',
|
|
15
|
-
);
|
|
16
|
-
assert.ok(
|
|
17
|
-
source.includes('localStorage.setItem(VERSION_RELEASE_NOTES_SEEN_KEY, latestVersion)'),
|
|
18
|
-
'Sidebar should mark equal-version release notes as seen when auto-showing them.',
|
|
19
|
-
);
|
|
20
|
-
assert.ok(
|
|
21
|
-
source.includes('hasSeenCurrentReleaseNotes'),
|
|
22
|
-
'Sidebar should avoid auto-showing release notes when the current version was already seen.',
|
|
23
|
-
);
|
|
24
|
-
assert.ok(
|
|
25
|
-
source.includes('!hasSeenCurrentReleaseNotes'),
|
|
26
|
-
'The auto-show condition should be gated by the seen-version check.',
|
|
27
|
-
);
|
|
28
|
-
|
|
29
|
-
console.log('version modal autoshow smoke passed');
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
import assert from 'node:assert/strict';
|
|
4
|
+
import { readFileSync } from 'node:fs';
|
|
5
|
+
|
|
6
|
+
const source = readFileSync('src/components/sidebar/view/Sidebar.tsx', 'utf8');
|
|
7
|
+
|
|
8
|
+
assert.ok(
|
|
9
|
+
source.includes('VERSION_RELEASE_NOTES_SEEN_KEY'),
|
|
10
|
+
'Sidebar should persist the latest equal-version release notes it auto-showed.',
|
|
11
|
+
);
|
|
12
|
+
assert.ok(
|
|
13
|
+
source.includes('localStorage.getItem(VERSION_RELEASE_NOTES_SEEN_KEY)'),
|
|
14
|
+
'Sidebar should read the seen release-notes version from localStorage.',
|
|
15
|
+
);
|
|
16
|
+
assert.ok(
|
|
17
|
+
source.includes('localStorage.setItem(VERSION_RELEASE_NOTES_SEEN_KEY, latestVersion)'),
|
|
18
|
+
'Sidebar should mark equal-version release notes as seen when auto-showing them.',
|
|
19
|
+
);
|
|
20
|
+
assert.ok(
|
|
21
|
+
source.includes('hasSeenCurrentReleaseNotes'),
|
|
22
|
+
'Sidebar should avoid auto-showing release notes when the current version was already seen.',
|
|
23
|
+
);
|
|
24
|
+
assert.ok(
|
|
25
|
+
source.includes('!hasSeenCurrentReleaseNotes'),
|
|
26
|
+
'The auto-show condition should be gated by the seen-version check.',
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
console.log('version modal autoshow smoke passed');
|
|
@@ -1,63 +1,63 @@
|
|
|
1
|
-
import { existsSync, readFileSync } from 'node:fs';
|
|
2
|
-
|
|
3
|
-
function assert(condition, message) {
|
|
4
|
-
if (!condition) {
|
|
5
|
-
throw new Error(message);
|
|
6
|
-
}
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
function read(path) {
|
|
10
|
-
assert(existsSync(path), `${path} should exist`);
|
|
11
|
-
return readFileSync(path, 'utf8');
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
const preferenceHook = read('src/hooks/useWorkbenchLayoutPreference.ts');
|
|
15
|
-
const appContent = read('src/components/app/AppContent.tsx');
|
|
16
|
-
const workbench = read('src/components/vscode-workbench/view/VSCodeWorkbench.tsx');
|
|
17
|
-
const appearanceTab = read('src/components/settings/view/tabs/AppearanceSettingsTab.tsx');
|
|
18
|
-
const loginForm = read('src/components/auth/view/LoginForm.tsx');
|
|
19
|
-
|
|
20
|
-
const enCommon = JSON.parse(read('src/i18n/locales/en/common.json'));
|
|
21
|
-
|
|
22
|
-
assert(
|
|
23
|
-
preferenceHook.includes("export type WorkbenchLayoutPreference = 'vscode';")
|
|
24
|
-
&& preferenceHook.includes('WORKBENCH_LAYOUT_CHANGE_EVENT')
|
|
25
|
-
&& !preferenceHook.includes("'classic'"),
|
|
26
|
-
'Workbench layout preference should be VS Code-only and should not preserve Classic fallback.',
|
|
27
|
-
);
|
|
28
|
-
|
|
29
|
-
assert(
|
|
30
|
-
appContent.includes('VSCodeWorkbench')
|
|
31
|
-
&& appContent.includes('<VSCodeWorkbench')
|
|
32
|
-
&& !appContent.includes('!useVscodeWorkbench'),
|
|
33
|
-
'AppContent should render the VS Code workbench as the desktop shell.',
|
|
34
|
-
);
|
|
35
|
-
|
|
36
|
-
assert(
|
|
37
|
-
workbench.includes('WorkbenchProjectLanding')
|
|
38
|
-
&& workbench.includes("useState<ActivityPanel>('projects')")
|
|
39
|
-
&& workbench.includes('WorkbenchWorkspacePanel')
|
|
40
|
-
&& workbench.includes('WorkbenchWorkspaceTabs')
|
|
41
|
-
&& workbench.includes('openEditorTabs')
|
|
42
|
-
&& workbench.includes('activeEditorPath')
|
|
43
|
-
&& workbench.includes('WorkbenchCliPanel')
|
|
44
|
-
&& !workbench.includes('<ChatInterface')
|
|
45
|
-
&& !workbench.includes('TaskMasterPanel'),
|
|
46
|
-
'VSCodeWorkbench should open on Projects, expose top workspace tabs, tab files, and use terminal-only CLI panel.',
|
|
47
|
-
);
|
|
48
|
-
|
|
49
|
-
assert(
|
|
50
|
-
!appearanceTab.includes('workbenchLayout')
|
|
51
|
-
&& !appearanceTab.includes('onWorkbenchLayoutChange')
|
|
52
|
-
&& !loginForm.includes('login.layout')
|
|
53
|
-
&& !loginForm.includes('setWorkbenchLayout'),
|
|
54
|
-
'Login and Appearance settings should not expose layout switching.',
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
assert(
|
|
58
|
-
enCommon.vscodeWorkbench?.activity?.explorer
|
|
59
|
-
&& enCommon.vscodeWorkbench?.panels?.cli,
|
|
60
|
-
'English common locale should include VS Code workbench copy.',
|
|
61
|
-
);
|
|
62
|
-
|
|
63
|
-
console.log('vscode workbench layout smoke passed');
|
|
1
|
+
import { existsSync, readFileSync } from 'node:fs';
|
|
2
|
+
|
|
3
|
+
function assert(condition, message) {
|
|
4
|
+
if (!condition) {
|
|
5
|
+
throw new Error(message);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
function read(path) {
|
|
10
|
+
assert(existsSync(path), `${path} should exist`);
|
|
11
|
+
return readFileSync(path, 'utf8');
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
const preferenceHook = read('src/hooks/useWorkbenchLayoutPreference.ts');
|
|
15
|
+
const appContent = read('src/components/app/AppContent.tsx');
|
|
16
|
+
const workbench = read('src/components/vscode-workbench/view/VSCodeWorkbench.tsx');
|
|
17
|
+
const appearanceTab = read('src/components/settings/view/tabs/AppearanceSettingsTab.tsx');
|
|
18
|
+
const loginForm = read('src/components/auth/view/LoginForm.tsx');
|
|
19
|
+
|
|
20
|
+
const enCommon = JSON.parse(read('src/i18n/locales/en/common.json'));
|
|
21
|
+
|
|
22
|
+
assert(
|
|
23
|
+
preferenceHook.includes("export type WorkbenchLayoutPreference = 'vscode';")
|
|
24
|
+
&& preferenceHook.includes('WORKBENCH_LAYOUT_CHANGE_EVENT')
|
|
25
|
+
&& !preferenceHook.includes("'classic'"),
|
|
26
|
+
'Workbench layout preference should be VS Code-only and should not preserve Classic fallback.',
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
assert(
|
|
30
|
+
appContent.includes('VSCodeWorkbench')
|
|
31
|
+
&& appContent.includes('<VSCodeWorkbench')
|
|
32
|
+
&& !appContent.includes('!useVscodeWorkbench'),
|
|
33
|
+
'AppContent should render the VS Code workbench as the desktop shell.',
|
|
34
|
+
);
|
|
35
|
+
|
|
36
|
+
assert(
|
|
37
|
+
workbench.includes('WorkbenchProjectLanding')
|
|
38
|
+
&& workbench.includes("useState<ActivityPanel>('projects')")
|
|
39
|
+
&& workbench.includes('WorkbenchWorkspacePanel')
|
|
40
|
+
&& workbench.includes('WorkbenchWorkspaceTabs')
|
|
41
|
+
&& workbench.includes('openEditorTabs')
|
|
42
|
+
&& workbench.includes('activeEditorPath')
|
|
43
|
+
&& workbench.includes('WorkbenchCliPanel')
|
|
44
|
+
&& !workbench.includes('<ChatInterface')
|
|
45
|
+
&& !workbench.includes('TaskMasterPanel'),
|
|
46
|
+
'VSCodeWorkbench should open on Projects, expose top workspace tabs, tab files, and use terminal-only CLI panel.',
|
|
47
|
+
);
|
|
48
|
+
|
|
49
|
+
assert(
|
|
50
|
+
!appearanceTab.includes('workbenchLayout')
|
|
51
|
+
&& !appearanceTab.includes('onWorkbenchLayoutChange')
|
|
52
|
+
&& !loginForm.includes('login.layout')
|
|
53
|
+
&& !loginForm.includes('setWorkbenchLayout'),
|
|
54
|
+
'Login and Appearance settings should not expose layout switching.',
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
assert(
|
|
58
|
+
enCommon.vscodeWorkbench?.activity?.explorer
|
|
59
|
+
&& enCommon.vscodeWorkbench?.panels?.cli,
|
|
60
|
+
'English common locale should include VS Code workbench copy.',
|
|
61
|
+
);
|
|
62
|
+
|
|
63
|
+
console.log('vscode workbench layout smoke passed');
|