Изменено (методы logger без форматирования): - Добавлена подготовка и выравнивание аттрибутов для logger - Выравнивание за счет добавления !BADKEY до процессинга log/slog - Добавлено переиспользование метода Log - Удалены методы [Logf, Infof, Debugf, Errorf, Warnf, Fatalf, Tracef] - Обновлены юниттесты - Удален wrapper в пакете logger - Изменен интерфейс logger - Отрефакторены вызовы logger'a в micro Co-authored-by: Vasiliy Tolstov <v.tolstov@unistack.org> Reviewed-on: #351 Co-authored-by: Evstigneev Denis <danteevstigneev@yandex.ru> Co-committed-by: Evstigneev Denis <danteevstigneev@yandex.ru>
		
			
				
	
	
		
			39 lines
		
	
	
		
			764 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			764 B
		
	
	
	
		
			Go
		
	
	
	
	
	
package memory
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"context"
 | 
						|
	"fmt"
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"go.unistack.org/micro/v3/logger"
 | 
						|
	"go.unistack.org/micro/v3/logger/slog"
 | 
						|
	"go.unistack.org/micro/v3/tracer"
 | 
						|
)
 | 
						|
 | 
						|
func TestLoggerWithTracer(t *testing.T) {
 | 
						|
	ctx := context.TODO()
 | 
						|
	buf := bytes.NewBuffer(nil)
 | 
						|
	logger.DefaultLogger = slog.NewLogger(logger.WithOutput(buf))
 | 
						|
 | 
						|
	if err := logger.DefaultLogger.Init(); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	var span tracer.Span
 | 
						|
	tr := NewTracer()
 | 
						|
	ctx, span = tr.Start(ctx, "test1")
 | 
						|
 | 
						|
	logger.DefaultLogger.Error(ctx, "my test error", fmt.Errorf("error"))
 | 
						|
 | 
						|
	if !strings.Contains(buf.String(), span.TraceID()) {
 | 
						|
		t.Fatalf("log does not contains trace id: %s", buf.Bytes())
 | 
						|
	}
 | 
						|
 | 
						|
	_, _ = tr.Start(ctx, "test2")
 | 
						|
 | 
						|
	for _, s := range tr.Spans() {
 | 
						|
		_ = s
 | 
						|
	}
 | 
						|
}
 |