2
0

preload.ts 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. // IMPORTANT: Set env vars BEFORE any imports from src/ directory
  2. // xdg-basedir reads env vars at import time, so we must set these first
  3. import os from "os"
  4. import path from "path"
  5. import fs from "fs/promises"
  6. import fsSync from "fs"
  7. import { afterAll } from "bun:test"
  8. const { Global } = await import("../src/global")
  9. const dir = path.join(os.tmpdir(), "opencode-test-data-" + process.pid)
  10. await fs.mkdir(dir, { recursive: true })
  11. afterAll(() => {
  12. fsSync.rmSync(dir, { recursive: true, force: true })
  13. })
  14. // Set test home directory to isolate tests from user's actual home directory
  15. // This prevents tests from picking up real user configs/skills from ~/.claude/skills
  16. const testHome = path.join(dir, "home")
  17. await fs.mkdir(testHome, { recursive: true })
  18. process.env["OPENCODE_TEST_HOME"] = testHome
  19. process.env["XDG_DATA_HOME"] = path.join(dir, "share")
  20. process.env["XDG_CACHE_HOME"] = path.join(dir, "cache")
  21. process.env["XDG_CONFIG_HOME"] = path.join(dir, "config")
  22. process.env["XDG_STATE_HOME"] = path.join(dir, "state")
  23. // Pre-fetch models.json so tests don't need the macro fallback
  24. // Also write the cache version file to prevent global/index.ts from clearing the cache
  25. const cacheDir = path.join(dir, "cache", "opencode")
  26. await fs.mkdir(cacheDir, { recursive: true })
  27. await fs.writeFile(path.join(cacheDir, "version"), "14")
  28. const url = Global.Path.modelsDevUrl
  29. const response = await fetch(`${url}/api.json`)
  30. if (response.ok) {
  31. await fs.writeFile(path.join(cacheDir, "models.json"), await response.text())
  32. }
  33. // Disable models.dev refresh to avoid race conditions during tests
  34. process.env["OPENCODE_DISABLE_MODELS_FETCH"] = "true"
  35. // Clear provider env vars to ensure clean test state
  36. delete process.env["ANTHROPIC_API_KEY"]
  37. delete process.env["OPENAI_API_KEY"]
  38. delete process.env["GOOGLE_API_KEY"]
  39. delete process.env["GOOGLE_GENERATIVE_AI_API_KEY"]
  40. delete process.env["AZURE_OPENAI_API_KEY"]
  41. delete process.env["AWS_ACCESS_KEY_ID"]
  42. delete process.env["AWS_PROFILE"]
  43. delete process.env["AWS_REGION"]
  44. delete process.env["AWS_BEARER_TOKEN_BEDROCK"]
  45. delete process.env["OPENROUTER_API_KEY"]
  46. delete process.env["GROQ_API_KEY"]
  47. delete process.env["MISTRAL_API_KEY"]
  48. delete process.env["PERPLEXITY_API_KEY"]
  49. delete process.env["TOGETHER_API_KEY"]
  50. delete process.env["XAI_API_KEY"]
  51. delete process.env["DEEPSEEK_API_KEY"]
  52. delete process.env["FIREWORKS_API_KEY"]
  53. delete process.env["CEREBRAS_API_KEY"]
  54. delete process.env["SAMBANOVA_API_KEY"]
  55. // Now safe to import from src/
  56. const { Log } = await import("../src/util/log")
  57. Log.init({
  58. print: false,
  59. dev: true,
  60. level: "DEBUG",
  61. })