Skip to content
Snippets Groups Projects
Select Git revision
  • 7149ed6259f3d9dbcd45c91c853d77918313e396
  • master default protected
  • feature/PRXS-3106-NoCache
  • feature/PRXS-3043-NewURLFormat
  • feature/2781-SpacesLoggingMiddleware
  • feature/PRXS-2974-FillImageDimensions
  • feature/PRXS-3143-3235-ReferenceOptions
  • feature/PRXS-3056-LocalesFromToMap
  • feature/PRXS-3421-ImplementNewRefAPI
  • feature/PRXS-3143-LimitReferenceFields
  • feature/PRXS-3234-FeaturePruneIdents
  • PRXS-3421-RecursiveReferences
  • feature/3109-SerializeFeature
  • release/0.33
  • feature/3109-RecoverySchema
  • feature/3109-feature
  • fix/PRXS-3369-ValidateFields
  • refactor/PRXS-3306-MovePkgGroup1
  • refactor/6-pkg-refactor-expr
  • fix/PRXS-3360-TemplateBuilderPatch
  • feature/3293-MongoV2
  • v0.33.1
  • v0.32.0
  • v0.31.1
  • v0.31.0
  • v0.30.0
  • v0.29.0
  • v0.28.0
  • v0.27.0-alpha.1+16
  • v0.27.0-alpha.1+15
  • v0.27.0-alpha.1+14
  • v0.27.0-alpha.1+13
  • v0.27.0-alpha.1+12
  • v0.27.0-alpha.1+11
  • v0.27.0-alpha.1+10
  • v0.27.0-alpha.1+9
  • v0.27.0-alpha.1+8
  • v0.27.0-alpha.1+7
  • v0.27.0-alpha.1+6
  • v0.27.0-alpha.1+5
  • v0.27.0-alpha.1+4
41 results

zap_test.go

Blame
  • user avatar
    ensiouel authored
    7149ed62
    History
    zap_test.go 1.28 KiB
    package zap
    
    import (
    	"context"
    	"testing"
    
    	"git.perx.ru/perxis/perxis-go/pkg/log"
    	logmocks "git.perx.ru/perxis/perxis-go/pkg/log/mocks"
    	"github.com/stretchr/testify/assert"
    	"github.com/stretchr/testify/mock"
    	"go.uber.org/zap"
    )
    
    func TestExample(t *testing.T) {
    	service := &logmocks.Service{}
    	service.On("Log", mock.Anything, mock.Anything).
    		Return(nil).Once()
    
    	func() {
    		ws := NewBufferedWriteSyncer(service)
    		defer func() {
    			err := ws.Stop()
    			assert.NoError(t, err)
    		}()
    
    		logger := WithLogService(zap.NewNop(), ws)
    
    		logger.Info("создан элемент коллекции",
    			Category("create"),
    			Component("Items.Service"),
    			Event("Items.Create"),
    			Object("/spaces/WPNN/envs/9VGP/cols/GxNv/items/W0fl"),
    			CallerFromContext(ContextWithCaller(context.Background(), "/users/PHVz")),
    			Attr("any"),
    			Tags("tag1", "tag2", "tag3"),
    		)
    		logger.Warn("изменен элемент коллекции",
    			Category("update"),
    			Component("Items.Service"),
    			Event("Items.Update"),
    			Object("/spaces/WPNN/envs/9VGP/cols/GxNv/items/W0fl/revs/cmV2cw"),
    			CallerFromContext(ContextWithCaller(context.Background(), "/users/PHVz")),
    		)
    	}()
    
    	service.AssertCalled(t, "Log", mock.Anything, mock.MatchedBy(func(entries []*log.Entry) bool {
    		return len(entries) == 2
    	}))
    }