package log import ( "context" "testing" "github.com/stretchr/testify/assert" ) func TestLoggerContext(t *testing.T) { ctx := context.Background() assert.Equal(t, GetLogger(ctx), L) // should be same as L variable assert.Equal(t, G(ctx), GetLogger(ctx)) // these should be the same. ctx = WithLogger(ctx, G(ctx).WithField("test", "one")) assert.Equal(t, GetLogger(ctx).Data["test"], "one") assert.Equal(t, G(ctx), GetLogger(ctx)) // these should be the same. } func TestModuleContext(t *testing.T) { ctx := context.Background() assert.Equal(t, GetModulePath(ctx), "") ctx = WithModule(ctx, "a") // basic behavior assert.Equal(t, GetModulePath(ctx), "a") logger := GetLogger(ctx) assert.Equal(t, logger.Data["module"], "a") parent, ctx := ctx, WithModule(ctx, "a") assert.Equal(t, ctx, parent) // should be a no-op assert.Equal(t, GetModulePath(ctx), "a") assert.Equal(t, GetLogger(ctx).Data["module"], "a") ctx = WithModule(ctx, "b") // new module assert.Equal(t, GetModulePath(ctx), "a/b") assert.Equal(t, GetLogger(ctx).Data["module"], "a/b") ctx = WithModule(ctx, "c") // new module assert.Equal(t, GetModulePath(ctx), "a/b/c") assert.Equal(t, GetLogger(ctx).Data["module"], "a/b/c") }