blob: aee998f812f193de92e3852a7e16a06b1f40f891 [file] [log] [blame]
/*
* Copyright 2022-present Open Networking Foundation
* Licensed 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
*
* http://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 controller
import (
"context"
"reflect"
"testing"
"voltha-go-controller/internal/pkg/of"
"voltha-go-controller/internal/test/mocks"
"github.com/golang/mock/gomock"
)
func Test_isFlowOperSuccess(t *testing.T) {
type args struct {
statusCode uint32
oper of.Command
}
tests := []struct {
name string
args args
want bool
}{
{
name: "test",
args: args{
statusCode: uint32(1004),
oper: of.CommandAdd,
},
want: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := isFlowOperSuccess(tt.args.statusCode, tt.args.oper); got != tt.want {
t.Errorf("isFlowOperSuccess() = %v, want %v", got, tt.want)
}
})
}
}
func TestAddFlowsTask_Start(t *testing.T) {
type args struct {
ctx context.Context
taskID uint8
}
tests := []struct {
name string
args args
wantErr bool
}{
{
name: "AddFlowsTask_Start",
args: args{
ctx: context.Background(),
taskID: 0,
},
wantErr: false,
},
{
name: "DeleteFlowsTask_Start",
args: args{
ctx: context.Background(),
taskID: 0,
},
wantErr: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
switch tt.name {
case "AddFlowsTask_Start":
subFlows := map[uint64]*of.VoltSubFlow{}
vltSubFlow := &of.VoltSubFlow{
Priority: 100,
Cookie: 103112802816,
State: of.FlowAddSuccess,
Match: of.Match{
InPort: 1573376,
MatchVlan: 4096,
L4Protocol: 255,
},
Action: of.Action{
Metadata: 279189651712,
GoToTableID: 1,
MeterID: 1,
SetVlan: 4097,
Pcp: 8,
Output: 4,
},
}
subFlows[0] = vltSubFlow
portsByID := map[uint32]*DevicePort{}
portsByID[256] = &DevicePort{
Name: "SDX6320031",
ID: 256,
}
device := &Device{
flows: subFlows,
PortsByID: portsByID,
}
flow := &of.VoltFlow{
SubFlows: subFlows,
PortName: "SDX6320031-1",
PortID: 256,
Command: 0,
}
aft := &AddFlowsTask{
flow: flow,
device: device,
}
dbintf := mocks.NewMockDBIntf(gomock.NewController(t))
db = dbintf
dbintf.EXPECT().PutFlow(gomock.Any(), gomock.Any(), gomock.Any(), gomock.Any()).Return(nil).AnyTimes()
if err := aft.Start(tt.args.ctx, tt.args.taskID); (err != nil) != tt.wantErr {
t.Errorf("AddFlowsTask.Start() error = %v, wantErr %v", err, tt.wantErr)
}
case "DeleteFlowsTask_Start":
subFlows := map[uint64]*of.VoltSubFlow{}
vltSubFlow := &of.VoltSubFlow{
Priority: 100,
Cookie: 103112802816,
State: of.FlowAddSuccess,
Match: of.Match{
InPort: 1573376,
MatchVlan: 4096,
L4Protocol: 255,
},
Action: of.Action{
Metadata: 279189651712,
GoToTableID: 1,
MeterID: 1,
SetVlan: 4097,
Pcp: 8,
Output: 4,
},
}
subFlows[0] = vltSubFlow
portsByID := map[uint32]*DevicePort{}
portsByID[256] = &DevicePort{
Name: "SDX6320031",
ID: 256,
}
device := &Device{
flows: subFlows,
PortsByID: portsByID,
}
flow := &of.VoltFlow{
SubFlows: subFlows,
PortName: "SDX6320031-1",
PortID: 256,
Command: 1,
}
aft := &AddFlowsTask{
flow: flow,
device: device,
}
appMock := mocks.NewMockApp(gomock.NewController(t))
NewController(ctx, appMock)
appMock.EXPECT().ProcessFlowModResultIndication(gomock.Any(), gomock.Any()).AnyTimes()
dbintf := mocks.NewMockDBIntf(gomock.NewController(t))
db = dbintf
dbintf.EXPECT().DelFlow(gomock.Any(), gomock.Any(), gomock.Any()).Return(nil).AnyTimes()
if err := aft.Start(tt.args.ctx, tt.args.taskID); (err != nil) != tt.wantErr {
t.Errorf("AddFlowsTask.Start() error = %v, wantErr %v", err, tt.wantErr)
}
}
})
}
}
func TestNewAddFlowsTask(t *testing.T) {
type args struct {
ctx context.Context
flow *of.VoltFlow
device *Device
}
flow := &of.VoltFlow{
PortName: "SDX6320031-1",
PortID: 256,
Command: 0,
}
portsByID := map[uint32]*DevicePort{}
portsByID[256] = &DevicePort{
Name: "SDX6320031",
ID: 256,
}
device := &Device{
PortsByID: portsByID,
}
tests := []struct {
name string
args args
want *AddFlowsTask
}{
{
name: "NewAddFlowsTask",
args: args{
ctx: context.Background(),
flow: flow,
device: device,
},
want: &AddFlowsTask{
ctx: context.Background(),
flow: flow,
device: device,
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := NewAddFlowsTask(tt.args.ctx, tt.args.flow, tt.args.device); reflect.DeepEqual(got, tt.want) {
t.Errorf("NewAddFlowsTask() = %v, want %v", got, tt.want)
}
})
}
}