Korjattu Worker-laskentasolmun timing: odotetaan WS-yhteyden avautumista

Ongelma: start_agent_node palautui heti ennen kuin WebSocket ehti avautua.
Worker lähetti 'started' ja warmup lähti liian aikaisin → hub ei löytänyt
solmua → "Ei vapaata solmua" -virhe.

Korjaukset:
1. worker.js: kuuntelee "Yhteys Hubiin avattu" -logia Wasmista ja
   resolveaa started-Promisen vasta sen jälkeen (15s timeout)
2. worker.js: onerror + onunhandledrejection käsittelijät
3. worker.js: console.error välitetään pääsäikeelle
4. index.astro: ensureCoderNode odottaa (await) workerStarted-Promisea
   ennen warmupia ja pending-promptin lähetystä

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Jaakko Vanhala
2026-04-09 16:55:22 +03:00
parent 857afbe111
commit 0dc53dba1c
2 changed files with 74 additions and 26 deletions

View File

@@ -3678,39 +3678,44 @@ ${filesHtml}
};
const taskId = coderSize === '3b' ? 5 : 4;
// Käynnistetään node Workerissa
coderWorker.onmessage = (e) => {
if (e.data.type === 'started') {
document.getElementById('coder-status').textContent = 'Connected';
document.getElementById('coder-status').style.color = '#d29922';
coderWsReady = true;
} else if (e.data.type === 'log') {
// Workerin console.log → pääsäikeen kuuntelijat (tilaindikaattori, pipeline-stepit)
console.log(e.data.message);
} else if (e.data.type === 'error') {
console.log('[Worker] Virhe: ' + e.data.message);
}
};
// Käynnistetään node Workerissa — odotetaan WS-yhteyden avautumista
const workerStarted = new Promise((resolve) => {
coderWorker.onmessage = (e) => {
if (e.data.type === 'started') {
document.getElementById('coder-status').textContent = 'Connected';
document.getElementById('coder-status').style.color = '#d29922';
coderWsReady = true;
resolve();
} else if (e.data.type === 'log') {
console.log(e.data.message);
} else if (e.data.type === 'error') {
console.error('[Worker] ' + e.data.message);
resolve(); // Resolvataan silti jotta ei jäädä jumiin
}
};
});
coderWorker.postMessage({
type: 'start',
data: { hubUrl: wsUrl, hasWebGPU: false, deviceInfo: JSON.stringify(deviceInfo), taskId }
});
// Warmup
setTimeout(() => {
if (uiSocket && uiSocket.readyState === 1) {
uiSocket.send(JSON.stringify({
type: 'user_text',
text: '{"prompt":"warmup","max_tokens":1}',
task_type: 'qwen-coder'
}));
}
}, 500);
// Odotetaan kunnes Worker on yhdistänyt hubiin
await workerStarted;
// Warmup — nyt WS on varmasti auki
if (uiSocket && uiSocket.readyState === 1) {
uiSocket.send(JSON.stringify({
type: 'user_text',
text: '{"prompt":"warmup","max_tokens":1}',
task_type: 'qwen-coder'
}));
}
if (pendingCodePrompt) {
setTimeout(() => {
sendCodeToHub(pendingCodePrompt);
}, 2000);
}, 500);
pendingCodePrompt = null;
}
} catch(e) {