feat(sync): add Claude home sync parity across providers
This commit is contained in:
@@ -11,8 +11,9 @@ describe("detectInstalledTools", () => {
|
||||
|
||||
// Create directories for some tools
|
||||
await fs.mkdir(path.join(tempHome, ".codex"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempCwd, ".cursor"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempCwd, ".gemini"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".codeium", "windsurf"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".gemini"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".copilot"), { recursive: true })
|
||||
|
||||
const results = await detectInstalledTools(tempHome, tempCwd)
|
||||
|
||||
@@ -20,14 +21,18 @@ describe("detectInstalledTools", () => {
|
||||
expect(codex?.detected).toBe(true)
|
||||
expect(codex?.reason).toContain(".codex")
|
||||
|
||||
const cursor = results.find((t) => t.name === "cursor")
|
||||
expect(cursor?.detected).toBe(true)
|
||||
expect(cursor?.reason).toContain(".cursor")
|
||||
const windsurf = results.find((t) => t.name === "windsurf")
|
||||
expect(windsurf?.detected).toBe(true)
|
||||
expect(windsurf?.reason).toContain(".codeium/windsurf")
|
||||
|
||||
const gemini = results.find((t) => t.name === "gemini")
|
||||
expect(gemini?.detected).toBe(true)
|
||||
expect(gemini?.reason).toContain(".gemini")
|
||||
|
||||
const copilot = results.find((t) => t.name === "copilot")
|
||||
expect(copilot?.detected).toBe(true)
|
||||
expect(copilot?.reason).toContain(".copilot")
|
||||
|
||||
// Tools without directories should not be detected
|
||||
const opencode = results.find((t) => t.name === "opencode")
|
||||
expect(opencode?.detected).toBe(false)
|
||||
@@ -45,7 +50,7 @@ describe("detectInstalledTools", () => {
|
||||
|
||||
const results = await detectInstalledTools(tempHome, tempCwd)
|
||||
|
||||
expect(results.length).toBe(6)
|
||||
expect(results.length).toBe(10)
|
||||
for (const tool of results) {
|
||||
expect(tool.detected).toBe(false)
|
||||
expect(tool.reason).toBe("not found")
|
||||
@@ -59,12 +64,30 @@ describe("detectInstalledTools", () => {
|
||||
await fs.mkdir(path.join(tempHome, ".config", "opencode"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".factory"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".pi"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".openclaw"), { recursive: true })
|
||||
|
||||
const results = await detectInstalledTools(tempHome, tempCwd)
|
||||
|
||||
expect(results.find((t) => t.name === "opencode")?.detected).toBe(true)
|
||||
expect(results.find((t) => t.name === "droid")?.detected).toBe(true)
|
||||
expect(results.find((t) => t.name === "pi")?.detected).toBe(true)
|
||||
expect(results.find((t) => t.name === "openclaw")?.detected).toBe(true)
|
||||
})
|
||||
|
||||
test("detects copilot from project-specific skills without generic .github false positives", async () => {
|
||||
const tempHome = await fs.mkdtemp(path.join(os.tmpdir(), "detect-copilot-home-"))
|
||||
const tempCwd = await fs.mkdtemp(path.join(os.tmpdir(), "detect-copilot-cwd-"))
|
||||
|
||||
await fs.mkdir(path.join(tempCwd, ".github"), { recursive: true })
|
||||
|
||||
let results = await detectInstalledTools(tempHome, tempCwd)
|
||||
expect(results.find((t) => t.name === "copilot")?.detected).toBe(false)
|
||||
|
||||
await fs.mkdir(path.join(tempCwd, ".github", "skills"), { recursive: true })
|
||||
|
||||
results = await detectInstalledTools(tempHome, tempCwd)
|
||||
expect(results.find((t) => t.name === "copilot")?.detected).toBe(true)
|
||||
expect(results.find((t) => t.name === "copilot")?.reason).toContain(".github/skills")
|
||||
})
|
||||
})
|
||||
|
||||
@@ -74,7 +97,7 @@ describe("getDetectedTargetNames", () => {
|
||||
const tempCwd = await fs.mkdtemp(path.join(os.tmpdir(), "detect-names-cwd-"))
|
||||
|
||||
await fs.mkdir(path.join(tempHome, ".codex"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempCwd, ".gemini"), { recursive: true })
|
||||
await fs.mkdir(path.join(tempHome, ".gemini"), { recursive: true })
|
||||
|
||||
const names = await getDetectedTargetNames(tempHome, tempCwd)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user