|
1 | 1 | package agent |
2 | 2 |
|
3 | 3 | import ( |
| 4 | + "bytes" |
4 | 5 | "context" |
5 | 6 | "errors" |
| 7 | + "log/slog" |
6 | 8 | "testing" |
7 | 9 |
|
8 | 10 | "github.com/stretchr/testify/assert" |
@@ -139,6 +141,42 @@ func TestModelOverride(t *testing.T) { |
139 | 141 | assert.Equal(t, "openai/gpt-4o", model.ID()) |
140 | 142 | } |
141 | 143 |
|
| 144 | +func TestModel_LogsSelection(t *testing.T) { |
| 145 | + t.Parallel() |
| 146 | + |
| 147 | + var buf bytes.Buffer |
| 148 | + handler := slog.NewTextHandler(&buf, &slog.HandlerOptions{Level: slog.LevelInfo}) |
| 149 | + prev := slog.Default() |
| 150 | + slog.SetDefault(slog.New(handler)) |
| 151 | + t.Cleanup(func() { slog.SetDefault(prev) }) |
| 152 | + |
| 153 | + model1 := &mockProvider{id: "anthropic/claude-sonnet-4-0"} |
| 154 | + model2 := &mockProvider{id: "openai/gpt-4o"} |
| 155 | + |
| 156 | + a := New("scanner", "test", WithModel(model1), WithModel(model2)) |
| 157 | + |
| 158 | + // Verify basic selection logging |
| 159 | + selected := a.Model() |
| 160 | + logOutput := buf.String() |
| 161 | + |
| 162 | + assert.Contains(t, logOutput, "Model selected") |
| 163 | + assert.Contains(t, logOutput, "agent=scanner") |
| 164 | + assert.Contains(t, logOutput, selected.ID()) |
| 165 | + assert.Contains(t, logOutput, "pool_size=2") |
| 166 | + |
| 167 | + // Verify override scenario logs correct pool_size |
| 168 | + buf.Reset() |
| 169 | + override := &mockProvider{id: "google/gemini-2.0-flash"} |
| 170 | + a.SetModelOverride(override) |
| 171 | + |
| 172 | + selected = a.Model() |
| 173 | + logOutput = buf.String() |
| 174 | + |
| 175 | + assert.Equal(t, "google/gemini-2.0-flash", selected.ID()) |
| 176 | + assert.Contains(t, logOutput, "google/gemini-2.0-flash") |
| 177 | + assert.Contains(t, logOutput, "pool_size=1") |
| 178 | +} |
| 179 | + |
142 | 180 | func TestModelOverride_ConcurrentAccess(t *testing.T) { |
143 | 181 | t.Parallel() |
144 | 182 |
|
|
0 commit comments