import { expect, test } from "bun:test" import { Context, Effect, Layer, Logger } from "effect" import { AppRuntime } from "../../src/effect/app-runtime" import { InstanceRef } from "../../src/effect/instance-ref" import { EffectLogger } from "../../src/effect/logger" import { makeRuntime } from "../../src/effect/run-service" import { Instance } from "../../src/project/instance" import { tmpdir } from "../fixture/fixture" function check(loggers: ReadonlySet>) { return { defaultLogger: loggers.has(Logger.defaultLogger), tracerLogger: loggers.has(Logger.tracerLogger), effectLogger: loggers.has(EffectLogger.logger), size: loggers.size, } } test("makeRuntime installs EffectLogger through Observability.layer", async () => { class Dummy extends Context.Service Effect.Effect> }>()( "@test/Dummy", ) {} const layer = Layer.effect( Dummy, Effect.gen(function* () { return Dummy.of({ current: () => Effect.map(Effect.service(Logger.CurrentLoggers), check), }) }), ) const rt = makeRuntime(Dummy, layer) const current = await rt.runPromise((svc) => svc.current()) expect(current.effectLogger).toBe(true) expect(current.defaultLogger).toBe(false) }) test("AppRuntime also installs EffectLogger through Observability.layer", async () => { const current = await AppRuntime.runPromise(Effect.map(Effect.service(Logger.CurrentLoggers), check)) expect(current.effectLogger).toBe(true) expect(current.defaultLogger).toBe(false) }) test("AppRuntime attaches InstanceRef from ALS", async () => { await using tmp = await tmpdir({ git: true }) const dir = await Instance.provide({ directory: tmp.path, fn: () => AppRuntime.runPromise( Effect.gen(function* () { return (yield* InstanceRef)?.directory }), ), }) expect(dir).toBe(tmp.path) })