Изменено (методы 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
 | |
| 	}
 | |
| }
 |