| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * https://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| package cache |
| |
| import ( |
| "fmt" |
| "testing" |
| |
| "github.com/stretchr/testify/assert" |
| "github.com/viney-shih/go-lock" |
| |
| "github.com/apache/plc4x/plc4go/internal/simulated" |
| plc4go "github.com/apache/plc4x/plc4go/pkg/api" |
| "github.com/apache/plc4x/plc4go/pkg/api/config" |
| "github.com/apache/plc4x/plc4go/spi/options" |
| "github.com/apache/plc4x/plc4go/spi/testutils" |
| ) |
| |
| func Test_connectionContainer_String(t1 *testing.T) { |
| type fields struct { |
| lock lock.RWMutex |
| connectionString string |
| driverManager plc4go.PlcDriverManager |
| tracerEnabled bool |
| connection tracedPlcConnection |
| leaseCounter uint32 |
| closed bool |
| state cachedPlcConnectionState |
| queue []chan plc4go.PlcConnectionConnectResult |
| listeners []connectionListener |
| } |
| tests := []struct { |
| name string |
| fields fields |
| setup func(t *testing.T, fields *fields) |
| want string |
| }{ |
| { |
| name: "string it", |
| want: "connectionContainer{:%!s(<nil>), leaseCounter: 0, closed: false, state: StateInitialized}", |
| }, |
| } |
| for _, tt := range tests { |
| t1.Run(tt.name, func(t *testing.T) { |
| if tt.setup != nil { |
| tt.setup(t, &tt.fields) |
| } |
| c := &connectionContainer{ |
| log: testutils.ProduceTestingLogger(t), |
| lock: tt.fields.lock, |
| connectionString: tt.fields.connectionString, |
| driverManager: tt.fields.driverManager, |
| tracerEnabled: tt.fields.tracerEnabled, |
| connection: tt.fields.connection, |
| leaseCounter: tt.fields.leaseCounter, |
| closed: tt.fields.closed, |
| state: tt.fields.state, |
| queue: tt.fields.queue, |
| listeners: tt.fields.listeners, |
| } |
| assert.Equalf(t1, tt.want, c.String(), "String()") |
| }) |
| } |
| } |
| |
| func Test_connectionContainer_addListener(t1 *testing.T) { |
| type fields struct { |
| lock lock.RWMutex |
| connectionString string |
| driverManager plc4go.PlcDriverManager |
| tracerEnabled bool |
| connection tracedPlcConnection |
| leaseCounter uint32 |
| closed bool |
| state cachedPlcConnectionState |
| queue []chan plc4go.PlcConnectionConnectResult |
| listeners []connectionListener |
| } |
| type args struct { |
| listener connectionListener |
| } |
| tests := []struct { |
| name string |
| fields fields |
| args args |
| }{ |
| { |
| name: "add it", |
| fields: fields{ |
| lock: lock.NewCASMutex(), |
| }, |
| }, |
| } |
| for _, tt := range tests { |
| t1.Run(tt.name, func(t1 *testing.T) { |
| t := &connectionContainer{ |
| log: testutils.ProduceTestingLogger(t1), |
| lock: tt.fields.lock, |
| connectionString: tt.fields.connectionString, |
| driverManager: tt.fields.driverManager, |
| tracerEnabled: tt.fields.tracerEnabled, |
| connection: tt.fields.connection, |
| leaseCounter: tt.fields.leaseCounter, |
| closed: tt.fields.closed, |
| state: tt.fields.state, |
| queue: tt.fields.queue, |
| listeners: tt.fields.listeners, |
| } |
| t.addListener(tt.args.listener) |
| }) |
| } |
| } |
| |
| func Test_connectionContainer_connect(t1 *testing.T) { |
| type fields struct { |
| lock lock.RWMutex |
| connectionString string |
| driverManager plc4go.PlcDriverManager |
| tracerEnabled bool |
| connection tracedPlcConnection |
| leaseCounter uint32 |
| closed bool |
| state cachedPlcConnectionState |
| queue []chan plc4go.PlcConnectionConnectResult |
| listeners []connectionListener |
| } |
| tests := []struct { |
| name string |
| fields fields |
| setup func(t *testing.T, fields *fields) |
| }{ |
| { |
| name: "connect fresh", |
| fields: fields{ |
| connectionString: "simulated://1.2.3.4:42", |
| lock: lock.NewCASMutex(), |
| queue: []chan plc4go.PlcConnectionConnectResult{}, |
| }, |
| setup: func(t *testing.T, fields *fields) { |
| logger := testutils.ProduceTestingLogger(t) |
| |
| driverManager := plc4go.NewPlcDriverManager(config.WithCustomLogger(logger)) |
| t.Cleanup(func() { |
| assert.NoError(t, driverManager.Close()) |
| }) |
| driverManager.RegisterDriver(simulated.NewDriver(options.WithCustomLogger(logger))) |
| fields.driverManager = driverManager |
| }, |
| }, |
| } |
| for _, tt := range tests { |
| t1.Run(tt.name, func(t *testing.T) { |
| if tt.setup != nil { |
| tt.setup(t, &tt.fields) |
| } |
| c := &connectionContainer{ |
| log: testutils.ProduceTestingLogger(t), |
| lock: tt.fields.lock, |
| connectionString: tt.fields.connectionString, |
| driverManager: tt.fields.driverManager, |
| tracerEnabled: tt.fields.tracerEnabled, |
| connection: tt.fields.connection, |
| leaseCounter: tt.fields.leaseCounter, |
| closed: tt.fields.closed, |
| state: tt.fields.state, |
| queue: tt.fields.queue, |
| listeners: tt.fields.listeners, |
| } |
| c.connect(testutils.TestContext(t)) |
| }) |
| } |
| } |
| |
| func Test_connectionContainer_lease(t1 *testing.T) { |
| type fields struct { |
| lock lock.RWMutex |
| connectionString string |
| driverManager plc4go.PlcDriverManager |
| tracerEnabled bool |
| connection tracedPlcConnection |
| leaseCounter uint32 |
| closed bool |
| state cachedPlcConnectionState |
| queue []chan plc4go.PlcConnectionConnectResult |
| listeners []connectionListener |
| } |
| tests := []struct { |
| name string |
| fields fields |
| setup func(t *testing.T, fields *fields) |
| wantNotNil bool |
| }{ |
| { |
| name: "lease fresh", |
| fields: fields{ |
| connectionString: "simulated://1.2.3.4:42", |
| lock: lock.NewCASMutex(), |
| queue: []chan plc4go.PlcConnectionConnectResult{}, |
| }, |
| setup: func(t *testing.T, fields *fields) { |
| logger := testutils.ProduceTestingLogger(t) |
| |
| driverManager := plc4go.NewPlcDriverManager(config.WithCustomLogger(logger)) |
| t.Cleanup(func() { |
| assert.NoError(t, driverManager.Close()) |
| }) |
| driverManager.RegisterDriver(simulated.NewDriver(options.WithCustomLogger(logger))) |
| fields.driverManager = driverManager |
| }, |
| wantNotNil: true, |
| }, |
| } |
| for _, tt := range tests { |
| t1.Run(tt.name, func(t *testing.T) { |
| if tt.setup != nil { |
| tt.setup(t, &tt.fields) |
| } |
| c := &connectionContainer{ |
| log: testutils.ProduceTestingLogger(t), |
| lock: tt.fields.lock, |
| connectionString: tt.fields.connectionString, |
| driverManager: tt.fields.driverManager, |
| tracerEnabled: tt.fields.tracerEnabled, |
| connection: tt.fields.connection, |
| leaseCounter: tt.fields.leaseCounter, |
| closed: tt.fields.closed, |
| state: tt.fields.state, |
| queue: tt.fields.queue, |
| listeners: tt.fields.listeners, |
| } |
| assert.True(t1, tt.wantNotNil, c.lease(), "lease()") |
| }) |
| } |
| } |
| |
| func Test_connectionContainer_returnConnection(t1 *testing.T) { |
| type fields struct { |
| lock lock.RWMutex |
| connectionString string |
| driverManager plc4go.PlcDriverManager |
| tracerEnabled bool |
| connection tracedPlcConnection |
| leaseCounter uint32 |
| closed bool |
| state cachedPlcConnectionState |
| queue []chan plc4go.PlcConnectionConnectResult |
| listeners []connectionListener |
| } |
| type args struct { |
| state cachedPlcConnectionState |
| } |
| tests := []struct { |
| name string |
| fields fields |
| args args |
| setup func(t *testing.T, fields *fields, args *args) |
| wantErr assert.ErrorAssertionFunc |
| }{ |
| { |
| name: "return connection fresh", |
| fields: fields{ |
| connectionString: "simulated://1.2.3.4:42", |
| lock: lock.NewCASMutex(), |
| queue: []chan plc4go.PlcConnectionConnectResult{}, |
| }, |
| args: args{ |
| state: StateInitialized, |
| }, |
| setup: func(t *testing.T, fields *fields, args *args) { |
| logger := testutils.ProduceTestingLogger(t) |
| |
| driverManager := plc4go.NewPlcDriverManager(config.WithCustomLogger(logger)) |
| t.Cleanup(func() { |
| assert.NoError(t, driverManager.Close()) |
| }) |
| driverManager.RegisterDriver(simulated.NewDriver(options.WithCustomLogger(logger))) |
| fields.driverManager = driverManager |
| }, |
| wantErr: assert.NoError, |
| }, |
| { |
| name: "return unconnected connection", |
| fields: fields{ |
| connectionString: "simulated://1.2.3.4:42", |
| lock: lock.NewCASMutex(), |
| queue: []chan plc4go.PlcConnectionConnectResult{}, |
| }, |
| args: args{ |
| state: StateInUse, |
| }, |
| setup: func(t *testing.T, fields *fields, args *args) { |
| logger := testutils.ProduceTestingLogger(t) |
| |
| driverManager := plc4go.NewPlcDriverManager(config.WithCustomLogger(logger)) |
| t.Cleanup(func() { |
| assert.NoError(t, driverManager.Close()) |
| }) |
| driverManager.RegisterDriver(simulated.NewDriver(options.WithCustomLogger(logger))) |
| fields.driverManager = driverManager |
| }, |
| wantErr: assert.Error, |
| }, |
| } |
| for _, tt := range tests { |
| t1.Run(tt.name, func(t *testing.T) { |
| if tt.setup != nil { |
| tt.setup(t, &tt.fields, &tt.args) |
| } |
| c := &connectionContainer{ |
| log: testutils.ProduceTestingLogger(t), |
| lock: tt.fields.lock, |
| connectionString: tt.fields.connectionString, |
| driverManager: tt.fields.driverManager, |
| tracerEnabled: tt.fields.tracerEnabled, |
| connection: tt.fields.connection, |
| leaseCounter: tt.fields.leaseCounter, |
| closed: tt.fields.closed, |
| state: tt.fields.state, |
| queue: tt.fields.queue, |
| listeners: tt.fields.listeners, |
| } |
| tt.wantErr(t1, c.returnConnection(testutils.TestContext(t), tt.args.state), fmt.Sprintf("returnConnection(%v)", tt.args.state)) |
| }) |
| } |
| } |