123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- package awslogs // import "github.com/docker/docker/daemon/logger/awslogs"
- import (
- "context"
- "fmt"
- "github.com/aws/aws-sdk-go-v2/feature/ec2/imds"
- "github.com/aws/aws-sdk-go-v2/service/cloudwatchlogs"
- )
- type mockClient struct {
- createLogGroupFunc func(context.Context, *cloudwatchlogs.CreateLogGroupInput, ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.CreateLogGroupOutput, error)
- createLogStreamFunc func(context.Context, *cloudwatchlogs.CreateLogStreamInput, ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.CreateLogStreamOutput, error)
- putLogEventsFunc func(context.Context, *cloudwatchlogs.PutLogEventsInput, ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.PutLogEventsOutput, error)
- }
- func (m *mockClient) CreateLogGroup(ctx context.Context, input *cloudwatchlogs.CreateLogGroupInput, opts ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.CreateLogGroupOutput, error) {
- return m.createLogGroupFunc(ctx, input, opts...)
- }
- func (m *mockClient) CreateLogStream(ctx context.Context, input *cloudwatchlogs.CreateLogStreamInput, opts ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.CreateLogStreamOutput, error) {
- return m.createLogStreamFunc(ctx, input, opts...)
- }
- func (m *mockClient) PutLogEvents(ctx context.Context, input *cloudwatchlogs.PutLogEventsInput, opts ...func(*cloudwatchlogs.Options)) (*cloudwatchlogs.PutLogEventsOutput, error) {
- if err := checkPutLogEventsConstraints(input); err != nil {
- return nil, err
- }
- return m.putLogEventsFunc(ctx, input, opts...)
- }
- func checkPutLogEventsConstraints(input *cloudwatchlogs.PutLogEventsInput) error {
- events := input.LogEvents
- // Checked enforced limits in mock
- totalBytes := 0
- for _, evt := range events {
- if evt.Message == nil {
- continue
- }
- eventBytes := len([]byte(*evt.Message))
- if eventBytes > maximumBytesPerEvent {
- // exceeded per event message size limits
- return fmt.Errorf("maximum bytes per event exceeded: Event too large %d, max allowed: %d", eventBytes, maximumBytesPerEvent)
- }
- // total event bytes including overhead
- totalBytes += eventBytes + perEventBytes
- }
- if totalBytes > maximumBytesPerPut {
- // exceeded per put maximum size limit
- return fmt.Errorf("maximum bytes per put exceeded: Upload too large %d, max allowed: %d", totalBytes, maximumBytesPerPut)
- }
- return nil
- }
- type mockmetadataclient struct {
- regionResult chan *regionResult
- }
- type regionResult struct {
- successResult string
- errorResult error
- }
- func newMockMetadataClient() *mockmetadataclient {
- return &mockmetadataclient{
- regionResult: make(chan *regionResult, 1),
- }
- }
- func (m *mockmetadataclient) GetRegion(context.Context, *imds.GetRegionInput, ...func(*imds.Options)) (*imds.GetRegionOutput, error) {
- output := <-m.regionResult
- err := output.errorResult
- if err != nil {
- return nil, err
- }
- return &imds.GetRegionOutput{Region: output.successResult}, err
- }
|