jettypod 4.1.2 → 4.1.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/.nvmrc +1 -0
- package/docs/COMPLETE-TESTING-STRATEGY.md +970 -0
- package/docs/DECISIONS.md +10 -12
- package/docs/NODE_VERSION.md +83 -0
- package/docs/TDD-INFRASTRUCTURE-STRATEGY.md +1374 -0
- package/docs/TESTING-FOR-NON-ENGINEERS.md +1588 -0
- package/docs/TESTING-STRATEGY-AUDIT.md +698 -0
- package/hooks/post-checkout +17 -0
- package/hooks/post-merge +17 -0
- package/hooks/pre-commit +30 -0
- package/jettypod.js +259 -120
- package/lib/coverage-tracker.js +218 -0
- package/lib/database.js +2 -0
- package/lib/db-export.js +192 -0
- package/lib/db-import.js +193 -0
- package/lib/external-transition-handler.js +32 -0
- package/lib/git-hook-helpers.js +174 -0
- package/lib/git-root.js +90 -0
- package/lib/infrastructure-chore-generator.js +45 -0
- package/lib/install-hooks.js +52 -0
- package/lib/jettypod-backup.js +238 -0
- package/lib/merge-lock.js +193 -0
- package/lib/migrations/012-add-worktree-path.js +38 -0
- package/lib/migrations/013-worktrees-table.js +86 -0
- package/lib/migrations/014-migrate-worktree-data.js +161 -0
- package/lib/migrations/015-merge-locks-table.js +67 -0
- package/lib/pattern-finder.js +152 -0
- package/lib/process-manager.js +140 -0
- package/lib/production-standards-reader.js +13 -2
- package/lib/production-standards-writer.js +85 -0
- package/lib/skills/feature-planning/dry-run-validator.js +135 -0
- package/lib/skills/feature-planning/validation-formatter.js +160 -0
- package/lib/smart-conflict-detection.js +168 -0
- package/lib/smart-fetch-rebase.js +614 -0
- package/lib/step-definition-parser.js +76 -0
- package/lib/unit-test-generator.js +232 -0
- package/lib/verification-command-generator.js +66 -0
- package/lib/worktree-diagnostics.js +413 -0
- package/lib/worktree-facade.js +174 -0
- package/lib/worktree-manager.js +636 -0
- package/lib/worktree-reconciler.js +429 -0
- package/package.json +30 -3
- package/skills-templates/external-transition/SKILL.md +34 -3
- package/skills-templates/feature-planning/SKILL.md +190 -24
- package/skills-templates/production-mode/SKILL.md +127 -9
- package/skills-templates/speed-mode/SKILL.md +454 -51
- package/skills-templates/stable-mode/SKILL.md +285 -76
- package/.claude/PROTECT_SKILLS.md +0 -28
- package/.claude/settings.json +0 -24
- package/.claude/settings.local.json +0 -16
- package/.claude/skills/epic-planning/SKILL.md +0 -297
- package/.claude/skills/external-transition/SKILL.md +0 -384
- package/.claude/skills/feature-planning/SKILL.md +0 -464
- package/.claude/skills/production-mode/SKILL.md +0 -369
- package/.claude/skills/speed-mode/SKILL.md +0 -481
- package/.claude/skills/stable-mode/SKILL.md +0 -713
- package/.claude/skills.backup-2025-11-10T23-33-09-368Z/epic-planning/SKILL.md +0 -297
- package/.claude/skills.backup-2025-11-10T23-33-09-368Z/feature-planning/SKILL.md +0 -464
- package/.claude/skills.backup-2025-11-10T23-33-09-368Z/speed-mode/SKILL.md +0 -467
- package/.claude/skills.backup-2025-11-10T23-33-09-368Z/stable-mode/SKILL.md +0 -673
- package/.claude/skills.backup-2025-11-11T16-15-10-070Z/epic-discover/SKILL.md +0 -297
- package/.claude/skills.backup-2025-11-11T16-42-43-212Z/epic-planning/SKILL.md +0 -297
- package/.claude/skills.backup-2025-11-11T16-42-43-212Z/feature-planning/SKILL.md +0 -464
- package/.claude/skills.backup-2025-11-11T16-42-43-212Z/speed-mode/SKILL.md +0 -467
- package/.claude/skills.backup-2025-11-11T16-42-43-212Z/stable-mode/SKILL.md +0 -673
- package/.claude/skills.backup-2025-11-11T17-06-09-783Z/epic-planning/SKILL.md +0 -297
- package/.claude/skills.backup-2025-11-11T17-06-09-783Z/feature-planning/SKILL.md +0 -464
- package/.claude/skills.backup-2025-11-11T17-06-09-783Z/speed-mode/SKILL.md +0 -467
- package/.claude/skills.backup-2025-11-11T17-06-09-783Z/stable-mode/SKILL.md +0 -673
- package/.devpod/current-work.json +0 -10
- package/.devpod/work.db +0 -0
- package/.github/workflows/test-safety.yml +0 -85
- package/.jettypod/config.json +0 -5
- package/.jettypod/current-work.json +0 -10
- package/.jettypod/hooks/README.md +0 -77
- package/.jettypod/hooks/protect-claude-md.js +0 -338
- package/.jettypod/test-work.db +0 -0
- package/.jettypod/work.db +0 -0
- package/CLAUDE.md +0 -49
- package/SPEED-STABLE-AUDIT.md +0 -853
- package/SYSTEM-BEHAVIOR.md +0 -2199
- package/TEST_SAFETY_AUDIT.md +0 -314
- package/TEST_SAFETY_IMPLEMENTATION.md +0 -97
- package/cucumber-report.html +0 -45
- package/dist/devpod-linux +0 -0
- package/dist/devpod-macos +0 -0
- package/dist/devpod-win.exe +0 -0
- package/docs/features/jettypod-standards-explained.md +0 -543
- package/docs/features/standards-inventory.md +0 -257
- package/features/auto-generate-production-chores.feature +0 -13
- package/features/backlog-command.feature +0 -26
- package/features/backlog-filtering-production.feature +0 -10
- package/features/claude-md-protection/steps.js +0 -498
- package/features/decisions/index.js +0 -490
- package/features/decisions/index.test.js +0 -208
- package/features/fix-text-wrapping.feature +0 -42
- package/features/git-hooks/git-hooks.feature +0 -30
- package/features/git-hooks/index.js +0 -93
- package/features/git-hooks/index.test.js +0 -137
- package/features/git-hooks/post-commit +0 -56
- package/features/git-hooks/post-merge +0 -47
- package/features/git-hooks/pre-commit +0 -28
- package/features/git-hooks/simple-steps.js +0 -53
- package/features/git-hooks/simple-test.feature +0 -10
- package/features/git-hooks/steps.js +0 -196
- package/features/jettypod-update-command.feature +0 -46
- package/features/mode-prompts/index.js +0 -95
- package/features/mode-prompts/simple-steps.js +0 -44
- package/features/mode-prompts/simple-test.feature +0 -9
- package/features/mode-prompts/validation.test.js +0 -120
- package/features/multiple-claude-instances.feature +0 -121
- package/features/production-mode-skill.feature +0 -121
- package/features/refactor-mode/steps.js +0 -217
- package/features/refactor-mode.feature +0 -49
- package/features/simplify-external-transition.feature +0 -166
- package/features/skills-update/index.test.js +0 -216
- package/features/step_definitions/backlog-command.steps.js +0 -37
- package/features/step_definitions/fix-text-wrapping.steps.js +0 -271
- package/features/step_definitions/multiple-claude-instances.steps.js +0 -621
- package/features/step_definitions/production-mode-skill.steps.js +0 -862
- package/features/step_definitions/simplify-external-transition.steps.js +0 -370
- package/features/step_definitions/terminal-logo.steps.js +0 -145
- package/features/step_definitions/update-command.steps.js +0 -183
- package/features/support/hooks.js +0 -9
- package/features/terminal-logo/index.js +0 -39
- package/features/terminal-logo/terminal-logo.feature +0 -30
- package/features/update-command/index.js +0 -181
- package/features/update-command/index.test.js +0 -225
- package/features/work-commands/bug-workflow-display.feature +0 -22
- package/features/work-commands/index.js +0 -498
- package/features/work-commands/simple-steps.js +0 -69
- package/features/work-commands/stable-tests.feature +0 -57
- package/features/work-commands/steps.js +0 -1174
- package/features/work-commands/validation.test.js +0 -88
- package/features/work-commands/work-commands.feature +0 -13
- package/features/work-tracking/discovery-validation.test.js +0 -228
- package/features/work-tracking/index.js +0 -1921
- package/features/work-tracking/mode-required.feature +0 -112
- package/features/work-tracking/phase-tracking.test.js +0 -482
- package/features/work-tracking/prototype-tracking.test.js +0 -485
- package/features/work-tracking/tree-view.test.js +0 -310
- package/features/work-tracking/work-set-mode.feature +0 -71
- package/features/work-tracking/work-start-mode.feature +0 -88
- package/full-test.txt +0 -0
- package/lib/bug-workflow.test.js +0 -177
- package/lib/claudemd.test.js +0 -195
- package/lib/config.test.js +0 -511
- package/lib/constants.test.js +0 -164
- package/lib/current-work.test.js +0 -146
- package/lib/database-project-config.test.js +0 -111
- package/lib/database.test.js +0 -106
- package/lib/decisions-generator.test.js +0 -457
- package/lib/decisions-helpers.test.js +0 -310
- package/lib/git-coordinator.js +0 -167
- package/lib/git.test.js +0 -145
- package/lib/migrations/002-default-work-item-modes.test.js +0 -351
- package/lib/production-chore-generator.test.js +0 -432
- package/lib/production-context-detector.test.js +0 -277
- package/lib/production-scenario-appender.test.js +0 -235
- package/lib/production-scenario-validator.test.js +0 -246
- package/lib/production-standards-reader.test.js +0 -270
- package/lib/project-state.test.js +0 -92
- package/lib/push-queue.js +0 -417
- package/lib/queue-processor.js +0 -74
- package/lib/test-helpers.js +0 -202
- package/lib/test-helpers.test.js +0 -255
- package/prototypes/2025-01-11-production-mode-autonomous.js +0 -119
- package/prototypes/2025-01-11-production-mode-collaborative.js +0 -166
- package/prototypes/2025-01-11-production-mode-guided.js +0 -217
- package/prototypes/2025-01-11-production-mode-smart-context.js +0 -347
- package/prototypes/2025-01-11-production-standards-example.md +0 -204
- package/prototypes/2025-11-10-backlog-filtering-tree-aware.js +0 -242
- package/prototypes/test/index.html +0 -1
- package/setup-dist-repo.sh +0 -68
- package/test-production-standards-engine.js +0 -130
- package/test-results.json +0 -2195
- package/test-safety-check.sh +0 -80
- package/work-item-tracking-plan.md +0 -199
- /package/{.jettypod/devpod.db → jettypod.db} +0 -0
package/test-results.json
DELETED
|
@@ -1,2195 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
> jettypod@4.0.0 test
|
|
3
|
-
> npm run test:unit && npm run test:bdd && npm run test:cleanup
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
> jettypod@4.0.0 test:unit
|
|
7
|
-
> NODE_ENV=test jest
|
|
8
|
-
|
|
9
|
-
PASS lib/production-chore-generator.test.js
|
|
10
|
-
PASS lib/claudemd.test.js
|
|
11
|
-
PASS features/update-command/index.test.js
|
|
12
|
-
PASS features/git-hooks/index.test.js
|
|
13
|
-
● Console
|
|
14
|
-
|
|
15
|
-
console.log
|
|
16
|
-
⚠️ Not a git repository - skipping hook installation
|
|
17
|
-
|
|
18
|
-
at log (features/git-hooks/index.js:14:13)
|
|
19
|
-
|
|
20
|
-
console.log
|
|
21
|
-
✓ Git hooks installed (pre-commit, post-commit, post-merge)
|
|
22
|
-
|
|
23
|
-
at log (features/git-hooks/index.js:62:11)
|
|
24
|
-
|
|
25
|
-
console.log
|
|
26
|
-
✓ Git hooks installed (pre-commit, post-commit, post-merge)
|
|
27
|
-
|
|
28
|
-
at log (features/git-hooks/index.js:62:11)
|
|
29
|
-
|
|
30
|
-
console.log
|
|
31
|
-
✓ Git hooks installed (pre-commit, post-commit, post-merge)
|
|
32
|
-
|
|
33
|
-
at log (features/git-hooks/index.js:62:11)
|
|
34
|
-
|
|
35
|
-
PASS lib/database.test.js
|
|
36
|
-
PASS features/work-tracking/discovery-validation.test.js
|
|
37
|
-
● Console
|
|
38
|
-
|
|
39
|
-
console.log
|
|
40
|
-
Created epic #502: Test Epic
|
|
41
|
-
|
|
42
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
43
|
-
|
|
44
|
-
console.log
|
|
45
|
-
Created epic #503: Test Epic
|
|
46
|
-
|
|
47
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
48
|
-
|
|
49
|
-
console.log
|
|
50
|
-
Created feature #504: Test Feature
|
|
51
|
-
|
|
52
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
53
|
-
|
|
54
|
-
console.log
|
|
55
|
-
Created feature #505: Test Feature
|
|
56
|
-
|
|
57
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
58
|
-
|
|
59
|
-
console.log
|
|
60
|
-
Created chore #506: Test Chore
|
|
61
|
-
|
|
62
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
63
|
-
|
|
64
|
-
console.log
|
|
65
|
-
Created chore #507: Chore 1
|
|
66
|
-
|
|
67
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
68
|
-
|
|
69
|
-
console.log
|
|
70
|
-
Created chore #508: Chore 2
|
|
71
|
-
|
|
72
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
73
|
-
|
|
74
|
-
console.log
|
|
75
|
-
Created chore #509: Chore 3
|
|
76
|
-
|
|
77
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
78
|
-
|
|
79
|
-
console.log
|
|
80
|
-
Created bug #510: Test Bug
|
|
81
|
-
|
|
82
|
-
at Statement.log (features/work-tracking/index.js:108:17)
|
|
83
|
-
|
|
84
|
-
PASS features/decisions/index.test.js
|
|
85
|
-
● Console
|
|
86
|
-
|
|
87
|
-
console.log
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:203:11)
|
|
91
|
-
|
|
92
|
-
console.log
|
|
93
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
94
|
-
|
|
95
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:204:11)
|
|
96
|
-
|
|
97
|
-
console.log
|
|
98
|
-
📋 PROJECT-LEVEL DECISIONS
|
|
99
|
-
|
|
100
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:205:11)
|
|
101
|
-
|
|
102
|
-
console.log
|
|
103
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
104
|
-
|
|
105
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:206:11)
|
|
106
|
-
|
|
107
|
-
console.log
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:207:11)
|
|
111
|
-
|
|
112
|
-
console.error
|
|
113
|
-
❌ Unable to read project configuration
|
|
114
|
-
|
|
115
|
-
211 | projectConfig = config.read();
|
|
116
|
-
212 | } catch (err) {
|
|
117
|
-
> 213 | console.error('❌ Unable to read project configuration');
|
|
118
|
-
| ^
|
|
119
|
-
214 | console.error(`Error: ${err.message}`);
|
|
120
|
-
215 | console.log('');
|
|
121
|
-
216 | console.log('This could mean:');
|
|
122
|
-
|
|
123
|
-
at Object.error [as showProjectDecisions] (features/decisions/index.js:213:13)
|
|
124
|
-
at showProjectDecisions (features/decisions/index.test.js:34:30)
|
|
125
|
-
at Object.<anonymous> (node_modules/expect/build/index.js:1824:9)
|
|
126
|
-
at Object.throwingMatcher [as toThrow] (node_modules/expect/build/index.js:2235:93)
|
|
127
|
-
at Object.toThrow (features/decisions/index.test.js:34:58)
|
|
128
|
-
|
|
129
|
-
console.error
|
|
130
|
-
Error: Config file not found
|
|
131
|
-
|
|
132
|
-
212 | } catch (err) {
|
|
133
|
-
213 | console.error('❌ Unable to read project configuration');
|
|
134
|
-
> 214 | console.error(`Error: ${err.message}`);
|
|
135
|
-
| ^
|
|
136
|
-
215 | console.log('');
|
|
137
|
-
216 | console.log('This could mean:');
|
|
138
|
-
217 | console.log(' - .jettypod/config.json is missing or corrupted');
|
|
139
|
-
|
|
140
|
-
at Object.error [as showProjectDecisions] (features/decisions/index.js:214:13)
|
|
141
|
-
at showProjectDecisions (features/decisions/index.test.js:34:30)
|
|
142
|
-
at Object.<anonymous> (node_modules/expect/build/index.js:1824:9)
|
|
143
|
-
at Object.throwingMatcher [as toThrow] (node_modules/expect/build/index.js:2235:93)
|
|
144
|
-
at Object.toThrow (features/decisions/index.test.js:34:58)
|
|
145
|
-
|
|
146
|
-
console.log
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:215:13)
|
|
150
|
-
|
|
151
|
-
console.log
|
|
152
|
-
This could mean:
|
|
153
|
-
|
|
154
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:216:13)
|
|
155
|
-
|
|
156
|
-
console.log
|
|
157
|
-
- .jettypod/config.json is missing or corrupted
|
|
158
|
-
|
|
159
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:217:13)
|
|
160
|
-
|
|
161
|
-
console.log
|
|
162
|
-
- JettyPod is not initialized (run jettypod init)
|
|
163
|
-
|
|
164
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:218:13)
|
|
165
|
-
|
|
166
|
-
console.log
|
|
167
|
-
- Insufficient permissions to read config file
|
|
168
|
-
|
|
169
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:219:13)
|
|
170
|
-
|
|
171
|
-
console.log
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:220:13)
|
|
175
|
-
|
|
176
|
-
console.log
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
180
|
-
|
|
181
|
-
console.log
|
|
182
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
183
|
-
|
|
184
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
185
|
-
|
|
186
|
-
console.log
|
|
187
|
-
📋 PROJECT-LEVEL DECISIONS
|
|
188
|
-
|
|
189
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
190
|
-
|
|
191
|
-
console.log
|
|
192
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
193
|
-
|
|
194
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
195
|
-
|
|
196
|
-
console.log
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
200
|
-
|
|
201
|
-
console.log
|
|
202
|
-
No project-level decisions yet.
|
|
203
|
-
|
|
204
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
205
|
-
|
|
206
|
-
console.log
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
210
|
-
|
|
211
|
-
console.log
|
|
212
|
-
💡 Tip: Start project discovery to make UX and tech stack decisions:
|
|
213
|
-
|
|
214
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
215
|
-
|
|
216
|
-
console.log
|
|
217
|
-
Talk to Claude Code about what you want to build
|
|
218
|
-
|
|
219
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
220
|
-
|
|
221
|
-
console.log
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
225
|
-
|
|
226
|
-
console.log
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
230
|
-
|
|
231
|
-
console.log
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
235
|
-
|
|
236
|
-
console.log
|
|
237
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
238
|
-
|
|
239
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
240
|
-
|
|
241
|
-
console.log
|
|
242
|
-
📋 PROJECT-LEVEL DECISIONS
|
|
243
|
-
|
|
244
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
245
|
-
|
|
246
|
-
console.log
|
|
247
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
248
|
-
|
|
249
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
250
|
-
|
|
251
|
-
console.log
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
255
|
-
|
|
256
|
-
console.log
|
|
257
|
-
Winner: prototypes/test
|
|
258
|
-
|
|
259
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
260
|
-
|
|
261
|
-
console.log
|
|
262
|
-
Rationale: Testing
|
|
263
|
-
|
|
264
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
265
|
-
|
|
266
|
-
console.log
|
|
267
|
-
Decided: 10/30/2025
|
|
268
|
-
|
|
269
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
270
|
-
|
|
271
|
-
console.log
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
275
|
-
|
|
276
|
-
console.log
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:203:11)
|
|
280
|
-
|
|
281
|
-
console.log
|
|
282
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
283
|
-
|
|
284
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:204:11)
|
|
285
|
-
|
|
286
|
-
console.log
|
|
287
|
-
📋 PROJECT-LEVEL DECISIONS
|
|
288
|
-
|
|
289
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:205:11)
|
|
290
|
-
|
|
291
|
-
console.log
|
|
292
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
293
|
-
|
|
294
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:206:11)
|
|
295
|
-
|
|
296
|
-
console.log
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:207:11)
|
|
300
|
-
|
|
301
|
-
console.log
|
|
302
|
-
Winner: prototypes/test
|
|
303
|
-
|
|
304
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:225:13)
|
|
305
|
-
|
|
306
|
-
console.log
|
|
307
|
-
Rationale: Testing
|
|
308
|
-
|
|
309
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:227:15)
|
|
310
|
-
|
|
311
|
-
console.log
|
|
312
|
-
Decided: Invalid Date
|
|
313
|
-
|
|
314
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:231:17)
|
|
315
|
-
|
|
316
|
-
console.log
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
at Object.log [as showProjectDecisions] (features/decisions/index.js:244:11)
|
|
320
|
-
|
|
321
|
-
console.log
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:116:11)
|
|
325
|
-
|
|
326
|
-
console.log
|
|
327
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
328
|
-
|
|
329
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:117:11)
|
|
330
|
-
|
|
331
|
-
console.log
|
|
332
|
-
📋 ALL DECISIONS (Chronological)
|
|
333
|
-
|
|
334
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:118:11)
|
|
335
|
-
|
|
336
|
-
console.log
|
|
337
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
338
|
-
|
|
339
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:119:11)
|
|
340
|
-
|
|
341
|
-
console.log
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:120:11)
|
|
345
|
-
|
|
346
|
-
console.error
|
|
347
|
-
⚠️ Unable to read project configuration
|
|
348
|
-
|
|
349
|
-
125 | projectConfig = config.read();
|
|
350
|
-
126 | } catch (err) {
|
|
351
|
-
> 127 | console.error('⚠️ Unable to read project configuration');
|
|
352
|
-
| ^
|
|
353
|
-
128 | console.error(`Error: ${err.message}`);
|
|
354
|
-
129 | console.log('');
|
|
355
|
-
130 | console.log('Skipping project-level decisions...');
|
|
356
|
-
|
|
357
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
358
|
-
at Object.error [as showAllDecisions] (features/decisions/index.js:127:13)
|
|
359
|
-
at Object.showAllDecisions (features/decisions/index.test.js:101:23)
|
|
360
|
-
|
|
361
|
-
console.error
|
|
362
|
-
Error: Config corrupted
|
|
363
|
-
|
|
364
|
-
126 | } catch (err) {
|
|
365
|
-
127 | console.error('⚠️ Unable to read project configuration');
|
|
366
|
-
> 128 | console.error(`Error: ${err.message}`);
|
|
367
|
-
| ^
|
|
368
|
-
129 | console.log('');
|
|
369
|
-
130 | console.log('Skipping project-level decisions...');
|
|
370
|
-
131 | console.log('');
|
|
371
|
-
|
|
372
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
373
|
-
at Object.error [as showAllDecisions] (features/decisions/index.js:128:13)
|
|
374
|
-
at Object.showAllDecisions (features/decisions/index.test.js:101:23)
|
|
375
|
-
|
|
376
|
-
console.log
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:129:13)
|
|
380
|
-
|
|
381
|
-
console.log
|
|
382
|
-
Skipping project-level decisions...
|
|
383
|
-
|
|
384
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:130:13)
|
|
385
|
-
|
|
386
|
-
console.log
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
at Object.log [as showAllDecisions] (features/decisions/index.js:131:13)
|
|
390
|
-
|
|
391
|
-
console.log
|
|
392
|
-
No epic decisions yet.
|
|
393
|
-
|
|
394
|
-
at Statement.log (features/decisions/index.js:187:17)
|
|
395
|
-
|
|
396
|
-
console.log
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
at Statement.log (features/decisions/index.js:188:17)
|
|
400
|
-
|
|
401
|
-
console.log
|
|
402
|
-
💡 Tip: Make architectural decisions during epic planning:
|
|
403
|
-
|
|
404
|
-
at Statement.log (features/decisions/index.js:189:17)
|
|
405
|
-
|
|
406
|
-
console.log
|
|
407
|
-
jettypod work epic-planning <epic-id>
|
|
408
|
-
|
|
409
|
-
at Statement.log (features/decisions/index.js:190:17)
|
|
410
|
-
|
|
411
|
-
console.log
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
at Statement.log (features/decisions/index.js:191:17)
|
|
415
|
-
|
|
416
|
-
console.log
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
420
|
-
|
|
421
|
-
console.log
|
|
422
|
-
❌ Epic #999 not found
|
|
423
|
-
|
|
424
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
425
|
-
|
|
426
|
-
console.log
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
430
|
-
|
|
431
|
-
console.log
|
|
432
|
-
This could mean:
|
|
433
|
-
|
|
434
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
435
|
-
|
|
436
|
-
console.log
|
|
437
|
-
- Epic #999 does not exist
|
|
438
|
-
|
|
439
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
440
|
-
|
|
441
|
-
console.log
|
|
442
|
-
- Work item #999 is not an epic
|
|
443
|
-
|
|
444
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
445
|
-
|
|
446
|
-
console.log
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
450
|
-
|
|
451
|
-
console.log
|
|
452
|
-
💡 Tip: See your epics with: jettypod backlog
|
|
453
|
-
|
|
454
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
455
|
-
|
|
456
|
-
console.log
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
460
|
-
|
|
461
|
-
console.log
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
465
|
-
|
|
466
|
-
console.log
|
|
467
|
-
docs/DECISIONS.md not found.
|
|
468
|
-
|
|
469
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
470
|
-
|
|
471
|
-
console.log
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
475
|
-
|
|
476
|
-
console.log
|
|
477
|
-
💡 This file will be created automatically when:
|
|
478
|
-
|
|
479
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
480
|
-
|
|
481
|
-
console.log
|
|
482
|
-
- You complete project discovery
|
|
483
|
-
|
|
484
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
485
|
-
|
|
486
|
-
console.log
|
|
487
|
-
- You make epic architectural decisions
|
|
488
|
-
|
|
489
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
490
|
-
|
|
491
|
-
console.log
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
495
|
-
|
|
496
|
-
console.log
|
|
497
|
-
To make decisions:
|
|
498
|
-
|
|
499
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
500
|
-
|
|
501
|
-
console.log
|
|
502
|
-
jettypod work epic-planning <epic-id>
|
|
503
|
-
|
|
504
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
505
|
-
|
|
506
|
-
console.log
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
510
|
-
|
|
511
|
-
console.log
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
515
|
-
|
|
516
|
-
console.log
|
|
517
|
-
# Decisions
|
|
518
|
-
|
|
519
|
-
Test content
|
|
520
|
-
|
|
521
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
522
|
-
|
|
523
|
-
console.error
|
|
524
|
-
❌ Unable to read DECISIONS.md
|
|
525
|
-
|
|
526
|
-
453 | console.log(content);
|
|
527
|
-
454 | } catch (readErr) {
|
|
528
|
-
> 455 | console.error('❌ Unable to read DECISIONS.md');
|
|
529
|
-
| ^
|
|
530
|
-
456 | console.error(`Error: ${readErr.message}`);
|
|
531
|
-
457 | console.log('');
|
|
532
|
-
458 | console.log('This could mean:');
|
|
533
|
-
|
|
534
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
535
|
-
at Object.error [as viewDecisionsFile] (features/decisions/index.js:455:17)
|
|
536
|
-
at Object.viewDecisionsFile (features/decisions/index.test.js:195:17)
|
|
537
|
-
|
|
538
|
-
console.error
|
|
539
|
-
Error: Permission denied
|
|
540
|
-
|
|
541
|
-
454 | } catch (readErr) {
|
|
542
|
-
455 | console.error('❌ Unable to read DECISIONS.md');
|
|
543
|
-
> 456 | console.error(`Error: ${readErr.message}`);
|
|
544
|
-
| ^
|
|
545
|
-
457 | console.log('');
|
|
546
|
-
458 | console.log('This could mean:');
|
|
547
|
-
459 | console.log(' - File is corrupted');
|
|
548
|
-
|
|
549
|
-
at console.<anonymous> (node_modules/jest-mock/build/index.js:631:25)
|
|
550
|
-
at Object.error [as viewDecisionsFile] (features/decisions/index.js:456:17)
|
|
551
|
-
at Object.viewDecisionsFile (features/decisions/index.test.js:195:17)
|
|
552
|
-
|
|
553
|
-
console.log
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:457:17)
|
|
557
|
-
|
|
558
|
-
console.log
|
|
559
|
-
This could mean:
|
|
560
|
-
|
|
561
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:458:17)
|
|
562
|
-
|
|
563
|
-
console.log
|
|
564
|
-
- File is corrupted
|
|
565
|
-
|
|
566
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:459:17)
|
|
567
|
-
|
|
568
|
-
console.log
|
|
569
|
-
- Insufficient permissions to read file
|
|
570
|
-
|
|
571
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:460:17)
|
|
572
|
-
|
|
573
|
-
console.log
|
|
574
|
-
- File is locked by another process
|
|
575
|
-
|
|
576
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:461:17)
|
|
577
|
-
|
|
578
|
-
console.log
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
at Object.log [as viewDecisionsFile] (features/decisions/index.js:462:17)
|
|
582
|
-
|
|
583
|
-
PASS lib/config.test.js
|
|
584
|
-
PASS lib/decisions-generator.test.js
|
|
585
|
-
PASS features/work-tracking/phase-tracking.test.js
|
|
586
|
-
PASS features/work-tracking/prototype-tracking.test.js
|
|
587
|
-
PASS lib/production-scenario-appender.test.js
|
|
588
|
-
PASS lib/decisions-helpers.test.js
|
|
589
|
-
PASS lib/database-project-config.test.js
|
|
590
|
-
PASS lib/production-context-detector.test.js
|
|
591
|
-
PASS lib/test-helpers.test.js
|
|
592
|
-
PASS lib/project-state.test.js
|
|
593
|
-
PASS lib/production-scenario-validator.test.js
|
|
594
|
-
PASS lib/migrations/002-default-work-item-modes.test.js
|
|
595
|
-
PASS lib/production-standards-reader.test.js
|
|
596
|
-
PASS lib/constants.test.js
|
|
597
|
-
PASS lib/current-work.test.js
|
|
598
|
-
PASS features/work-tracking/tree-view.test.js
|
|
599
|
-
PASS features/work-commands/validation.test.js
|
|
600
|
-
PASS lib/bug-workflow.test.js
|
|
601
|
-
PASS features/mode-prompts/validation.test.js
|
|
602
|
-
PASS features/skills-update/index.test.js
|
|
603
|
-
PASS lib/git.test.js
|
|
604
|
-
|
|
605
|
-
Test Suites: 28 passed, 28 total
|
|
606
|
-
Tests: 415 passed, 415 total
|
|
607
|
-
Snapshots: 0 total
|
|
608
|
-
Time: 4.394 s
|
|
609
|
-
Ran all test suites.
|
|
610
|
-
|
|
611
|
-
> jettypod@4.0.0 test:bdd
|
|
612
|
-
> NODE_ENV=test cucumber-js
|
|
613
|
-
|
|
614
|
-
This Node.js version (v24.5.0) has not been tested with this version of Cucumber; it should work normally, but please raise an issue if you see anything unexpected.
|
|
615
|
-
`publishQuiet` option is no longer needed, you can remove it from your configuration; see https://github.com/cucumber/cucumber-js/blob/main/docs/deprecations.md
|
|
616
|
-
.......................................................................................................................................hint: Using 'master' as the name for the initial branch. This default branch name
|
|
617
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
618
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
619
|
-
hint:
|
|
620
|
-
hint: git config --global init.defaultBranch <name>
|
|
621
|
-
hint:
|
|
622
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
623
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
624
|
-
hint:
|
|
625
|
-
hint: git branch -m <name>
|
|
626
|
-
......F-...hint: Using 'master' as the name for the initial branch. This default branch name
|
|
627
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
628
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
629
|
-
hint:
|
|
630
|
-
hint: git config --global init.defaultBranch <name>
|
|
631
|
-
hint:
|
|
632
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
633
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
634
|
-
hint:
|
|
635
|
-
hint: git branch -m <name>
|
|
636
|
-
..........F...hint: Using 'master' as the name for the initial branch. This default branch name
|
|
637
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
638
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
639
|
-
hint:
|
|
640
|
-
hint: git config --global init.defaultBranch <name>
|
|
641
|
-
hint:
|
|
642
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
643
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
644
|
-
hint:
|
|
645
|
-
hint: git branch -m <name>
|
|
646
|
-
............hint: Using 'master' as the name for the initial branch. This default branch name
|
|
647
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
648
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
649
|
-
hint:
|
|
650
|
-
hint: git config --global init.defaultBranch <name>
|
|
651
|
-
hint:
|
|
652
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
653
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
654
|
-
hint:
|
|
655
|
-
hint: git branch -m <name>
|
|
656
|
-
.F---U--...hint: Using 'master' as the name for the initial branch. This default branch name
|
|
657
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
658
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
659
|
-
hint:
|
|
660
|
-
hint: git config --global init.defaultBranch <name>
|
|
661
|
-
hint:
|
|
662
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
663
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
664
|
-
hint:
|
|
665
|
-
hint: git branch -m <name>
|
|
666
|
-
..⚠️ Push queue file corrupted - reinitializing with empty queue
|
|
667
|
-
.......hint: Using 'master' as the name for the initial branch. This default branch name
|
|
668
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
669
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
670
|
-
hint:
|
|
671
|
-
hint: git config --global init.defaultBranch <name>
|
|
672
|
-
hint:
|
|
673
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
674
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
675
|
-
hint:
|
|
676
|
-
hint: git branch -m <name>
|
|
677
|
-
..❌ Insufficient permissions to write push queue
|
|
678
|
-
File: /Users/erikspangenberg/projects/jettypod-source/test-tmp/queue-test-O1wXNi/.jettypod/push-queue.json
|
|
679
|
-
|
|
680
|
-
To fix permissions:
|
|
681
|
-
chmod u+w /Users/erikspangenberg/projects/jettypod-source/test-tmp/queue-test-O1wXNi/.jettypod
|
|
682
|
-
chmod u+w /Users/erikspangenberg/projects/jettypod-source/test-tmp/queue-test-O1wXNi/.jettypod/push-queue.json
|
|
683
|
-
.......hint: Using 'master' as the name for the initial branch. This default branch name
|
|
684
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
685
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
686
|
-
hint:
|
|
687
|
-
hint: git config --global init.defaultBranch <name>
|
|
688
|
-
hint:
|
|
689
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
690
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
691
|
-
hint:
|
|
692
|
-
hint: git branch -m <name>
|
|
693
|
-
..........hint: Using 'master' as the name for the initial branch. This default branch name
|
|
694
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
695
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
696
|
-
hint:
|
|
697
|
-
hint: git config --global init.defaultBranch <name>
|
|
698
|
-
hint:
|
|
699
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
700
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
701
|
-
hint:
|
|
702
|
-
hint: git branch -m <name>
|
|
703
|
-
.........hint: Using 'master' as the name for the initial branch. This default branch name
|
|
704
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
705
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
706
|
-
hint:
|
|
707
|
-
hint: git config --global init.defaultBranch <name>
|
|
708
|
-
hint:
|
|
709
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
710
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
711
|
-
hint:
|
|
712
|
-
hint: git branch -m <name>
|
|
713
|
-
.........hint: Using 'master' as the name for the initial branch. This default branch name
|
|
714
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
715
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
716
|
-
hint:
|
|
717
|
-
hint: git config --global init.defaultBranch <name>
|
|
718
|
-
hint:
|
|
719
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
720
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
721
|
-
hint:
|
|
722
|
-
hint: git branch -m <name>
|
|
723
|
-
..⚠️ Found 1 invalid queue entries - removing them
|
|
724
|
-
Invalid entries detected with missing instanceId or commitSha
|
|
725
|
-
.......hint: Using 'master' as the name for the initial branch. This default branch name
|
|
726
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
727
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
728
|
-
hint:
|
|
729
|
-
hint: git config --global init.defaultBranch <name>
|
|
730
|
-
hint:
|
|
731
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
732
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
733
|
-
hint:
|
|
734
|
-
hint: git branch -m <name>
|
|
735
|
-
...🧹 Removed 1 stale queue entries
|
|
736
|
-
• Instance stale-instance (waiting 60 minutes)
|
|
737
|
-
.......hint: Using 'master' as the name for the initial branch. This default branch name
|
|
738
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
739
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
740
|
-
hint:
|
|
741
|
-
hint: git config --global init.defaultBranch <name>
|
|
742
|
-
hint:
|
|
743
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
744
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
745
|
-
hint:
|
|
746
|
-
hint: git branch -m <name>
|
|
747
|
-
.........hint: Using 'master' as the name for the initial branch. This default branch name
|
|
748
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
749
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
750
|
-
hint:
|
|
751
|
-
hint: git config --global init.defaultBranch <name>
|
|
752
|
-
hint:
|
|
753
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
754
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
755
|
-
hint:
|
|
756
|
-
hint: git branch -m <name>
|
|
757
|
-
..❌ Invalid commit SHA provided to queue
|
|
758
|
-
Commit SHA must be a non-empty string
|
|
759
|
-
|
|
760
|
-
To fix:
|
|
761
|
-
Ensure you have committed your changes before pushing
|
|
762
|
-
Run: git rev-parse HEAD
|
|
763
|
-
.......hint: Using 'master' as the name for the initial branch. This default branch name
|
|
764
|
-
hint: is subject to change. To configure the initial branch name to use in all
|
|
765
|
-
hint: of your new repositories, which will suppress this warning, call:
|
|
766
|
-
hint:
|
|
767
|
-
hint: git config --global init.defaultBranch <name>
|
|
768
|
-
hint:
|
|
769
|
-
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
|
|
770
|
-
hint: 'development'. The just-created branch can be renamed via this command:
|
|
771
|
-
hint:
|
|
772
|
-
hint: git branch -m <name>
|
|
773
|
-
..............F---............................................F-.............................U----..F----..........U--.....................................❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
774
|
-
Project state remains "internal"
|
|
775
|
-
.F-----....F--....❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
776
|
-
Project state remains "internal"
|
|
777
|
-
.F---....❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
778
|
-
Project state remains "internal"
|
|
779
|
-
.F--....❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
780
|
-
Project state remains "internal"
|
|
781
|
-
.F--....❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
782
|
-
Project state remains "internal"
|
|
783
|
-
.F--...UUU-UUUUU...U-UUUUUUUU...UU-UUU...UU-UUUU...U-UU--...UU-UUU...❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
784
|
-
Project state remains "internal"
|
|
785
|
-
.UUUU..UU-UUU...UUUUU...❌ Failed to generate infrastructure chores: Production standards file not found. Run external-transition first.
|
|
786
|
-
Project state remains "internal"
|
|
787
|
-
.UUUU...UU-UU...........................Phase column already exists, skipping...
|
|
788
|
-
Added prototype_files column to work_items
|
|
789
|
-
Added discovery_winner column to work_items
|
|
790
|
-
Added scenario_file column to work_items
|
|
791
|
-
Added discovery_rationale column to work_items
|
|
792
|
-
..Working on: [#1] Install script fails (bug)
|
|
793
|
-
|
|
794
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
795
|
-
🐛 BUG FIXING WORKFLOW
|
|
796
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
797
|
-
|
|
798
|
-
1. REPRODUCE
|
|
799
|
-
□ Create minimal reproduction case
|
|
800
|
-
□ Write down exact steps to trigger
|
|
801
|
-
□ Note what you expect vs what happens
|
|
802
|
-
□ Check if issue exists in latest code
|
|
803
|
-
|
|
804
|
-
2. INVESTIGATE
|
|
805
|
-
□ Read error messages/stack traces completely
|
|
806
|
-
□ Check relevant code around the issue
|
|
807
|
-
□ Look for recent changes (git log/blame)
|
|
808
|
-
□ Search for similar bugs (closed issues)
|
|
809
|
-
|
|
810
|
-
3. ISOLATE
|
|
811
|
-
□ Narrow down to specific file/function
|
|
812
|
-
□ Identify root cause, not just symptoms
|
|
813
|
-
□ Verify your hypothesis with logging/debugging
|
|
814
|
-
□ Understand why the bug occurs
|
|
815
|
-
|
|
816
|
-
4. FIX
|
|
817
|
-
□ Make the minimal change that fixes root cause
|
|
818
|
-
□ Avoid "while I'm here" refactoring
|
|
819
|
-
□ Add defensive checks if appropriate
|
|
820
|
-
□ Update error messages to be clearer
|
|
821
|
-
|
|
822
|
-
5. VERIFY
|
|
823
|
-
□ Confirm original reproduction case now works
|
|
824
|
-
□ Run existing tests - ensure nothing broke
|
|
825
|
-
□ Add regression test for this specific bug
|
|
826
|
-
□ Test edge cases around the fix
|
|
827
|
-
|
|
828
|
-
6. COMMIT
|
|
829
|
-
□ Clear commit message: "fix: [brief description]"
|
|
830
|
-
□ Reference issue number if applicable
|
|
831
|
-
□ Explain what caused it and how you fixed it
|
|
832
|
-
□ Push and verify CI passes
|
|
833
|
-
|
|
834
|
-
DEBUGGING TECHNIQUES:
|
|
835
|
-
• Add strategic console.log/print statements
|
|
836
|
-
• Use git bisect to find when bug was introduced
|
|
837
|
-
• Compare working vs broken behavior side-by-side
|
|
838
|
-
• Rubber duck: explain the bug out loud
|
|
839
|
-
• Take breaks - fresh eyes spot issues faster
|
|
840
|
-
|
|
841
|
-
RED FLAGS:
|
|
842
|
-
❌ "It works on my machine" - not fixed
|
|
843
|
-
❌ Fixing symptoms without understanding cause
|
|
844
|
-
❌ Adding try/catch to hide errors
|
|
845
|
-
❌ Skipping reproduction - you'll miss edge cases
|
|
846
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
847
|
-
|
|
848
|
-
..........Phase column already exists, skipping...
|
|
849
|
-
Added prototype_files column to work_items
|
|
850
|
-
Added discovery_winner column to work_items
|
|
851
|
-
Added scenario_file column to work_items
|
|
852
|
-
Added discovery_rationale column to work_items
|
|
853
|
-
..Working on: [#1] Add new feature (feature)
|
|
854
|
-
|
|
855
|
-
✨ Feature Discovery Mode
|
|
856
|
-
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
|
|
857
|
-
|
|
858
|
-
This feature is in discovery phase. Claude Code will help you:
|
|
859
|
-
1. Explore 3 different UX approaches
|
|
860
|
-
2. (Optional) Build throwaway prototypes
|
|
861
|
-
3. Choose the winning approach
|
|
862
|
-
4. Generate BDD scenarios for the happy path
|
|
863
|
-
5. Transition to implementation (speed mode)
|
|
864
|
-
|
|
865
|
-
💬 Claude Code is ready to guide you through feature discovery.
|
|
866
|
-
|
|
867
|
-
📋 The feature-planning skill will automatically activate.
|
|
868
|
-
|
|
869
|
-
....Phase column already exists, skipping...
|
|
870
|
-
Added prototype_files column to work_items
|
|
871
|
-
Added discovery_winner column to work_items
|
|
872
|
-
Added scenario_file column to work_items
|
|
873
|
-
Added discovery_rationale column to work_items
|
|
874
|
-
.....Phase column already exists, skipping...
|
|
875
|
-
Added prototype_files column to work_items
|
|
876
|
-
Added discovery_winner column to work_items
|
|
877
|
-
Added scenario_file column to work_items
|
|
878
|
-
Added discovery_rationale column to work_items
|
|
879
|
-
..........Phase column already exists, skipping...
|
|
880
|
-
Added prototype_files column to work_items
|
|
881
|
-
Added discovery_winner column to work_items
|
|
882
|
-
Added scenario_file column to work_items
|
|
883
|
-
Added discovery_rationale column to work_items
|
|
884
|
-
.....Phase column already exists, skipping...
|
|
885
|
-
Added prototype_files column to work_items
|
|
886
|
-
Added discovery_winner column to work_items
|
|
887
|
-
Added scenario_file column to work_items
|
|
888
|
-
Added discovery_rationale column to work_items
|
|
889
|
-
.....Phase column already exists, skipping...
|
|
890
|
-
Added prototype_files column to work_items
|
|
891
|
-
Added discovery_winner column to work_items
|
|
892
|
-
Added scenario_file column to work_items
|
|
893
|
-
Added discovery_rationale column to work_items
|
|
894
|
-
..No active work item
|
|
895
|
-
....Phase column already exists, skipping...
|
|
896
|
-
Added prototype_files column to work_items
|
|
897
|
-
Added discovery_winner column to work_items
|
|
898
|
-
Added scenario_file column to work_items
|
|
899
|
-
Added discovery_rationale column to work_items
|
|
900
|
-
.Phase column already exists, skipping...
|
|
901
|
-
Added prototype_files column to work_items
|
|
902
|
-
Added discovery_winner column to work_items
|
|
903
|
-
Added scenario_file column to work_items
|
|
904
|
-
Added discovery_rationale column to work_items
|
|
905
|
-
.Warning: Corrupted current work file: Unexpected token 'i', "invalid json {{{" is not valid JSON
|
|
906
|
-
....Phase column already exists, skipping...
|
|
907
|
-
Added prototype_files column to work_items
|
|
908
|
-
Added discovery_winner column to work_items
|
|
909
|
-
Added scenario_file column to work_items
|
|
910
|
-
Added discovery_rationale column to work_items
|
|
911
|
-
........Warning: Failed to create or checkout branch "feature/work-2-test-epic". Error: Command failed: git checkout "feature/work-2-test-epic"
|
|
912
|
-
error: Your local changes to the following files would be overwritten by checkout:
|
|
913
|
-
.jettypod/work.db
|
|
914
|
-
CLAUDE.md
|
|
915
|
-
lib/database.js
|
|
916
|
-
test-results.json
|
|
917
|
-
Please commit your changes or stash them before you switch branches.
|
|
918
|
-
Aborting
|
|
919
|
-
|
|
920
|
-
Working on: [#2] Test Epic (epic)
|
|
921
|
-
...................Phase column already exists, skipping...
|
|
922
|
-
Added prototype_files column to work_items
|
|
923
|
-
Added discovery_winner column to work_items
|
|
924
|
-
Added scenario_file column to work_items
|
|
925
|
-
Added discovery_rationale column to work_items
|
|
926
|
-
......Phase column already exists, skipping...
|
|
927
|
-
Added prototype_files column to work_items
|
|
928
|
-
Added discovery_winner column to work_items
|
|
929
|
-
Added scenario_file column to work_items
|
|
930
|
-
Added discovery_rationale column to work_items
|
|
931
|
-
......Phase column already exists, skipping...
|
|
932
|
-
Added prototype_files column to work_items
|
|
933
|
-
Added discovery_winner column to work_items
|
|
934
|
-
Added scenario_file column to work_items
|
|
935
|
-
Added discovery_rationale column to work_items
|
|
936
|
-
......Phase column already exists, skipping...
|
|
937
|
-
Added prototype_files column to work_items
|
|
938
|
-
Added discovery_winner column to work_items
|
|
939
|
-
Added scenario_file column to work_items
|
|
940
|
-
Added discovery_rationale column to work_items
|
|
941
|
-
...F..Phase column already exists, skipping...
|
|
942
|
-
Added prototype_files column to work_items
|
|
943
|
-
Added discovery_winner column to work_items
|
|
944
|
-
Added scenario_file column to work_items
|
|
945
|
-
Added discovery_rationale column to work_items
|
|
946
|
-
.Error: Invalid mode: invalid. Must be one of: speed, stable, production
|
|
947
|
-
.....Phase column already exists, skipping...
|
|
948
|
-
Added prototype_files column to work_items
|
|
949
|
-
Added discovery_winner column to work_items
|
|
950
|
-
Added scenario_file column to work_items
|
|
951
|
-
Added discovery_rationale column to work_items
|
|
952
|
-
.Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
953
|
-
..F..Phase column already exists, skipping...
|
|
954
|
-
Added prototype_files column to work_items
|
|
955
|
-
Added discovery_winner column to work_items
|
|
956
|
-
Added scenario_file column to work_items
|
|
957
|
-
Added discovery_rationale column to work_items
|
|
958
|
-
...F..Phase column already exists, skipping...
|
|
959
|
-
Added prototype_files column to work_items
|
|
960
|
-
Added discovery_winner column to work_items
|
|
961
|
-
Added scenario_file column to work_items
|
|
962
|
-
Added discovery_rationale column to work_items
|
|
963
|
-
......Phase column already exists, skipping...
|
|
964
|
-
Added prototype_files column to work_items
|
|
965
|
-
Added discovery_winner column to work_items
|
|
966
|
-
Added scenario_file column to work_items
|
|
967
|
-
Added discovery_rationale column to work_items
|
|
968
|
-
......Phase column already exists, skipping...
|
|
969
|
-
Added prototype_files column to work_items
|
|
970
|
-
Added discovery_winner column to work_items
|
|
971
|
-
Added scenario_file column to work_items
|
|
972
|
-
Added discovery_rationale column to work_items
|
|
973
|
-
......Phase column already exists, skipping...
|
|
974
|
-
Added prototype_files column to work_items
|
|
975
|
-
Added discovery_winner column to work_items
|
|
976
|
-
Added scenario_file column to work_items
|
|
977
|
-
Added discovery_rationale column to work_items
|
|
978
|
-
.Error: Invalid mode: discovery. Must be one of: speed, stable, production
|
|
979
|
-
..F..Phase column already exists, skipping...
|
|
980
|
-
Added prototype_files column to work_items
|
|
981
|
-
Added discovery_winner column to work_items
|
|
982
|
-
Added scenario_file column to work_items
|
|
983
|
-
Added discovery_rationale column to work_items
|
|
984
|
-
......Phase column already exists, skipping...
|
|
985
|
-
Added prototype_files column to work_items
|
|
986
|
-
Added discovery_winner column to work_items
|
|
987
|
-
Added scenario_file column to work_items
|
|
988
|
-
Added discovery_rationale column to work_items
|
|
989
|
-
......Phase column already exists, skipping...
|
|
990
|
-
Added prototype_files column to work_items
|
|
991
|
-
Added discovery_winner column to work_items
|
|
992
|
-
Added scenario_file column to work_items
|
|
993
|
-
Added discovery_rationale column to work_items
|
|
994
|
-
...Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
995
|
-
F------..Phase column already exists, skipping...
|
|
996
|
-
Added prototype_files column to work_items
|
|
997
|
-
Added discovery_winner column to work_items
|
|
998
|
-
Added scenario_file column to work_items
|
|
999
|
-
Added discovery_rationale column to work_items
|
|
1000
|
-
.......Phase column already exists, skipping...
|
|
1001
|
-
Added prototype_files column to work_items
|
|
1002
|
-
Added discovery_winner column to work_items
|
|
1003
|
-
Added scenario_file column to work_items
|
|
1004
|
-
Added discovery_rationale column to work_items
|
|
1005
|
-
.Error: Invalid mode: Speed. Must be one of: speed, stable, production
|
|
1006
|
-
....Phase column already exists, skipping...
|
|
1007
|
-
Added prototype_files column to work_items
|
|
1008
|
-
Added discovery_winner column to work_items
|
|
1009
|
-
Added scenario_file column to work_items
|
|
1010
|
-
Added discovery_rationale column to work_items
|
|
1011
|
-
.....Phase column already exists, skipping...
|
|
1012
|
-
Added prototype_files column to work_items
|
|
1013
|
-
Added discovery_winner column to work_items
|
|
1014
|
-
Added scenario_file column to work_items
|
|
1015
|
-
Added discovery_rationale column to work_items
|
|
1016
|
-
.....Phase column already exists, skipping...
|
|
1017
|
-
Added prototype_files column to work_items
|
|
1018
|
-
Added discovery_winner column to work_items
|
|
1019
|
-
Added scenario_file column to work_items
|
|
1020
|
-
Added discovery_rationale column to work_items
|
|
1021
|
-
...Working on: [#1] Test Feature (feature)
|
|
1022
|
-
.......Phase column already exists, skipping...
|
|
1023
|
-
Added prototype_files column to work_items
|
|
1024
|
-
Added discovery_winner column to work_items
|
|
1025
|
-
Added scenario_file column to work_items
|
|
1026
|
-
Added discovery_rationale column to work_items
|
|
1027
|
-
...Error: Invalid mode: discovery. Must be one of: speed, stable, production
|
|
1028
|
-
.Working on: [#1] Item 1 (feature)
|
|
1029
|
-
...F-..Phase column already exists, skipping...
|
|
1030
|
-
Added prototype_files column to work_items
|
|
1031
|
-
Added discovery_winner column to work_items
|
|
1032
|
-
Added scenario_file column to work_items
|
|
1033
|
-
Added discovery_rationale column to work_items
|
|
1034
|
-
........Phase column already exists, skipping...
|
|
1035
|
-
Added prototype_files column to work_items
|
|
1036
|
-
Added discovery_winner column to work_items
|
|
1037
|
-
Added scenario_file column to work_items
|
|
1038
|
-
Added discovery_rationale column to work_items
|
|
1039
|
-
.......Phase column already exists, skipping...
|
|
1040
|
-
Added prototype_files column to work_items
|
|
1041
|
-
Added discovery_winner column to work_items
|
|
1042
|
-
Added scenario_file column to work_items
|
|
1043
|
-
Added discovery_rationale column to work_items
|
|
1044
|
-
...Working on: [#1] Test Feature (feature)
|
|
1045
|
-
..F-..Phase column already exists, skipping...
|
|
1046
|
-
Added prototype_files column to work_items
|
|
1047
|
-
Added discovery_winner column to work_items
|
|
1048
|
-
Added scenario_file column to work_items
|
|
1049
|
-
Added discovery_rationale column to work_items
|
|
1050
|
-
...Working on: [#1] Test Feature (feature)
|
|
1051
|
-
......Phase column already exists, skipping...
|
|
1052
|
-
Added prototype_files column to work_items
|
|
1053
|
-
Added discovery_winner column to work_items
|
|
1054
|
-
Added scenario_file column to work_items
|
|
1055
|
-
Added discovery_rationale column to work_items
|
|
1056
|
-
...Working on: [#1] Test Feature (feature)
|
|
1057
|
-
......Phase column already exists, skipping...
|
|
1058
|
-
Added prototype_files column to work_items
|
|
1059
|
-
Added discovery_winner column to work_items
|
|
1060
|
-
Added scenario_file column to work_items
|
|
1061
|
-
Added discovery_rationale column to work_items
|
|
1062
|
-
...Working on: [#1] Test Feature (feature)
|
|
1063
|
-
..Stopped work on #1
|
|
1064
|
-
.Working on: [#1] Test Feature (feature)
|
|
1065
|
-
....Phase column already exists, skipping...
|
|
1066
|
-
Added prototype_files column to work_items
|
|
1067
|
-
Added discovery_winner column to work_items
|
|
1068
|
-
Added scenario_file column to work_items
|
|
1069
|
-
Added discovery_rationale column to work_items
|
|
1070
|
-
...Working on: [#1] Test Feature (feature)
|
|
1071
|
-
........Phase column already exists, skipping...
|
|
1072
|
-
Added prototype_files column to work_items
|
|
1073
|
-
Added discovery_winner column to work_items
|
|
1074
|
-
Added scenario_file column to work_items
|
|
1075
|
-
Added discovery_rationale column to work_items
|
|
1076
|
-
...Working on: [#1] Speed Feature (feature)
|
|
1077
|
-
....Phase column already exists, skipping...
|
|
1078
|
-
Added prototype_files column to work_items
|
|
1079
|
-
Added discovery_winner column to work_items
|
|
1080
|
-
Added scenario_file column to work_items
|
|
1081
|
-
Added discovery_rationale column to work_items
|
|
1082
|
-
..Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
1083
|
-
.F-..Phase column already exists, skipping...
|
|
1084
|
-
Added prototype_files column to work_items
|
|
1085
|
-
Added discovery_winner column to work_items
|
|
1086
|
-
Added scenario_file column to work_items
|
|
1087
|
-
Added discovery_rationale column to work_items
|
|
1088
|
-
..Error: Invalid mode: discovery. Must be one of: speed, stable, production
|
|
1089
|
-
..Working on: [#1] Child Chore (chore of #1 Child Chore)
|
|
1090
|
-
|
|
1091
|
-
⚠️ Warning: Parent feature has no scenario file
|
|
1092
|
-
|
|
1093
|
-
Parent feature #1 "Child Chore" does not have
|
|
1094
|
-
a scenario file set.
|
|
1095
|
-
|
|
1096
|
-
Suggestion: Create a BDD scenario file for the feature and update scenario_file.
|
|
1097
|
-
|
|
1098
|
-
.F..Phase column already exists, skipping...
|
|
1099
|
-
Added prototype_files column to work_items
|
|
1100
|
-
Added discovery_winner column to work_items
|
|
1101
|
-
Added scenario_file column to work_items
|
|
1102
|
-
Added discovery_rationale column to work_items
|
|
1103
|
-
...Working on: [#1] Production Feature (feature)
|
|
1104
|
-
....Phase column already exists, skipping...
|
|
1105
|
-
Added prototype_files column to work_items
|
|
1106
|
-
Added discovery_winner column to work_items
|
|
1107
|
-
Added scenario_file column to work_items
|
|
1108
|
-
Added discovery_rationale column to work_items
|
|
1109
|
-
...Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
1110
|
-
.Working on: [#1] Speed Feature (feature)
|
|
1111
|
-
..Stopped work on #1
|
|
1112
|
-
.Working on: [#1] Speed Feature (feature)
|
|
1113
|
-
.F..Phase column already exists, skipping...
|
|
1114
|
-
Added prototype_files column to work_items
|
|
1115
|
-
Added discovery_winner column to work_items
|
|
1116
|
-
Added scenario_file column to work_items
|
|
1117
|
-
Added discovery_rationale column to work_items
|
|
1118
|
-
..Error: Invalid mode: discovery. Must be one of: speed, stable, production
|
|
1119
|
-
...F-..Phase column already exists, skipping...
|
|
1120
|
-
Added prototype_files column to work_items
|
|
1121
|
-
Added discovery_winner column to work_items
|
|
1122
|
-
Added scenario_file column to work_items
|
|
1123
|
-
Added discovery_rationale column to work_items
|
|
1124
|
-
...Working on: [#1] Test Epic (epic)
|
|
1125
|
-
.....Phase column already exists, skipping...
|
|
1126
|
-
Added prototype_files column to work_items
|
|
1127
|
-
Added discovery_winner column to work_items
|
|
1128
|
-
Added scenario_file column to work_items
|
|
1129
|
-
Added discovery_rationale column to work_items
|
|
1130
|
-
...F--..Phase column already exists, skipping...
|
|
1131
|
-
Added prototype_files column to work_items
|
|
1132
|
-
Added discovery_winner column to work_items
|
|
1133
|
-
Added scenario_file column to work_items
|
|
1134
|
-
Added discovery_rationale column to work_items
|
|
1135
|
-
....Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
1136
|
-
F-----..Phase column already exists, skipping...
|
|
1137
|
-
Added prototype_files column to work_items
|
|
1138
|
-
Added discovery_winner column to work_items
|
|
1139
|
-
Added scenario_file column to work_items
|
|
1140
|
-
Added discovery_rationale column to work_items
|
|
1141
|
-
...Working on: [#1] Test Feature (feature)
|
|
1142
|
-
.Stopped work on #1
|
|
1143
|
-
....Phase column already exists, skipping...
|
|
1144
|
-
Added prototype_files column to work_items
|
|
1145
|
-
Added discovery_winner column to work_items
|
|
1146
|
-
Added scenario_file column to work_items
|
|
1147
|
-
Added discovery_rationale column to work_items
|
|
1148
|
-
...Working on: [#1] Test Feature (feature)
|
|
1149
|
-
.Stopped work on #1
|
|
1150
|
-
.Working on: [#1] Test Feature (feature)
|
|
1151
|
-
....
|
|
1152
|
-
|
|
1153
|
-
Failures:
|
|
1154
|
-
|
|
1155
|
-
1) Scenario: Single Claude instance pushes to main without queue # features/multiple-claude-instances.feature:8
|
|
1156
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1157
|
-
✔ Before # features/step_definitions/multiple-claude-instances.steps.js:19
|
|
1158
|
-
✔ Given I am a Claude Code instance with completed work # features/step_definitions/multiple-claude-instances.steps.js:64
|
|
1159
|
-
✔ And I have committed my changes locally # features/step_definitions/multiple-claude-instances.steps.js:69
|
|
1160
|
-
✔ And the push queue is empty # features/step_definitions/multiple-claude-instances.steps.js:75
|
|
1161
|
-
✔ And main branch has no new commits # features/step_definitions/multiple-claude-instances.steps.js:80
|
|
1162
|
-
✔ When I attempt to push to main # features/step_definitions/multiple-claude-instances.steps.js:114
|
|
1163
|
-
✖ Then I push directly to main # features/step_definitions/multiple-claude-instances.steps.js:154
|
|
1164
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1165
|
-
|
|
1166
|
-
'queued' !== 'direct'
|
|
1167
|
-
|
|
1168
|
-
+ expected - actual
|
|
1169
|
-
|
|
1170
|
-
-queued
|
|
1171
|
-
+direct
|
|
1172
|
-
|
|
1173
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/multiple-claude-instances.steps.js:155:10)
|
|
1174
|
-
- And I do not create a queue entry # features/step_definitions/multiple-claude-instances.steps.js:158
|
|
1175
|
-
✔ After # features/step_definitions/multiple-claude-instances.steps.js:41
|
|
1176
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1177
|
-
|
|
1178
|
-
2) Scenario: First Claude instance creates queue entry when main is ahead # features/multiple-claude-instances.feature:17
|
|
1179
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1180
|
-
✔ Before # features/step_definitions/multiple-claude-instances.steps.js:19
|
|
1181
|
-
✔ Given I am a Claude Code instance with completed work # features/step_definitions/multiple-claude-instances.steps.js:64
|
|
1182
|
-
✔ And I have committed my changes locally # features/step_definitions/multiple-claude-instances.steps.js:69
|
|
1183
|
-
✔ And the push queue is empty # features/step_definitions/multiple-claude-instances.steps.js:75
|
|
1184
|
-
✔ And main branch has 2 new commits since my work started # features/step_definitions/multiple-claude-instances.steps.js:85
|
|
1185
|
-
✔ When I attempt to push to main # features/step_definitions/multiple-claude-instances.steps.js:114
|
|
1186
|
-
✔ Then I create a queue entry at position 1 # features/step_definitions/multiple-claude-instances.steps.js:164
|
|
1187
|
-
✔ And I see "Added to push queue (position 1)" # features/step_definitions/multiple-claude-instances.steps.js:171
|
|
1188
|
-
✔ And I rebase my commits on top of main # features/step_definitions/multiple-claude-instances.steps.js:177
|
|
1189
|
-
✔ And I push to main # features/step_definitions/multiple-claude-instances.steps.js:182
|
|
1190
|
-
✖ And I remove my queue entry # features/step_definitions/multiple-claude-instances.steps.js:187
|
|
1191
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1192
|
-
+ actual - expected
|
|
1193
|
-
|
|
1194
|
-
+ {
|
|
1195
|
-
+ commitSha: '5c2c466d83aa42ff497da8fc05e0eec96a62471a',
|
|
1196
|
-
+ instanceId: 'test-instance-1762982016349',
|
|
1197
|
-
+ position: 1,
|
|
1198
|
-
+ status: 'waiting',
|
|
1199
|
-
+ timestamp: 1762982016695
|
|
1200
|
-
+ }
|
|
1201
|
-
- undefined
|
|
1202
|
-
|
|
1203
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/multiple-claude-instances.steps.js:191:10)
|
|
1204
|
-
✔ After # features/step_definitions/multiple-claude-instances.steps.js:41
|
|
1205
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1206
|
-
|
|
1207
|
-
3) Scenario: Queue processes sequentially when first completes # features/multiple-claude-instances.feature:39
|
|
1208
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1209
|
-
✔ Before # features/step_definitions/multiple-claude-instances.steps.js:19
|
|
1210
|
-
✖ Given Claude instance A is at position 1 and is pushing # features/step_definitions/multiple-claude-instances.steps.js:106
|
|
1211
|
-
TypeError: Cannot set properties of undefined (setting 'status')
|
|
1212
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/multiple-claude-instances.steps.js:110:16)
|
|
1213
|
-
- And I am at position 2 in the queue # features/step_definitions/multiple-claude-instances.steps.js:381
|
|
1214
|
-
- When Claude instance A completes their push # features/step_definitions/multiple-claude-instances.steps.js:141
|
|
1215
|
-
- Then I move to position 1 # features/step_definitions/multiple-claude-instances.steps.js:204
|
|
1216
|
-
? And I rebase my commits on top of the updated main
|
|
1217
|
-
Undefined. Implement with the following snippet:
|
|
1218
|
-
|
|
1219
|
-
Then('I rebase my commits on top of the updated main', function () {
|
|
1220
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1221
|
-
return 'pending';
|
|
1222
|
-
});
|
|
1223
|
-
|
|
1224
|
-
- And I push to main # features/step_definitions/multiple-claude-instances.steps.js:182
|
|
1225
|
-
- And I remove my queue entry # features/step_definitions/multiple-claude-instances.steps.js:187
|
|
1226
|
-
✔ After # features/step_definitions/multiple-claude-instances.steps.js:41
|
|
1227
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1228
|
-
|
|
1229
|
-
4) Scenario: Fresh from stable mode - Quick validation (Scenario A) # features/production-mode-skill.feature:8
|
|
1230
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1231
|
-
✔ Given a feature just completed stable mode within 1 day # features/step_definitions/production-mode-skill.steps.js:15
|
|
1232
|
-
✔ And production scenarios already exist in the feature file # features/step_definitions/production-mode-skill.steps.js:43
|
|
1233
|
-
✔ And production chores already exist for the feature # features/step_definitions/production-mode-skill.steps.js:86
|
|
1234
|
-
✔ And production standards file exists # features/step_definitions/production-mode-skill.steps.js:108
|
|
1235
|
-
✔ When I start the production-mode skill for this feature # features/step_definitions/production-mode-skill.steps.js:274
|
|
1236
|
-
✖ Then it detects Scenario A (hot context) # features/step_definitions/production-mode-skill.steps.js:286
|
|
1237
|
-
AssertionError [ERR_ASSERTION]: Should have production scenarios
|
|
1238
|
-
+ expected - actual
|
|
1239
|
-
|
|
1240
|
-
-false
|
|
1241
|
-
+true
|
|
1242
|
-
|
|
1243
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/production-mode-skill.steps.js:301:16)
|
|
1244
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1245
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1246
|
-
- And it validates existing scenarios against current standards # features/step_definitions/production-mode-skill.steps.js:309
|
|
1247
|
-
- And it identifies no gaps # features/step_definitions/production-mode-skill.steps.js:318
|
|
1248
|
-
- And it proceeds to implement existing production chores # features/step_definitions/production-mode-skill.steps.js:328
|
|
1249
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1250
|
-
|
|
1251
|
-
5) Scenario: Invalid production standards format # features/production-mode-skill.feature:59
|
|
1252
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1253
|
-
✔ Given a feature in stable mode # features/step_definitions/production-mode-skill.steps.js:499
|
|
1254
|
-
✔ And the production standards file exists with valid JSON # features/step_definitions/production-mode-skill.steps.js:556
|
|
1255
|
-
✔ But the standards array is missing required fields # features/step_definitions/production-mode-skill.steps.js:564
|
|
1256
|
-
✔ When I start the production-mode skill for this feature # features/step_definitions/production-mode-skill.steps.js:274
|
|
1257
|
-
✖ Then it fails with error "Invalid standards format" # features/step_definitions/production-mode-skill.steps.js:734
|
|
1258
|
-
AssertionError [ERR_ASSERTION]: Should error about format
|
|
1259
|
-
+ expected - actual
|
|
1260
|
-
|
|
1261
|
-
-false
|
|
1262
|
-
+true
|
|
1263
|
-
|
|
1264
|
-
at /Users/erikspangenberg/projects/jettypod-source/features/step_definitions/production-mode-skill.steps.js:748:14
|
|
1265
|
-
- And it specifies which required fields are missing # features/step_definitions/production-mode-skill.steps.js:779
|
|
1266
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1267
|
-
|
|
1268
|
-
6) Scenario: File permission error reading standards # features/production-mode-skill.feature:93
|
|
1269
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1270
|
-
✔ Given a feature in stable mode # features/step_definitions/production-mode-skill.steps.js:499
|
|
1271
|
-
? And the production standards file exists
|
|
1272
|
-
Undefined. Implement with the following snippet:
|
|
1273
|
-
|
|
1274
|
-
Given('the production standards file exists', function () {
|
|
1275
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1276
|
-
return 'pending';
|
|
1277
|
-
});
|
|
1278
|
-
|
|
1279
|
-
- But the file is not readable due to permissions # features/step_definitions/production-mode-skill.steps.js:649
|
|
1280
|
-
- When I start the production-mode skill for this feature # features/step_definitions/production-mode-skill.steps.js:274
|
|
1281
|
-
- Then it fails with error indicating permission denied # features/step_definitions/production-mode-skill.steps.js:804
|
|
1282
|
-
- And it shows the file path with permission issues # features/step_definitions/production-mode-skill.steps.js:813
|
|
1283
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1284
|
-
|
|
1285
|
-
7) Scenario: File permission error writing scenarios # features/production-mode-skill.feature:101
|
|
1286
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1287
|
-
✖ Given a feature in Scenario C (generating scenarios) # features/step_definitions/production-mode-skill.steps.js:657
|
|
1288
|
-
TypeError: this.runStep is not a function
|
|
1289
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/production-mode-skill.steps.js:658:14)
|
|
1290
|
-
- And production standards are loaded successfully # features/step_definitions/production-mode-skill.steps.js:663
|
|
1291
|
-
- But the scenario file is not writable due to permissions # features/step_definitions/production-mode-skill.steps.js:669
|
|
1292
|
-
- When attempting to append scenarios to the file # features/step_definitions/production-mode-skill.steps.js:725
|
|
1293
|
-
- Then it fails with error indicating write permission denied # features/step_definitions/production-mode-skill.steps.js:822
|
|
1294
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1295
|
-
|
|
1296
|
-
8) Scenario: Database connection error # features/production-mode-skill.feature:115
|
|
1297
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1298
|
-
✔ Given the database file is locked or corrupted # features/step_definitions/production-mode-skill.steps.js:685
|
|
1299
|
-
? When I start the production-mode skill
|
|
1300
|
-
Undefined. Implement with the following snippet:
|
|
1301
|
-
|
|
1302
|
-
When('I start the production-mode skill', function () {
|
|
1303
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1304
|
-
return 'pending';
|
|
1305
|
-
});
|
|
1306
|
-
|
|
1307
|
-
- Then it fails with database error # features/step_definitions/production-mode-skill.steps.js:840
|
|
1308
|
-
- And it suggests checking database integrity # features/step_definitions/production-mode-skill.steps.js:852
|
|
1309
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1310
|
-
|
|
1311
|
-
9) Scenario: User transitions project to external state # features/simplify-external-transition.feature:9
|
|
1312
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1313
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1314
|
-
✔ And I have some features in stable mode with production chores already created # features/step_definitions/simplify-external-transition.steps.js:31
|
|
1315
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1316
|
-
✖ Then the project_state should be updated to "external" # features/step_definitions/simplify-external-transition.steps.js:67
|
|
1317
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1318
|
-
+ actual - expected
|
|
1319
|
-
|
|
1320
|
-
+ 'internal'
|
|
1321
|
-
- 'external'
|
|
1322
|
-
|
|
1323
|
-
+ expected - actual
|
|
1324
|
-
|
|
1325
|
-
-internal
|
|
1326
|
-
+external
|
|
1327
|
-
|
|
1328
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:70:10)
|
|
1329
|
-
- And an "Infrastructure Readiness" epic should be created # features/step_definitions/simplify-external-transition.steps.js:73
|
|
1330
|
-
- And 4 infrastructure features should be created under the epic # features/step_definitions/simplify-external-transition.steps.js:88
|
|
1331
|
-
- And 15 infrastructure chores should be created across the features # features/step_definitions/simplify-external-transition.steps.js:111
|
|
1332
|
-
- And production mode work items should now be visible in the backlog # features/step_definitions/simplify-external-transition.steps.js:126
|
|
1333
|
-
- And no duplicate production chores should be created for existing features # features/step_definitions/simplify-external-transition.steps.js:147
|
|
1334
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1335
|
-
|
|
1336
|
-
10) Scenario: Project already in external state # features/simplify-external-transition.feature:23
|
|
1337
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1338
|
-
✔ Given I have a JettyPod project in external state # features/step_definitions/simplify-external-transition.steps.js:165
|
|
1339
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1340
|
-
✖ Then I should see a message "Project already in external state" # features/step_definitions/simplify-external-transition.steps.js:225
|
|
1341
|
-
AssertionError [ERR_ASSERTION]: Should have output
|
|
1342
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:226:10)
|
|
1343
|
-
- And no duplicate infrastructure items should be created # features/step_definitions/simplify-external-transition.steps.js:230
|
|
1344
|
-
- And the command should exit successfully # features/step_definitions/simplify-external-transition.steps.js:245
|
|
1345
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1346
|
-
|
|
1347
|
-
11) Scenario: Infrastructure epic already exists # features/simplify-external-transition.feature:30
|
|
1348
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1349
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1350
|
-
✔ And an "Infrastructure Readiness" epic already exists # features/step_definitions/simplify-external-transition.steps.js:189
|
|
1351
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1352
|
-
✖ Then the project_state should be updated to "external" # features/step_definitions/simplify-external-transition.steps.js:67
|
|
1353
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1354
|
-
+ actual - expected
|
|
1355
|
-
|
|
1356
|
-
+ 'internal'
|
|
1357
|
-
- 'external'
|
|
1358
|
-
|
|
1359
|
-
+ expected - actual
|
|
1360
|
-
|
|
1361
|
-
-internal
|
|
1362
|
-
+external
|
|
1363
|
-
|
|
1364
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:70:10)
|
|
1365
|
-
- And no duplicate "Infrastructure Readiness" epic should be created # features/step_definitions/simplify-external-transition.steps.js:249
|
|
1366
|
-
- And existing infrastructure items should be preserved # features/step_definitions/simplify-external-transition.steps.js:263
|
|
1367
|
-
- And I should see a message about existing infrastructure # features/step_definitions/simplify-external-transition.steps.js:281
|
|
1368
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1369
|
-
|
|
1370
|
-
12) Scenario: Database connection fails during transition # features/simplify-external-transition.feature:39
|
|
1371
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1372
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1373
|
-
✔ And the database connection will fail # features/step_definitions/simplify-external-transition.steps.js:206
|
|
1374
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1375
|
-
✖ Then I should see a clear error message about database failure # features/step_definitions/simplify-external-transition.steps.js:289
|
|
1376
|
-
TypeError: Cannot read properties of undefined (reading 'includes')
|
|
1377
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:290:39)
|
|
1378
|
-
- And the project_state should remain "internal" # features/step_definitions/simplify-external-transition.steps.js:298
|
|
1379
|
-
- And no partial infrastructure items should be created # features/step_definitions/simplify-external-transition.steps.js:304
|
|
1380
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1381
|
-
|
|
1382
|
-
13) Scenario: Work item creation fails mid-transition # features/simplify-external-transition.feature:47
|
|
1383
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1384
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1385
|
-
✔ And work item creation will fail after creating the epic # features/step_definitions/simplify-external-transition.steps.js:215
|
|
1386
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1387
|
-
✖ Then I should see an error message about failed creation # features/step_definitions/simplify-external-transition.steps.js:318
|
|
1388
|
-
TypeError: Cannot read properties of undefined (reading 'includes')
|
|
1389
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:319:39)
|
|
1390
|
-
- And the project_state should remain "internal" # features/step_definitions/simplify-external-transition.steps.js:298
|
|
1391
|
-
- And any partial work items should be cleaned up # features/step_definitions/simplify-external-transition.steps.js:327
|
|
1392
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1393
|
-
|
|
1394
|
-
14) Scenario: Invalid checklist data structure # features/simplify-external-transition.feature:55
|
|
1395
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1396
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1397
|
-
✔ And the infrastructure checklist has invalid data # features/step_definitions/simplify-external-transition.steps.js:220
|
|
1398
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1399
|
-
✖ Then I should see a validation error message # features/step_definitions/simplify-external-transition.steps.js:342
|
|
1400
|
-
TypeError: Cannot read properties of undefined (reading 'includes')
|
|
1401
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/step_definitions/simplify-external-transition.steps.js:343:39)
|
|
1402
|
-
- And the project_state should remain "internal" # features/step_definitions/simplify-external-transition.steps.js:298
|
|
1403
|
-
- And no infrastructure items should be created # features/step_definitions/simplify-external-transition.steps.js:351
|
|
1404
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1405
|
-
|
|
1406
|
-
15) Scenario: Infrastructure chores generated from production standards # features/simplify-external-transition.feature:63
|
|
1407
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1408
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1409
|
-
? And I have production standards with infrastructure-scoped standards
|
|
1410
|
-
Undefined. Implement with the following snippet:
|
|
1411
|
-
|
|
1412
|
-
Given('I have production standards with infrastructure-scoped standards', function () {
|
|
1413
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1414
|
-
return 'pending';
|
|
1415
|
-
});
|
|
1416
|
-
|
|
1417
|
-
? And the standards include "database_backups" in infrastructure scope
|
|
1418
|
-
Undefined. Implement with the following snippet:
|
|
1419
|
-
|
|
1420
|
-
Given('the standards include {string} in infrastructure scope', function (string) {
|
|
1421
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1422
|
-
return 'pending';
|
|
1423
|
-
});
|
|
1424
|
-
|
|
1425
|
-
? And the standards include "monitoring_setup" in infrastructure scope
|
|
1426
|
-
Undefined. Implement with the following snippet:
|
|
1427
|
-
|
|
1428
|
-
Given('the standards include {string} in infrastructure scope', function (string) {
|
|
1429
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1430
|
-
return 'pending';
|
|
1431
|
-
});
|
|
1432
|
-
|
|
1433
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1434
|
-
? Then infrastructure chores should be created from standards
|
|
1435
|
-
Undefined. Implement with the following snippet:
|
|
1436
|
-
|
|
1437
|
-
Then('infrastructure chores should be created from standards', function () {
|
|
1438
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1439
|
-
return 'pending';
|
|
1440
|
-
});
|
|
1441
|
-
|
|
1442
|
-
? And each infrastructure standard should create one chore
|
|
1443
|
-
Undefined. Implement with the following snippet:
|
|
1444
|
-
|
|
1445
|
-
Then('each infrastructure standard should create one chore', function () {
|
|
1446
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1447
|
-
return 'pending';
|
|
1448
|
-
});
|
|
1449
|
-
|
|
1450
|
-
? And chore descriptions should include acceptance criteria from standards
|
|
1451
|
-
Undefined. Implement with the following snippet:
|
|
1452
|
-
|
|
1453
|
-
Then('chore descriptions should include acceptance criteria from standards', function () {
|
|
1454
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1455
|
-
return 'pending';
|
|
1456
|
-
});
|
|
1457
|
-
|
|
1458
|
-
? And chore descriptions should include reasoning from standards
|
|
1459
|
-
Undefined. Implement with the following snippet:
|
|
1460
|
-
|
|
1461
|
-
Then('chore descriptions should include reasoning from standards', function () {
|
|
1462
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1463
|
-
return 'pending';
|
|
1464
|
-
});
|
|
1465
|
-
|
|
1466
|
-
? And no static checklist should be used
|
|
1467
|
-
Undefined. Implement with the following snippet:
|
|
1468
|
-
|
|
1469
|
-
Then('no static checklist should be used', function () {
|
|
1470
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1471
|
-
return 'pending';
|
|
1472
|
-
});
|
|
1473
|
-
|
|
1474
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1475
|
-
|
|
1476
|
-
16) Scenario: Different presets create different infrastructure chores # features/simplify-external-transition.feature:75
|
|
1477
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1478
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1479
|
-
? And production standards are set to "startup-mvp" preset
|
|
1480
|
-
Undefined. Implement with the following snippet:
|
|
1481
|
-
|
|
1482
|
-
Given('production standards are set to {string} preset', function (string) {
|
|
1483
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1484
|
-
return 'pending';
|
|
1485
|
-
});
|
|
1486
|
-
|
|
1487
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1488
|
-
? Then infrastructure chores should match startup-mvp standards
|
|
1489
|
-
Undefined. Implement with the following snippet:
|
|
1490
|
-
|
|
1491
|
-
Then('infrastructure chores should match startup-mvp standards', function () {
|
|
1492
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1493
|
-
return 'pending';
|
|
1494
|
-
});
|
|
1495
|
-
|
|
1496
|
-
? And I should see fewer infrastructure chores than enterprise preset
|
|
1497
|
-
Undefined. Implement with the following snippet:
|
|
1498
|
-
|
|
1499
|
-
Then('I should see fewer infrastructure chores than enterprise preset', function () {
|
|
1500
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1501
|
-
return 'pending';
|
|
1502
|
-
});
|
|
1503
|
-
|
|
1504
|
-
? When I change production standards to "enterprise" preset
|
|
1505
|
-
Undefined. Implement with the following snippet:
|
|
1506
|
-
|
|
1507
|
-
When('I change production standards to {string} preset', function (string) {
|
|
1508
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1509
|
-
return 'pending';
|
|
1510
|
-
});
|
|
1511
|
-
|
|
1512
|
-
? And I run "jettypod project external" on a new project
|
|
1513
|
-
Undefined. Implement with the following snippet:
|
|
1514
|
-
|
|
1515
|
-
When('I run {string} on a new project', function (string) {
|
|
1516
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1517
|
-
return 'pending';
|
|
1518
|
-
});
|
|
1519
|
-
|
|
1520
|
-
? Then infrastructure chores should match enterprise standards
|
|
1521
|
-
Undefined. Implement with the following snippet:
|
|
1522
|
-
|
|
1523
|
-
Then('infrastructure chores should match enterprise standards', function () {
|
|
1524
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1525
|
-
return 'pending';
|
|
1526
|
-
});
|
|
1527
|
-
|
|
1528
|
-
? And I should see more infrastructure chores than startup-mvp preset
|
|
1529
|
-
Undefined. Implement with the following snippet:
|
|
1530
|
-
|
|
1531
|
-
Then('I should see more infrastructure chores than startup-mvp preset', function () {
|
|
1532
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1533
|
-
return 'pending';
|
|
1534
|
-
});
|
|
1535
|
-
|
|
1536
|
-
? And additional chores should include multi-region setup
|
|
1537
|
-
Undefined. Implement with the following snippet:
|
|
1538
|
-
|
|
1539
|
-
Then('additional chores should include multi-region setup', function () {
|
|
1540
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1541
|
-
return 'pending';
|
|
1542
|
-
});
|
|
1543
|
-
|
|
1544
|
-
? And additional chores should include advanced monitoring
|
|
1545
|
-
Undefined. Implement with the following snippet:
|
|
1546
|
-
|
|
1547
|
-
Then('additional chores should include advanced monitoring', function () {
|
|
1548
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1549
|
-
return 'pending';
|
|
1550
|
-
});
|
|
1551
|
-
|
|
1552
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1553
|
-
|
|
1554
|
-
17) Scenario: Scope field correctly filters infrastructure vs feature standards # features/simplify-external-transition.feature:89
|
|
1555
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1556
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1557
|
-
? And production standards include 5 infrastructure-scoped standards
|
|
1558
|
-
Undefined. Implement with the following snippet:
|
|
1559
|
-
|
|
1560
|
-
Given('production standards include {int} infrastructure-scoped standards', function (int) {
|
|
1561
|
-
// Given('production standards include {float} infrastructure-scoped standards', function (float) {
|
|
1562
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1563
|
-
return 'pending';
|
|
1564
|
-
});
|
|
1565
|
-
|
|
1566
|
-
? And production standards include 8 feature-scoped standards
|
|
1567
|
-
Undefined. Implement with the following snippet:
|
|
1568
|
-
|
|
1569
|
-
Given('production standards include {int} feature-scoped standards', function (int) {
|
|
1570
|
-
// Given('production standards include {float} feature-scoped standards', function (float) {
|
|
1571
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1572
|
-
return 'pending';
|
|
1573
|
-
});
|
|
1574
|
-
|
|
1575
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1576
|
-
? Then exactly 5 infrastructure chores should be created
|
|
1577
|
-
Undefined. Implement with the following snippet:
|
|
1578
|
-
|
|
1579
|
-
Then('exactly {int} infrastructure chores should be created', function (int) {
|
|
1580
|
-
// Then('exactly {float} infrastructure chores should be created', function (float) {
|
|
1581
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1582
|
-
return 'pending';
|
|
1583
|
-
});
|
|
1584
|
-
|
|
1585
|
-
? And no feature-scoped standards should create infrastructure chores
|
|
1586
|
-
Undefined. Implement with the following snippet:
|
|
1587
|
-
|
|
1588
|
-
Then('no feature-scoped standards should create infrastructure chores', function () {
|
|
1589
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1590
|
-
return 'pending';
|
|
1591
|
-
});
|
|
1592
|
-
|
|
1593
|
-
? And feature-scoped standards should be reserved for feature production chores
|
|
1594
|
-
Undefined. Implement with the following snippet:
|
|
1595
|
-
|
|
1596
|
-
Then('feature-scoped standards should be reserved for feature production chores', function () {
|
|
1597
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1598
|
-
return 'pending';
|
|
1599
|
-
});
|
|
1600
|
-
|
|
1601
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1602
|
-
|
|
1603
|
-
18) Scenario: Infrastructure chore created per standard (not grouped by domain) # features/simplify-external-transition.feature:98
|
|
1604
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1605
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1606
|
-
? And production standards include 3 security infrastructure standards
|
|
1607
|
-
Undefined. Implement with the following snippet:
|
|
1608
|
-
|
|
1609
|
-
Given('production standards include {int} security infrastructure standards', function (int) {
|
|
1610
|
-
// Given('production standards include {float} security infrastructure standards', function (float) {
|
|
1611
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1612
|
-
return 'pending';
|
|
1613
|
-
});
|
|
1614
|
-
|
|
1615
|
-
? And production standards include 2 monitoring infrastructure standards
|
|
1616
|
-
Undefined. Implement with the following snippet:
|
|
1617
|
-
|
|
1618
|
-
Given('production standards include {int} monitoring infrastructure standards', function (int) {
|
|
1619
|
-
// Given('production standards include {float} monitoring infrastructure standards', function (float) {
|
|
1620
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1621
|
-
return 'pending';
|
|
1622
|
-
});
|
|
1623
|
-
|
|
1624
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1625
|
-
? Then 5 separate infrastructure chores should be created
|
|
1626
|
-
Undefined. Implement with the following snippet:
|
|
1627
|
-
|
|
1628
|
-
Then('{int} separate infrastructure chores should be created', function (int) {
|
|
1629
|
-
// Then('{float} separate infrastructure chores should be created', function (float) {
|
|
1630
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1631
|
-
return 'pending';
|
|
1632
|
-
});
|
|
1633
|
-
|
|
1634
|
-
? And each chore should reference exactly one standard
|
|
1635
|
-
Undefined. Implement with the following snippet:
|
|
1636
|
-
|
|
1637
|
-
Then('each chore should reference exactly one standard', function () {
|
|
1638
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1639
|
-
return 'pending';
|
|
1640
|
-
});
|
|
1641
|
-
|
|
1642
|
-
? And chores should not be grouped by domain
|
|
1643
|
-
Undefined. Implement with the following snippet:
|
|
1644
|
-
|
|
1645
|
-
Then('chores should not be grouped by domain', function () {
|
|
1646
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1647
|
-
return 'pending';
|
|
1648
|
-
});
|
|
1649
|
-
|
|
1650
|
-
? And each chore title should describe the specific standard
|
|
1651
|
-
Undefined. Implement with the following snippet:
|
|
1652
|
-
|
|
1653
|
-
Then('each chore title should describe the specific standard', function () {
|
|
1654
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1655
|
-
return 'pending';
|
|
1656
|
-
});
|
|
1657
|
-
|
|
1658
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1659
|
-
|
|
1660
|
-
19) Scenario: Missing production standards file during transition # features/simplify-external-transition.feature:108
|
|
1661
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1662
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1663
|
-
? And no production standards file exists
|
|
1664
|
-
Undefined. Implement with the following snippet:
|
|
1665
|
-
|
|
1666
|
-
Given('no production standards file exists', function () {
|
|
1667
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1668
|
-
return 'pending';
|
|
1669
|
-
});
|
|
1670
|
-
|
|
1671
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1672
|
-
? Then I should see an error "Production standards file not found"
|
|
1673
|
-
Undefined. Implement with the following snippet:
|
|
1674
|
-
|
|
1675
|
-
Then('I should see an error {string}', function (string) {
|
|
1676
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1677
|
-
return 'pending';
|
|
1678
|
-
});
|
|
1679
|
-
|
|
1680
|
-
? And I should be prompted to run external transition interactively
|
|
1681
|
-
Undefined. Implement with the following snippet:
|
|
1682
|
-
|
|
1683
|
-
Then('I should be prompted to run external transition interactively', function () {
|
|
1684
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1685
|
-
return 'pending';
|
|
1686
|
-
});
|
|
1687
|
-
|
|
1688
|
-
- And the project_state should remain "internal" # features/step_definitions/simplify-external-transition.steps.js:298
|
|
1689
|
-
- And no infrastructure items should be created # features/step_definitions/simplify-external-transition.steps.js:351
|
|
1690
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1691
|
-
|
|
1692
|
-
20) Scenario: Infrastructure chores include pattern guidance from standards # features/simplify-external-transition.feature:117
|
|
1693
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1694
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1695
|
-
? And production standards include a standard with pattern guidance
|
|
1696
|
-
Undefined. Implement with the following snippet:
|
|
1697
|
-
|
|
1698
|
-
Given('production standards include a standard with pattern guidance', function () {
|
|
1699
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1700
|
-
return 'pending';
|
|
1701
|
-
});
|
|
1702
|
-
|
|
1703
|
-
? And the standard has pattern "Use pg_dump with --clean flag"
|
|
1704
|
-
Undefined. Implement with the following snippet:
|
|
1705
|
-
|
|
1706
|
-
Given('the standard has pattern {string}', function (string) {
|
|
1707
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1708
|
-
return 'pending';
|
|
1709
|
-
});
|
|
1710
|
-
|
|
1711
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1712
|
-
? Then the created chore should include the pattern in description
|
|
1713
|
-
Undefined. Implement with the following snippet:
|
|
1714
|
-
|
|
1715
|
-
Then('the created chore should include the pattern in description', function () {
|
|
1716
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1717
|
-
return 'pending';
|
|
1718
|
-
});
|
|
1719
|
-
|
|
1720
|
-
? And the pattern should be labeled "Pattern:" in the description
|
|
1721
|
-
Undefined. Implement with the following snippet:
|
|
1722
|
-
|
|
1723
|
-
Then('the pattern should be labeled {string} in the description', function (string) {
|
|
1724
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1725
|
-
return 'pending';
|
|
1726
|
-
});
|
|
1727
|
-
|
|
1728
|
-
? And developers should have clear implementation guidance
|
|
1729
|
-
Undefined. Implement with the following snippet:
|
|
1730
|
-
|
|
1731
|
-
Then('developers should have clear implementation guidance', function () {
|
|
1732
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1733
|
-
return 'pending';
|
|
1734
|
-
});
|
|
1735
|
-
|
|
1736
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1737
|
-
|
|
1738
|
-
21) Scenario: Audit logging for external transition # features/simplify-external-transition.feature:128
|
|
1739
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1740
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1741
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1742
|
-
? Then an audit log entry should be created
|
|
1743
|
-
Undefined. Implement with the following snippet:
|
|
1744
|
-
|
|
1745
|
-
Then('an audit log entry should be created', function () {
|
|
1746
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1747
|
-
return 'pending';
|
|
1748
|
-
});
|
|
1749
|
-
|
|
1750
|
-
? And the log should include timestamp, user, and project details
|
|
1751
|
-
Undefined. Implement with the following snippet:
|
|
1752
|
-
|
|
1753
|
-
Then('the log should include timestamp, user, and project details', function () {
|
|
1754
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1755
|
-
return 'pending';
|
|
1756
|
-
});
|
|
1757
|
-
|
|
1758
|
-
? And the log should record the state change from "internal" to "external"
|
|
1759
|
-
Undefined. Implement with the following snippet:
|
|
1760
|
-
|
|
1761
|
-
Then('the log should record the state change from {string} to {string}', function (string, string2) {
|
|
1762
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1763
|
-
return 'pending';
|
|
1764
|
-
});
|
|
1765
|
-
|
|
1766
|
-
? And the log should include the infrastructure epic ID created
|
|
1767
|
-
Undefined. Implement with the following snippet:
|
|
1768
|
-
|
|
1769
|
-
Then('the log should include the infrastructure epic ID created', function () {
|
|
1770
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1771
|
-
return 'pending';
|
|
1772
|
-
});
|
|
1773
|
-
|
|
1774
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1775
|
-
|
|
1776
|
-
22) Scenario: Performance with large projects (1000+ work items) # features/simplify-external-transition.feature:136
|
|
1777
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1778
|
-
? Given I have a JettyPod project with 1000 work items
|
|
1779
|
-
Undefined. Implement with the following snippet:
|
|
1780
|
-
|
|
1781
|
-
Given('I have a JettyPod project with {int} work items', function (int) {
|
|
1782
|
-
// Given('I have a JettyPod project with {float} work items', function (float) {
|
|
1783
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1784
|
-
return 'pending';
|
|
1785
|
-
});
|
|
1786
|
-
|
|
1787
|
-
? And the project is in internal state
|
|
1788
|
-
Undefined. Implement with the following snippet:
|
|
1789
|
-
|
|
1790
|
-
Given('the project is in internal state', function () {
|
|
1791
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1792
|
-
return 'pending';
|
|
1793
|
-
});
|
|
1794
|
-
|
|
1795
|
-
- When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1796
|
-
? Then the transition should complete in under 5 seconds
|
|
1797
|
-
Undefined. Implement with the following snippet:
|
|
1798
|
-
|
|
1799
|
-
Then('the transition should complete in under {int} seconds', function (int) {
|
|
1800
|
-
// Then('the transition should complete in under {float} seconds', function (float) {
|
|
1801
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1802
|
-
return 'pending';
|
|
1803
|
-
});
|
|
1804
|
-
|
|
1805
|
-
? And memory usage should remain under 100MB
|
|
1806
|
-
Undefined. Implement with the following snippet:
|
|
1807
|
-
|
|
1808
|
-
Then('memory usage should remain under 100MB', function () {
|
|
1809
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1810
|
-
return 'pending';
|
|
1811
|
-
});
|
|
1812
|
-
|
|
1813
|
-
? And all infrastructure items should be created successfully
|
|
1814
|
-
Undefined. Implement with the following snippet:
|
|
1815
|
-
|
|
1816
|
-
Then('all infrastructure items should be created successfully', function () {
|
|
1817
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1818
|
-
return 'pending';
|
|
1819
|
-
});
|
|
1820
|
-
|
|
1821
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1822
|
-
|
|
1823
|
-
23) Scenario: Concurrent transition attempts are prevented # features/simplify-external-transition.feature:144
|
|
1824
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1825
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1826
|
-
? When I start "jettypod project external" in one process
|
|
1827
|
-
Undefined. Implement with the following snippet:
|
|
1828
|
-
|
|
1829
|
-
When('I start {string} in one process', function (string) {
|
|
1830
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1831
|
-
return 'pending';
|
|
1832
|
-
});
|
|
1833
|
-
|
|
1834
|
-
? And I attempt "jettypod project external" in another process
|
|
1835
|
-
Undefined. Implement with the following snippet:
|
|
1836
|
-
|
|
1837
|
-
When('I attempt {string} in another process', function (string) {
|
|
1838
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1839
|
-
return 'pending';
|
|
1840
|
-
});
|
|
1841
|
-
|
|
1842
|
-
? Then the second attempt should be blocked
|
|
1843
|
-
Undefined. Implement with the following snippet:
|
|
1844
|
-
|
|
1845
|
-
Then('the second attempt should be blocked', function () {
|
|
1846
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1847
|
-
return 'pending';
|
|
1848
|
-
});
|
|
1849
|
-
|
|
1850
|
-
? And I should see "Transition already in progress"
|
|
1851
|
-
Undefined. Implement with the following snippet:
|
|
1852
|
-
|
|
1853
|
-
Then('I should see {string}', function (string) {
|
|
1854
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1855
|
-
return 'pending';
|
|
1856
|
-
});
|
|
1857
|
-
|
|
1858
|
-
? And only one infrastructure epic should be created
|
|
1859
|
-
Undefined. Implement with the following snippet:
|
|
1860
|
-
|
|
1861
|
-
Then('only one infrastructure epic should be created', function () {
|
|
1862
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1863
|
-
return 'pending';
|
|
1864
|
-
});
|
|
1865
|
-
|
|
1866
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1867
|
-
|
|
1868
|
-
24) Scenario: State transition is recorded for compliance # features/simplify-external-transition.feature:152
|
|
1869
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1870
|
-
✔ Given I have a JettyPod project in internal state # features/step_definitions/simplify-external-transition.steps.js:10
|
|
1871
|
-
✔ When I run "jettypod project external" # features/work-commands/steps.js:186
|
|
1872
|
-
? Then a state transition record should be created
|
|
1873
|
-
Undefined. Implement with the following snippet:
|
|
1874
|
-
|
|
1875
|
-
Then('a state transition record should be created', function () {
|
|
1876
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1877
|
-
return 'pending';
|
|
1878
|
-
});
|
|
1879
|
-
|
|
1880
|
-
? And the record should include "from: internal, to: external"
|
|
1881
|
-
Undefined. Implement with the following snippet:
|
|
1882
|
-
|
|
1883
|
-
Then('the record should include {string}', function (string) {
|
|
1884
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1885
|
-
return 'pending';
|
|
1886
|
-
});
|
|
1887
|
-
|
|
1888
|
-
? And the record should include a timestamp
|
|
1889
|
-
Undefined. Implement with the following snippet:
|
|
1890
|
-
|
|
1891
|
-
Then('the record should include a timestamp', function () {
|
|
1892
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1893
|
-
return 'pending';
|
|
1894
|
-
});
|
|
1895
|
-
|
|
1896
|
-
? And the record should be immutable
|
|
1897
|
-
Undefined. Implement with the following snippet:
|
|
1898
|
-
|
|
1899
|
-
Then('the record should be immutable', function () {
|
|
1900
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1901
|
-
return 'pending';
|
|
1902
|
-
});
|
|
1903
|
-
|
|
1904
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1905
|
-
|
|
1906
|
-
25) Scenario: Infrastructure creation is idempotent # features/simplify-external-transition.feature:160
|
|
1907
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1908
|
-
✔ Given I have a JettyPod project in external state # features/step_definitions/simplify-external-transition.steps.js:165
|
|
1909
|
-
? And an "Infrastructure Readiness" epic exists
|
|
1910
|
-
Undefined. Implement with the following snippet:
|
|
1911
|
-
|
|
1912
|
-
Given('an {string} epic exists', function (string) {
|
|
1913
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1914
|
-
return 'pending';
|
|
1915
|
-
});
|
|
1916
|
-
|
|
1917
|
-
? When I run "jettypod project external" again
|
|
1918
|
-
Undefined. Implement with the following snippet:
|
|
1919
|
-
|
|
1920
|
-
When('I run {string} again', function (string) {
|
|
1921
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1922
|
-
return 'pending';
|
|
1923
|
-
});
|
|
1924
|
-
|
|
1925
|
-
- Then no duplicate infrastructure items should be created # features/step_definitions/simplify-external-transition.steps.js:230
|
|
1926
|
-
? And the existing epic ID should be preserved
|
|
1927
|
-
Undefined. Implement with the following snippet:
|
|
1928
|
-
|
|
1929
|
-
Then('the existing epic ID should be preserved', function () {
|
|
1930
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1931
|
-
return 'pending';
|
|
1932
|
-
});
|
|
1933
|
-
|
|
1934
|
-
? And I should see "Infrastructure already configured"
|
|
1935
|
-
Undefined. Implement with the following snippet:
|
|
1936
|
-
|
|
1937
|
-
Then('I should see {string}', function (string) {
|
|
1938
|
-
// Write code here that turns the phrase above into concrete actions
|
|
1939
|
-
return 'pending';
|
|
1940
|
-
});
|
|
1941
|
-
|
|
1942
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1943
|
-
|
|
1944
|
-
26) Scenario: Create feature without mode defaults to discovery # features/work-tracking/mode-required.feature:26
|
|
1945
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1946
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
1947
|
-
✔ When I create a feature "Test Feature" without mode # features/work-commands/steps.js:527
|
|
1948
|
-
✔ Then the work item is created successfully # features/work-commands/steps.js:568
|
|
1949
|
-
✖ And the work item has mode "discovery" # features/work-commands/steps.js:573
|
|
1950
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1951
|
-
+ actual - expected
|
|
1952
|
-
|
|
1953
|
-
+ null
|
|
1954
|
-
- 'discovery'
|
|
1955
|
-
|
|
1956
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:14)
|
|
1957
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1958
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1959
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1960
|
-
|
|
1961
|
-
27) Scenario: Create bug with explicit mode # features/work-tracking/mode-required.feature:39
|
|
1962
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1963
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
1964
|
-
✔ When I create a bug "Test Bug" with mode "stable" # features/work-commands/steps.js:636
|
|
1965
|
-
✔ Then the work item is created successfully # features/work-commands/steps.js:568
|
|
1966
|
-
✖ And the work item has mode "stable" # features/work-commands/steps.js:573
|
|
1967
|
-
TypeError: Cannot read properties of undefined (reading 'mode')
|
|
1968
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:30)
|
|
1969
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1970
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1971
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1972
|
-
|
|
1973
|
-
28) Scenario: Create bug without mode defaults to discovery # features/work-tracking/mode-required.feature:45
|
|
1974
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1975
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
1976
|
-
✔ When I create a bug "Test Bug" without mode # features/work-commands/steps.js:655
|
|
1977
|
-
✔ Then the work item is created successfully # features/work-commands/steps.js:568
|
|
1978
|
-
✖ And the work item has mode "discovery" # features/work-commands/steps.js:573
|
|
1979
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
1980
|
-
+ actual - expected
|
|
1981
|
-
|
|
1982
|
-
+ null
|
|
1983
|
-
- 'discovery'
|
|
1984
|
-
|
|
1985
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:14)
|
|
1986
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1987
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1988
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
1989
|
-
|
|
1990
|
-
29) Scenario: Create feature with all valid modes # features/work-tracking/mode-required.feature:74
|
|
1991
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
1992
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
1993
|
-
✔ When I create a feature "Test Feature" with mode "discovery" # features/work-commands/steps.js:506
|
|
1994
|
-
✔ Then the work item is created successfully # features/work-commands/steps.js:568
|
|
1995
|
-
✖ And the work item has mode "discovery" # features/work-commands/steps.js:573
|
|
1996
|
-
TypeError: Cannot read properties of undefined (reading 'mode')
|
|
1997
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:30)
|
|
1998
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
1999
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2000
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2001
|
-
|
|
2002
|
-
30) Scenario: Epic with children in different modes # features/work-tracking/mode-required.feature:79
|
|
2003
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2004
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2005
|
-
✔ And I create an epic "Test Epic" without mode # features/work-commands/steps.js:483
|
|
2006
|
-
✔ And I create a feature "Speed Feature" with mode "speed" and parent epic # features/work-commands/steps.js:607
|
|
2007
|
-
✖ And I create a bug "Stable Bug" with mode "stable" and parent epic # features/work-commands/steps.js:738
|
|
2008
|
-
Error: Command failed: node /Users/erikspangenberg/projects/jettypod-source/jettypod.js work create bug "Stable Bug" "" --mode=stable --parent=1
|
|
2009
|
-
Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
2010
|
-
|
|
2011
|
-
at genericNodeError (node:internal/errors:985:15)
|
|
2012
|
-
at wrappedFn (node:internal/errors:539:14)
|
|
2013
|
-
at checkExecSyncError (node:child_process:924:11)
|
|
2014
|
-
at execSync (node:child_process:996:15)
|
|
2015
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:739:18)
|
|
2016
|
-
- And I create a chore "Test Chore" without mode and parent epic # features/work-commands/steps.js:750
|
|
2017
|
-
- When I view the backlog # features/work-commands/steps.js:619
|
|
2018
|
-
- Then I see the epic without mode indicator # features/work-commands/steps.js:789
|
|
2019
|
-
- And I see the feature with mode "speed" # features/work-commands/steps.js:774
|
|
2020
|
-
- And I see the bug with mode "stable" # features/work-commands/steps.js:779
|
|
2021
|
-
- And I see the chore without mode indicator # features/work-commands/steps.js:796
|
|
2022
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2023
|
-
|
|
2024
|
-
31) Scenario: Set mode on non-current item does not update CLAUDE.md # features/work-tracking/work-set-mode.feature:19
|
|
2025
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2026
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2027
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2028
|
-
✔ Given I create a feature "Item 1" with mode "speed" # features/work-commands/steps.js:506
|
|
2029
|
-
✔ And I create a feature "Item 2" with mode "discovery" # features/work-commands/steps.js:506
|
|
2030
|
-
✔ And I start work on the feature "Item 1" # features/work-commands/steps.js:1064
|
|
2031
|
-
✔ And CLAUDE.md mode is set to "speed" # features/work-commands/steps.js:914
|
|
2032
|
-
✔ When I set mode for item "Item 2" to "stable" # features/work-commands/steps.js:965
|
|
2033
|
-
✖ Then item "Item 2" has mode "stable" # features/work-commands/steps.js:1035
|
|
2034
|
-
TypeError: Cannot read properties of undefined (reading 'mode')
|
|
2035
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:1040:30)
|
|
2036
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2037
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2038
|
-
- But CLAUDE.md mode is set to "speed" # features/work-commands/steps.js:914
|
|
2039
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2040
|
-
|
|
2041
|
-
32) Scenario: Change to all valid modes # features/work-tracking/work-set-mode.feature:50
|
|
2042
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2043
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2044
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2045
|
-
✔ Given I create a feature "Test Feature" with mode "speed" # features/work-commands/steps.js:506
|
|
2046
|
-
✔ And I start work on the feature # features/work-commands/steps.js:861
|
|
2047
|
-
✔ When I set mode for current item to "discovery" # features/work-commands/steps.js:951
|
|
2048
|
-
✖ Then the work item has mode "discovery" # features/work-commands/steps.js:573
|
|
2049
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
2050
|
-
+ actual - expected
|
|
2051
|
-
|
|
2052
|
-
+ 'speed'
|
|
2053
|
-
- 'discovery'
|
|
2054
|
-
|
|
2055
|
-
+ expected - actual
|
|
2056
|
-
|
|
2057
|
-
-speed
|
|
2058
|
-
+discovery
|
|
2059
|
-
|
|
2060
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:14)
|
|
2061
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2062
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2063
|
-
- And CLAUDE.md mode is set to "discovery" # features/work-commands/steps.js:914
|
|
2064
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2065
|
-
|
|
2066
|
-
33) Scenario: Start work on bug in stable mode # features/work-tracking/work-start-mode.feature:16
|
|
2067
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2068
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2069
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2070
|
-
✔ Given I create a bug "Stable Bug" with mode "stable" # features/work-commands/steps.js:636
|
|
2071
|
-
✖ When I start work on the bug # features/work-commands/steps.js:875
|
|
2072
|
-
Error: Work item #1 not found
|
|
2073
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/index.js:67:23)
|
|
2074
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2075
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2076
|
-
- Then CLAUDE.md mode is set to "stable" # features/work-commands/steps.js:914
|
|
2077
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2078
|
-
|
|
2079
|
-
34) Scenario: Start work on chore inherits parent feature mode # features/work-tracking/work-start-mode.feature:21
|
|
2080
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2081
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2082
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2083
|
-
✔ Given I create a feature "Discovery Feature" with mode "discovery" # features/work-commands/steps.js:506
|
|
2084
|
-
✔ And I create a chore "Child Chore" without mode and parent feature # features/work-commands/steps.js:762
|
|
2085
|
-
✔ When I start work on the chore # features/work-commands/steps.js:889
|
|
2086
|
-
✖ Then CLAUDE.md mode is set to "discovery" # features/work-commands/steps.js:914
|
|
2087
|
-
AssertionError [ERR_ASSERTION]: CLAUDE.md should have a Mode line
|
|
2088
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:918:3)
|
|
2089
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2090
|
-
|
|
2091
|
-
35) Scenario: Switch from speed mode item to stable mode item # features/work-tracking/work-start-mode.feature:33
|
|
2092
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2093
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2094
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2095
|
-
✔ Given I create a feature "Speed Feature" with mode "speed" # features/work-commands/steps.js:506
|
|
2096
|
-
✔ And I create a bug "Stable Bug" with mode "stable" # features/work-commands/steps.js:636
|
|
2097
|
-
✔ And I start work on the feature # features/work-commands/steps.js:861
|
|
2098
|
-
✔ And CLAUDE.md mode is set to "speed" # features/work-commands/steps.js:914
|
|
2099
|
-
✔ When I stop work # features/work-commands/steps.js:909
|
|
2100
|
-
✔ And I start work on the bug # features/work-commands/steps.js:875
|
|
2101
|
-
✖ Then CLAUDE.md mode is set to "stable" # features/work-commands/steps.js:914
|
|
2102
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
2103
|
-
|
|
2104
|
-
'speed' !== 'stable'
|
|
2105
|
-
|
|
2106
|
-
+ expected - actual
|
|
2107
|
-
|
|
2108
|
-
-speed
|
|
2109
|
-
+stable
|
|
2110
|
-
|
|
2111
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:919:10)
|
|
2112
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2113
|
-
|
|
2114
|
-
36) Scenario: Start work updates mode even if item already in progress # features/work-tracking/work-start-mode.feature:42
|
|
2115
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2116
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2117
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2118
|
-
✔ Given I create a feature "Test Feature" with mode "discovery" # features/work-commands/steps.js:506
|
|
2119
|
-
✔ And the feature status is "in_progress" # features/work-commands/steps.js:837
|
|
2120
|
-
✔ And CLAUDE.md has mode "speed" # features/work-commands/steps.js:848
|
|
2121
|
-
✖ When I start work on the feature # features/work-commands/steps.js:861
|
|
2122
|
-
Error: Work item #1 not found
|
|
2123
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/index.js:67:23)
|
|
2124
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2125
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2126
|
-
- Then CLAUDE.md mode is set to "discovery" # features/work-commands/steps.js:914
|
|
2127
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2128
|
-
|
|
2129
|
-
37) Scenario: Start work on feature with default discovery mode # features/work-tracking/work-start-mode.feature:57
|
|
2130
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2131
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2132
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2133
|
-
✔ Given I create a feature "Default Feature" without mode # features/work-commands/steps.js:527
|
|
2134
|
-
✖ And the work item has mode "discovery" # features/work-commands/steps.js:573
|
|
2135
|
-
AssertionError [ERR_ASSERTION]: Expected values to be strictly equal:
|
|
2136
|
-
+ actual - expected
|
|
2137
|
-
|
|
2138
|
-
+ null
|
|
2139
|
-
- 'discovery'
|
|
2140
|
-
|
|
2141
|
-
at Statement.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:578:14)
|
|
2142
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2143
|
-
at Statement.replacement (/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/lib/trace.js:25:27)
|
|
2144
|
-
- When I start work on the feature # features/work-commands/steps.js:861
|
|
2145
|
-
- Then CLAUDE.md mode is set to "discovery" # features/work-commands/steps.js:914
|
|
2146
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2147
|
-
|
|
2148
|
-
38) Scenario: Start work on child item inherits its own mode, not parent's # features/work-tracking/work-start-mode.feature:64
|
|
2149
|
-
✔ Before # features/claude-md-protection/steps.js:14
|
|
2150
|
-
✔ Given jettypod is initialized # features/work-commands/steps.js:294
|
|
2151
|
-
✔ And CLAUDE.md exists # features/work-commands/steps.js:824
|
|
2152
|
-
✔ Given I create an epic "Test Epic" without mode # features/work-commands/steps.js:483
|
|
2153
|
-
✔ And I create a feature "Speed Feature" with mode "speed" and parent epic # features/work-commands/steps.js:607
|
|
2154
|
-
✖ And I create a bug "Stable Bug" with mode "stable" and parent epic # features/work-commands/steps.js:738
|
|
2155
|
-
Error: Command failed: node /Users/erikspangenberg/projects/jettypod-source/jettypod.js work create bug "Stable Bug" "" --mode=stable --parent=1
|
|
2156
|
-
Error: Bugs cannot have modes. Only features have modes (speed/stable/production).
|
|
2157
|
-
|
|
2158
|
-
at genericNodeError (node:internal/errors:985:15)
|
|
2159
|
-
at wrappedFn (node:internal/errors:539:14)
|
|
2160
|
-
at checkExecSyncError (node:child_process:924:11)
|
|
2161
|
-
at execSync (node:child_process:996:15)
|
|
2162
|
-
at World.<anonymous> (/Users/erikspangenberg/projects/jettypod-source/features/work-commands/steps.js:739:18)
|
|
2163
|
-
- When I start work on the speed feature # features/work-commands/steps.js:899
|
|
2164
|
-
- Then CLAUDE.md mode is set to "speed" # features/work-commands/steps.js:914
|
|
2165
|
-
- When I stop work # features/work-commands/steps.js:909
|
|
2166
|
-
- And I start work on the stable bug # features/work-commands/steps.js:904
|
|
2167
|
-
- Then CLAUDE.md mode is set to "stable" # features/work-commands/steps.js:914
|
|
2168
|
-
✔ After # features/claude-md-protection/steps.js:18
|
|
2169
|
-
|
|
2170
|
-
123 scenarios (25 failed, 13 undefined, 85 passed)
|
|
2171
|
-
687 steps (25 failed, 61 undefined, 63 skipped, 538 passed)
|
|
2172
|
-
0m40.827s (executing steps: 0m40.515s)
|
|
2173
|
-
FATAL ERROR: Error::ThrowAsJavaScriptException napi_throw
|
|
2174
|
-
----- Native stack trace -----
|
|
2175
|
-
|
|
2176
|
-
1: 0x105ec9737 node::OnFatalError(char const*, char const*) [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2177
|
-
2: 0x105e82cda napi_fatal_error [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2178
|
-
3: 0x14537963a Napi::Error::Fatal(char const*, char const*) [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2179
|
-
4: 0x14537ca5d Napi::Error::ThrowAsJavaScriptException() const [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2180
|
-
5: 0x14537b38c bool Napi::Object::Set<Napi::Number>(Napi::Value, Napi::Number const&) const [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2181
|
-
6: 0x145390c37 node_sqlite3::Statement::CleanQueue() [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2182
|
-
7: 0x14539e49a node_sqlite3::Statement::~Statement() [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2183
|
-
8: 0x145399c1e node_sqlite3::Statement::~Statement() [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2184
|
-
9: 0x14539c882 Napi::ObjectWrap<node_sqlite3::Statement>::FinalizeCallback(napi_env__*, void*, void*) [/Users/erikspangenberg/projects/jettypod-source/node_modules/sqlite3/build/Release/node_sqlite3.node]
|
|
2185
|
-
10: 0x105e87b47 void napi_env__::CallIntoModule<void node_napi_env__::CallFinalizer<true>(void (*)(napi_env__*, void*, void*), void*, void*)::'lambda'(napi_env__*)&, void node_napi_env__::CallbackIntoModule<true, void node_napi_env__::CallFinalizer<true>(void (*)(napi_env__*, void*, void*), void*, void*)::'lambda'(napi_env__*)>(void node_napi_env__::CallFinalizer<true>(void (*)(napi_env__*, void*, void*), void*, void*)::'lambda'(napi_env__*)&&)::'lambda'(napi_env__*, v8::Local<v8::Value>)>(void node_napi_env__::CallFinalizer<true>(void (*)(napi_env__*, void*, void*), void*, void*)::'lambda'(napi_env__*)&, void node_napi_env__::CallFinalizer<true>(void (*)(napi_env__*, void*, void*), void*, void*)::'lambda'(napi_env__*)&&) [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2186
|
-
11: 0x105e82310 node_napi_env__::CallFinalizer(void (*)(napi_env__*, void*, void*), void*, void*) [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2187
|
-
12: 0x105e605aa v8impl::Reference::Finalize() [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2188
|
-
13: 0x105e820f6 node_napi_env__::DeleteMe() [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2189
|
-
14: 0x105ddac11 node::CleanupQueue::Drain() [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2190
|
-
15: 0x105e4d148 node::Environment::RunCleanup() [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2191
|
-
16: 0x105daf014 node::FreeEnvironment(node::Environment*) [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2192
|
-
17: 0x105f28656 node::NodeMainInstance::Run() [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2193
|
-
18: 0x105e7e816 node::Start(int, char**) [/Users/erikspangenberg/.nvm/versions/node/v24.5.0/bin/node]
|
|
2194
|
-
19: 0x7ff80cddf530 start [/usr/lib/dyld]
|
|
2195
|
-
sh: line 1: 52228 Abort trap: 6 npm run test:bdd
|