| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- import { expect, test } from "bun:test"
- import { Log } from "../../../src/util/log"
- Log.init({ print: false })
- const { DEFAULT_THEMES, allThemes, addTheme, hasTheme, resolveTheme } = await import(
- "../../../src/cli/cmd/tui/context/theme"
- )
- test("addTheme writes into module theme store", () => {
- const name = `plugin-theme-${Date.now()}`
- expect(addTheme(name, DEFAULT_THEMES.opencode)).toBe(true)
- expect(allThemes()[name]).toBeDefined()
- })
- test("addTheme keeps first theme for duplicate names", () => {
- const name = `plugin-theme-keep-${Date.now()}`
- const one = structuredClone(DEFAULT_THEMES.opencode)
- const two = structuredClone(DEFAULT_THEMES.opencode)
- one.theme.primary = "#101010"
- two.theme.primary = "#fefefe"
- expect(addTheme(name, one)).toBe(true)
- expect(addTheme(name, two)).toBe(false)
- expect(allThemes()[name]).toBeDefined()
- expect(allThemes()[name]!.theme.primary).toBe("#101010")
- })
- test("addTheme ignores entries without a theme object", () => {
- const name = `plugin-theme-invalid-${Date.now()}`
- expect(addTheme(name, { defs: { a: "#ffffff" } })).toBe(false)
- expect(allThemes()[name]).toBeUndefined()
- })
- test("hasTheme checks theme presence", () => {
- const name = `plugin-theme-has-${Date.now()}`
- expect(hasTheme(name)).toBe(false)
- expect(addTheme(name, DEFAULT_THEMES.opencode)).toBe(true)
- expect(hasTheme(name)).toBe(true)
- })
- test("resolveTheme rejects circular color refs", () => {
- const item = structuredClone(DEFAULT_THEMES.opencode)
- item.defs = {
- ...(item.defs ?? {}),
- one: "two",
- two: "one",
- }
- item.theme.primary = "one"
- expect(() => resolveTheme(item, "dark")).toThrow("Circular color reference")
- })
|