Initial import from garrytan/gstack@026751e (main snapshot via local relay)
Some checks failed
Workflow Lint / actionlint (push) Has been cancelled
Build CI Image / build (push) Has been cancelled
Skill Docs Freshness / check-freshness (push) Has been cancelled
Periodic Evals / build-image (push) Has been cancelled
Periodic Evals / evals (map[file:test/codex-e2e.test.ts name:e2e-codex]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/gemini-e2e.test.ts name:e2e-gemini]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-design.test.ts name:e2e-design]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-plan.test.ts name:e2e-plan]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-bugs.test.ts name:e2e-qa-bugs]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-workflow.test.ts name:e2e-qa-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-review.test.ts name:e2e-review]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-workflow.test.ts name:e2e-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-routing-e2e.test.ts name:e2e-routing]) (push) Has been cancelled
Some checks failed
Workflow Lint / actionlint (push) Has been cancelled
Build CI Image / build (push) Has been cancelled
Skill Docs Freshness / check-freshness (push) Has been cancelled
Periodic Evals / build-image (push) Has been cancelled
Periodic Evals / evals (map[file:test/codex-e2e.test.ts name:e2e-codex]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/gemini-e2e.test.ts name:e2e-gemini]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-design.test.ts name:e2e-design]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-plan.test.ts name:e2e-plan]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-bugs.test.ts name:e2e-qa-bugs]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-qa-workflow.test.ts name:e2e-qa-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-review.test.ts name:e2e-review]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-e2e-workflow.test.ts name:e2e-workflow]) (push) Has been cancelled
Periodic Evals / evals (map[file:test/skill-routing-e2e.test.ts name:e2e-routing]) (push) Has been cancelled
Source: https://github.com/garrytan/gstack/commit/026751e
This commit is contained in:
47
browse/test/error-handling.test.ts
Normal file
47
browse/test/error-handling.test.ts
Normal file
@@ -0,0 +1,47 @@
|
||||
import { describe, test, expect } from 'bun:test';
|
||||
import * as fs from 'fs';
|
||||
import * as os from 'os';
|
||||
import * as path from 'path';
|
||||
import { safeUnlink, safeKill, isProcessAlive } from '../src/error-handling';
|
||||
|
||||
describe('safeUnlink', () => {
|
||||
test('removes an existing file', () => {
|
||||
const tmp = path.join(os.tmpdir(), `test-safeUnlink-${Date.now()}`);
|
||||
fs.writeFileSync(tmp, 'hello');
|
||||
safeUnlink(tmp);
|
||||
expect(fs.existsSync(tmp)).toBe(false);
|
||||
});
|
||||
|
||||
test('ignores ENOENT (file does not exist)', () => {
|
||||
expect(() => safeUnlink('/tmp/nonexistent-file-' + Date.now())).not.toThrow();
|
||||
});
|
||||
|
||||
test('rethrows non-ENOENT errors', () => {
|
||||
// Attempt to unlink a directory — throws EPERM/EISDIR
|
||||
const dir = fs.mkdtempSync(path.join(os.tmpdir(), 'test-safeUnlink-'));
|
||||
expect(() => safeUnlink(dir)).toThrow();
|
||||
fs.rmdirSync(dir);
|
||||
});
|
||||
});
|
||||
|
||||
describe('safeKill', () => {
|
||||
test('sends signal to a running process', () => {
|
||||
// signal 0 is a no-op existence check — safe to send to self
|
||||
expect(() => safeKill(process.pid, 0)).not.toThrow();
|
||||
});
|
||||
|
||||
test('ignores ESRCH (process does not exist)', () => {
|
||||
// PID 99999999 is extremely unlikely to exist
|
||||
expect(() => safeKill(99999999, 0)).not.toThrow();
|
||||
});
|
||||
});
|
||||
|
||||
describe('isProcessAlive', () => {
|
||||
test('returns true for current process', () => {
|
||||
expect(isProcessAlive(process.pid)).toBe(true);
|
||||
});
|
||||
|
||||
test('returns false for non-existent process', () => {
|
||||
expect(isProcessAlive(99999999)).toBe(false);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user