The parallel agent's full session, committed now that it's solo: - Grammar: flam/drag/roll ornaments (f/F d/D z/Z, per-lane orns channel) across src/engine.js, pico-cp/pico-explorer/pico-scroll app.py, pico/main.py, rust/track-format, + golden vectors / conformance (tests/, rust/track-format/tests). - Live-sync deep-sync: SysEx 0x44 SLSYNC + 0x45 LOGSYNC (docs/livesync-protocol.md, src/livesync.js). - PM_E-2 notation: web engine (pm_e-2.html, build/deploy/index/embed wiring) + Rust device port (pm-ui draw_notation rewrite + LaneView.groups, pm-kit ViewMode, uisim notesim). Verified: node tests/run.mjs 47 pass / 1 known; ./rust/run.sh green; pm-kit firmware + uisim compile. |
||
|---|---|---|
| .. | ||
| adapters | ||
| fixtures | ||
| .gitignore | ||
| README.md | ||
| run.mjs | ||
Track-format conformance tests
Golden-vector suite that pins the track ("program"/"patch") format to a single meaning and checks that both implementations agree:
- web —
src/engine.js - firmware —
pico-cp/app.py
The spec is docs/track-format.md. Any new implementation (e.g. a Rust engine) must pass the
same vectors — that is what keeps "the same groove on the device and in the browser" true.
Run
node tests/run.mjs # table of pass / known-divergence / FAIL per case
node tests/run.mjs -v # also print expected-vs-actual diffs for unexpected failures
Exit code is non-zero on any unexpected failure or round-trip (idempotency) break, so it works as a CI gate.
Layout
fixtures/track-format.json— the vectors. Each hasin(a patch),norm(expected normalized meaning, see spec §5), astatus, and optionalexpectFaillisting impls known to differ today.adapters/js_adapter.mjs— loads the realsrc/engine.jsgrammar (no copy) and normalizes.adapters/py_adapter.py— extracts the realpico-cp/app.pygrammar functions viaast(no copy) and normalizes.run.mjs— runs every vector through both adapters and reports.
Reading the result
✓ pass— implementation matches the spec for that vector.· known— a divergence/feature listed inexpectFail; expected, not a failure.✗ FAIL— an unexpected mismatch (a regression). Investigate.★ fixed— an impl listed inexpectFailnow passes; remove it fromexpectFail.
When you fix a divergence in code, delete that impl from the case's expectFail. When you
implement the new playback-flow tokens (rep / end), those cases flip to pass.