mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-04-10 11:23:32 +08:00
fix: sanitize SessionStart session summaries (#710)
This commit is contained in:
@@ -40,11 +40,10 @@ async function main() {
|
|||||||
log(`[SessionStart] Latest: ${latest.path}`);
|
log(`[SessionStart] Latest: ${latest.path}`);
|
||||||
|
|
||||||
// Read and inject the latest session content into Claude's context
|
// Read and inject the latest session content into Claude's context
|
||||||
const content = readFile(latest.path);
|
const content = stripAnsi(readFile(latest.path));
|
||||||
if (content && !content.includes('[Session context goes here]')) {
|
if (content && !content.includes('[Session context goes here]')) {
|
||||||
// Only inject if the session has actual content (not the blank template)
|
// Only inject if the session has actual content (not the blank template)
|
||||||
// Strip ANSI escape codes that may have leaked from terminal output (#642)
|
output(`Previous session summary:\n${content}`);
|
||||||
output(`Previous session summary:\n${stripAnsi(content)}`);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -415,6 +415,36 @@ async function runTests() {
|
|||||||
passed++;
|
passed++;
|
||||||
else failed++;
|
else failed++;
|
||||||
|
|
||||||
|
if (
|
||||||
|
await asyncTest('strips ANSI escape codes from injected session content', async () => {
|
||||||
|
const isoHome = path.join(os.tmpdir(), `ecc-ansi-start-${Date.now()}`);
|
||||||
|
const sessionsDir = path.join(isoHome, '.claude', 'sessions');
|
||||||
|
fs.mkdirSync(sessionsDir, { recursive: true });
|
||||||
|
fs.mkdirSync(path.join(isoHome, '.claude', 'skills', 'learned'), { recursive: true });
|
||||||
|
|
||||||
|
const sessionFile = path.join(sessionsDir, '2026-02-11-winansi00-session.tmp');
|
||||||
|
fs.writeFileSync(
|
||||||
|
sessionFile,
|
||||||
|
'\x1b[H\x1b[2J\x1b[3J# Real Session\n\nI worked on \x1b[1;36mWindows terminal handling\x1b[0m.\x1b[K\n'
|
||||||
|
);
|
||||||
|
|
||||||
|
try {
|
||||||
|
const result = await runScript(path.join(scriptsDir, 'session-start.js'), '', {
|
||||||
|
HOME: isoHome,
|
||||||
|
USERPROFILE: isoHome
|
||||||
|
});
|
||||||
|
assert.strictEqual(result.code, 0);
|
||||||
|
assert.ok(result.stdout.includes('Previous session summary'), 'Should inject real session content');
|
||||||
|
assert.ok(result.stdout.includes('Windows terminal handling'), 'Should preserve sanitized session text');
|
||||||
|
assert.ok(!result.stdout.includes('\x1b['), 'Should not emit ANSI escape codes');
|
||||||
|
} finally {
|
||||||
|
fs.rmSync(isoHome, { recursive: true, force: true });
|
||||||
|
}
|
||||||
|
})
|
||||||
|
)
|
||||||
|
passed++;
|
||||||
|
else failed++;
|
||||||
|
|
||||||
if (
|
if (
|
||||||
await asyncTest('reports learned skills count', async () => {
|
await asyncTest('reports learned skills count', async () => {
|
||||||
const isoHome = path.join(os.tmpdir(), `ecc-skills-start-${Date.now()}`);
|
const isoHome = path.join(os.tmpdir(), `ecc-skills-start-${Date.now()}`);
|
||||||
|
|||||||
Reference in New Issue
Block a user