Files
sigil/test/s11-concurrent-page-in.test.ts
xiaoju e86bae8d4a refactor: migrate to Dynamic Workers — fix /run/{name} 404
Root cause: CF blocks Worker-to-Worker fetch on workers.dev (error 1042).
Gateway Worker could not proxy requests to child worker subdomains.

Fix: Replace CF API worker scripts with Dynamic Workers (LOADER binding).
- deploy() writes code to KV only, no CF API calls
- invoke() uses LOADER.get(id, fn) to execute code inline
- remove() clears KV only, no CF API delete
- Removed cf-api.ts, slot management, subdomain routing
- 67/67 tests passing, production verified

Reported-by: 小墨 🖊️ (KUMA)
小橘 🍊(NEKO Team)
2026-04-03 10:57:50 +00:00

53 lines
1.7 KiB
TypeScript

import { describe, it, expect, beforeEach } from 'vitest'
import { createMockKv, createMockLoader, MockEmbeddingService } from './setup.js'
import { WorkerPool } from '../src/backend/worker-pool.js'
import { KvStore } from '../src/kv.js'
describe('S11: 并发换入去重', () => {
let mockKv: KVNamespace
let mockLoader: ReturnType<typeof createMockLoader>
let mockEmbed: MockEmbeddingService
let pool: WorkerPool
let kv: KvStore
beforeEach(async () => {
mockKv = createMockKv()
mockLoader = createMockLoader({
invokeResponse: () => new Response('pong', { status: 200 }),
})
mockEmbed = new MockEmbeddingService()
pool = new WorkerPool(mockKv, mockLoader.loader, mockEmbed as any)
kv = new KvStore(mockKv)
// Simulate evicted capability: code in KV but not deployed
await kv.setCode('ping', "export default { fetch() { return new Response('pong') } }")
await kv.setMeta('ping', {
type: 'normal',
created_at: Date.now() - 10000,
})
await kv.setLru('ping', {
last_access: Date.now() - 10000,
access_count: 0,
deployed: false,
})
})
it('should handle concurrent page-ins without error', async () => {
const req1 = new Request('https://sigil.shazhou.workers.dev/run/ping')
const req2 = new Request('https://sigil.shazhou.workers.dev/run/ping')
// Fire concurrently
const [resp1, resp2] = await Promise.all([
pool.invoke('ping', req1),
pool.invoke('ping', req2),
])
expect(resp1.status).toBe(200)
expect(resp2.status).toBe(200)
// LOADER.get() should be called (at least once — may be called for each concurrent request)
const loaderCalls = mockLoader.loaderCalls()
expect(loaderCalls.length).toBeGreaterThanOrEqual(1)
})
})