42 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
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")
 | 
						|
}
 |