mirror of
https://github.com/l5yth/potato-mesh.git
synced 2026-03-28 17:42:48 +01:00
38 lines
1023 B
Ruby
38 lines
1023 B
Ruby
# frozen_string_literal: true
|
|
|
|
require "spec_helper"
|
|
require "potato_mesh/logging"
|
|
|
|
describe PotatoMesh::Logging do
|
|
describe ".formatter" do
|
|
it "generates structured log entries" do
|
|
timestamp = Time.utc(2024, 1, 2, 3, 4, 5, 678_000)
|
|
formatted = described_class.formatter("DEBUG", timestamp, "potato-mesh", "hello")
|
|
|
|
expect(formatted).to eq("[2024-01-02T03:04:05.678Z] [potato-mesh] [debug] hello\n")
|
|
end
|
|
end
|
|
|
|
describe ".log" do
|
|
it "passes structured metadata to the logger" do
|
|
logger = instance_double(Logger)
|
|
|
|
expect(logger).to receive(:debug).with("context=test foo=\"bar\" hello")
|
|
|
|
described_class.log(logger, :debug, "hello", context: "test", foo: "bar")
|
|
end
|
|
end
|
|
|
|
describe ".logger_for" do
|
|
it "returns the logger from an object with settings" do
|
|
container = Class.new do
|
|
def settings
|
|
Struct.new(:logger).new(:logger)
|
|
end
|
|
end
|
|
|
|
expect(described_class.logger_for(container.new)).to eq(:logger)
|
|
end
|
|
end
|
|
end
|