Fix JIT compiler, CSSX browser support, double-fetch, SPA layout
JIT compiler: - Fix jit_compile_lambda: resolve `compile` via symbol lookup in env instead of embedding VmClosure in AST (CEK dispatches differently) - Register eval-defcomp/eval-defisland/eval-defmacro runtime helpers in browser kernel for bytecoded defcomp forms - Disable broken .sxbc.json path (missing arity in nested code blocks), use .sxbc text format only - Mark JIT-failed closures as sentinel to stop retrying CSSX in browser: - Add cssx.sx symlink + cssx.sxbc to browser web stack - Add flush-cssx! to orchestration.sx post-swap for SPA nav - Add cssx.sx to compile-modules.js and mcp_tree.ml bytecode lists SPA navigation: - Fix double-fetch: check e.defaultPrevented in click delegation (bind-event already handled the click) - Fix layout destruction: change nav links from outerHTML to innerHTML swap (outerHTML destroyed #main-panel when response lacked it) - Guard JS popstate handler when SX engine is booted - Rename sx-platform.js → sx-platform-2.js to bust immutable cache Playwright tests: - Add trackErrors() helper to all test specs - Add SPA DOM comparison test (SPA nav vs fresh load) - Add single-fetch + no-duplicate-elements test - Improve MCP tool output: show failure details and error messages Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
// @ts-check
|
||||
const { test, expect } = require('playwright/test');
|
||||
const { BASE_URL, waitForSxReady } = require('./helpers');
|
||||
const { BASE_URL, waitForSxReady, trackErrors } = require('./helpers');
|
||||
|
||||
const TEST_PAGE = '/sx/(etc.(philosophy.wittgenstein))';
|
||||
|
||||
@@ -137,6 +137,7 @@ test.describe('Isomorphic SSR', () => {
|
||||
});
|
||||
|
||||
test('islands hydrate and reactive signals work', async ({ page }) => {
|
||||
const t = trackErrors(page);
|
||||
await page.goto(BASE_URL + '/sx/', { waitUntil: 'domcontentloaded' });
|
||||
await waitForSxReady(page);
|
||||
|
||||
@@ -158,9 +159,11 @@ test.describe('Isomorphic SSR', () => {
|
||||
await page.waitForTimeout(300);
|
||||
const colourAfter = await reactive.evaluate(el => el.style.color);
|
||||
expect(colourAfter).not.toBe(colourBefore);
|
||||
expect(t.errors()).toEqual([]);
|
||||
});
|
||||
|
||||
test('navigation links have valid URLs (no [object Object])', async ({ page }) => {
|
||||
const t = trackErrors(page);
|
||||
await page.goto(BASE_URL + '/sx/', { waitUntil: 'domcontentloaded' });
|
||||
await waitForSxReady(page);
|
||||
|
||||
@@ -176,9 +179,11 @@ test.describe('Isomorphic SSR', () => {
|
||||
return broken;
|
||||
});
|
||||
expect(brokenLinks).toEqual([]);
|
||||
expect(t.errors()).toEqual([]);
|
||||
});
|
||||
|
||||
test('navigation preserves header island state', async ({ page }) => {
|
||||
const t = trackErrors(page);
|
||||
await page.goto(BASE_URL + '/sx/', { waitUntil: 'domcontentloaded' });
|
||||
await waitForSxReady(page);
|
||||
|
||||
@@ -199,6 +204,7 @@ test.describe('Isomorphic SSR', () => {
|
||||
// Colour should be preserved (def-store keeps signals across re-hydration)
|
||||
const colourAfter = await reactive.evaluate(el => el.style.color);
|
||||
expect(colourAfter).toBe(colourBefore);
|
||||
expect(t.errors()).toEqual([]);
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user