- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
73 lines
1.6 KiB
JavaScript
73 lines
1.6 KiB
JavaScript
import { resolve } from 'pathe';
|
|
import { x } from 'tinyexec';
|
|
|
|
class VitestGit {
|
|
root;
|
|
constructor(cwd) {
|
|
this.cwd = cwd;
|
|
}
|
|
async resolveFilesWithGitCommand(args) {
|
|
let result;
|
|
try {
|
|
result = await x("git", args, { nodeOptions: { cwd: this.root } });
|
|
} catch (e) {
|
|
e.message = e.stderr;
|
|
throw e;
|
|
}
|
|
return result.stdout.split("\n").filter((s) => s !== "").map((changedPath) => resolve(this.root, changedPath));
|
|
}
|
|
async findChangedFiles(options) {
|
|
const root = await this.getRoot(this.cwd);
|
|
if (!root) return null;
|
|
this.root = root;
|
|
const changedSince = options.changedSince;
|
|
if (typeof changedSince === "string") {
|
|
const [committed, staged, unstaged] = await Promise.all([
|
|
this.getFilesSince(changedSince),
|
|
this.getStagedFiles(),
|
|
this.getUnstagedFiles()
|
|
]);
|
|
return [
|
|
...committed,
|
|
...staged,
|
|
...unstaged
|
|
];
|
|
}
|
|
const [staged, unstaged] = await Promise.all([this.getStagedFiles(), this.getUnstagedFiles()]);
|
|
return [...staged, ...unstaged];
|
|
}
|
|
getFilesSince(hash) {
|
|
return this.resolveFilesWithGitCommand([
|
|
"diff",
|
|
"--name-only",
|
|
`${hash}...HEAD`
|
|
]);
|
|
}
|
|
getStagedFiles() {
|
|
return this.resolveFilesWithGitCommand([
|
|
"diff",
|
|
"--cached",
|
|
"--name-only"
|
|
]);
|
|
}
|
|
getUnstagedFiles() {
|
|
return this.resolveFilesWithGitCommand([
|
|
"ls-files",
|
|
"--other",
|
|
"--modified",
|
|
"--exclude-standard"
|
|
]);
|
|
}
|
|
async getRoot(cwd) {
|
|
const args = ["rev-parse", "--show-cdup"];
|
|
try {
|
|
const result = await x("git", args, { nodeOptions: { cwd } });
|
|
return resolve(cwd, result.stdout.trim());
|
|
} catch {
|
|
return null;
|
|
}
|
|
}
|
|
}
|
|
|
|
export { VitestGit };
|