use mock logger in integration tests

This commit is contained in:
Shreyas Goenka 2025-01-03 11:47:45 +05:30
parent 2357954885
commit 4832b545b0
No known key found for this signature in database
GPG Key ID: 92A07DF49CCB0622
2 changed files with 36 additions and 20 deletions

View File

@ -45,8 +45,8 @@ func TestBundleInitOnMlopsStacks(t *testing.T) {
ctx, wt := acc.WorkspaceTest(t) ctx, wt := acc.WorkspaceTest(t)
w := wt.W w := wt.W
// Configure a telemetry logger in the context. // Use mock logger to introspect the telemetry payload.
ctx = telemetry.WithDefaultLogger(ctx) ctx = telemetry.WithMockLogger(ctx)
tmpDir1 := t.TempDir() tmpDir1 := t.TempDir()
tmpDir2 := t.TempDir() tmpDir2 := t.TempDir()
@ -71,10 +71,9 @@ func TestBundleInitOnMlopsStacks(t *testing.T) {
testcli.RequireSuccessfulRun(t, ctx, "bundle", "init", "mlops-stacks", "--output-dir", tmpDir2, "--config-file", filepath.Join(tmpDir1, "config.json")) testcli.RequireSuccessfulRun(t, ctx, "bundle", "init", "mlops-stacks", "--output-dir", tmpDir2, "--config-file", filepath.Join(tmpDir1, "config.json"))
// Assert the telemetry payload is correctly logged. // Assert the telemetry payload is correctly logged.
logs := telemetry.Introspect(ctx) tlmyEvents := telemetry.Introspect(ctx)
require.NoError(t, err) require.Len(t, telemetry.Introspect(ctx), 1)
require.Len(t, len(logs), 1) event := tlmyEvents[0].BundleInitEvent
event := logs[0].BundleInitEvent
assert.Equal(t, "mlops-stacks", event.TemplateName) assert.Equal(t, "mlops-stacks", event.TemplateName)
get := func(key string) string { get := func(key string) string {
@ -179,8 +178,8 @@ func TestBundleInitTelemetryForDefaultTemplates(t *testing.T) {
for _, tc := range tcases { for _, tc := range tcases {
ctx, _ := acc.WorkspaceTest(t) ctx, _ := acc.WorkspaceTest(t)
// Configure a telemetry logger in the context. // Use mock logger to introspect the telemetry payload.
ctx = telemetry.WithDefaultLogger(ctx) ctx = telemetry.WithMockLogger(ctx)
tmpDir1 := t.TempDir() tmpDir1 := t.TempDir()
tmpDir2 := t.TempDir() tmpDir2 := t.TempDir()
@ -199,7 +198,7 @@ func TestBundleInitTelemetryForDefaultTemplates(t *testing.T) {
// Assert the telemetry payload is correctly logged. // Assert the telemetry payload is correctly logged.
logs := telemetry.Introspect(ctx) logs := telemetry.Introspect(ctx)
require.Len(t, len(logs), 1) require.Len(t, logs, 1)
event := logs[0].BundleInitEvent event := logs[0].BundleInitEvent
assert.Equal(t, event.TemplateName, tc.name) assert.Equal(t, event.TemplateName, tc.name)
@ -258,17 +257,17 @@ func TestBundleInitTelemetryForCustomTemplates(t *testing.T) {
err = os.WriteFile(filepath.Join(tmpDir3, "config.json"), b, 0o644) err = os.WriteFile(filepath.Join(tmpDir3, "config.json"), b, 0o644)
require.NoError(t, err) require.NoError(t, err)
// Configure a telemetry logger in the context. // Use mock logger to introspect the telemetry payload.
ctx = telemetry.WithDefaultLogger(ctx) ctx = telemetry.WithMockLogger(ctx)
// Run bundle init. // Run bundle init.
testcli.RequireSuccessfulRun(t, ctx, "bundle", "init", tmpDir1, "--output-dir", tmpDir2, "--config-file", filepath.Join(tmpDir3, "config.json")) testcli.RequireSuccessfulRun(t, ctx, "bundle", "init", tmpDir1, "--output-dir", tmpDir2, "--config-file", filepath.Join(tmpDir3, "config.json"))
// Assert the telemetry payload is correctly logged. For custom templates we should // Assert the telemetry payload is correctly logged. For custom templates we should
// never set template_enum_args. // never set template_enum_args.
logs := telemetry.Introspect(ctx) tlmyEvents := telemetry.Introspect(ctx)
require.Len(t, len(logs), 1) require.Len(t, len(tlmyEvents), 1)
event := logs[0].BundleInitEvent event := tlmyEvents[0].BundleInitEvent
assert.Equal(t, "custom", event.TemplateName) assert.Equal(t, "custom", event.TemplateName)
assert.Empty(t, event.TemplateEnumArgs) assert.Empty(t, event.TemplateEnumArgs)

View File

@ -11,15 +11,32 @@ type telemetryLogger int
// Key to store the telemetry logger in the context // Key to store the telemetry logger in the context
var telemetryLoggerKey telemetryLogger var telemetryLoggerKey telemetryLogger
// TODO: Add tests for these methods.
func WithDefaultLogger(ctx context.Context) context.Context { func WithDefaultLogger(ctx context.Context) context.Context {
v := ctx.Value(telemetryLoggerKey) v := ctx.Value(telemetryLoggerKey)
if v != nil {
panic(fmt.Sprintf("telemetry logger already set in the context: %v", v)) // If no logger is set in the context, set the default logger.
if v == nil {
nctx := context.WithValue(ctx, telemetryLoggerKey, &defaultLogger{logs: []FrontendLog{}})
return nctx
} }
return context.WithValue(ctx, telemetryLoggerKey, &defaultLogger{logs: []FrontendLog{}}) switch v.(type) {
case *defaultLogger:
panic(fmt.Sprintf("default telemetry logger already set in the context: %v", v))
case *mockLogger:
// Do nothing. Unit and integration tests set the mock logger in the context
// to avoid making actual API calls. Thus WithDefaultLogger should silently
// ignore the mock logger.
default:
panic(fmt.Sprintf("unexpected telemetry logger type: %T", v))
} }
return ctx
}
// WithMockLogger sets a mock telemetry logger in the context. It overrides the
// default logger if it is already set in the context.
func WithMockLogger(ctx context.Context) context.Context { func WithMockLogger(ctx context.Context) context.Context {
v := ctx.Value(telemetryLoggerKey) v := ctx.Value(telemetryLoggerKey)
if v != nil { if v != nil {
@ -35,11 +52,11 @@ func fromContext(ctx context.Context) Logger {
panic("telemetry logger not found in the context") panic("telemetry logger not found in the context")
} }
switch v.(type) { switch vv := v.(type) {
case *defaultLogger: case *defaultLogger:
return v.(*defaultLogger) return vv
case *mockLogger: case *mockLogger:
return v.(*mockLogger) return vv
default: default:
panic(fmt.Sprintf("unexpected telemetry logger type: %T", v)) panic(fmt.Sprintf("unexpected telemetry logger type: %T", v))
} }