2020-04-12 08:55:13 -04:00
|
|
|
package routing
|
|
|
|
|
|
|
|
|
|
import (
|
2020-04-19 18:13:48 +00:00
|
|
|
"context"
|
2020-04-12 08:55:13 -04:00
|
|
|
"fmt"
|
|
|
|
|
"net"
|
|
|
|
|
"testing"
|
|
|
|
|
|
2020-04-12 18:09:46 +00:00
|
|
|
"github.com/golang/mock/gomock"
|
2020-07-26 12:07:06 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
2020-04-12 18:09:46 +00:00
|
|
|
"github.com/qdm12/golibs/command/mock_command"
|
2020-07-11 21:03:55 +00:00
|
|
|
"github.com/qdm12/golibs/files/mock_files"
|
|
|
|
|
"github.com/qdm12/golibs/logging/mock_logging"
|
2020-04-12 08:55:13 -04:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
2020-07-11 21:03:55 +00:00
|
|
|
func Test_DeleteRouteVia(t *testing.T) {
|
2020-04-12 08:55:13 -04:00
|
|
|
t.Parallel()
|
2020-07-11 21:03:55 +00:00
|
|
|
ctx := context.Background()
|
2020-04-12 08:55:13 -04:00
|
|
|
tests := map[string]struct {
|
|
|
|
|
subnet net.IPNet
|
|
|
|
|
runOutput string
|
|
|
|
|
runErr error
|
|
|
|
|
err error
|
|
|
|
|
}{
|
|
|
|
|
"no output no error": {
|
|
|
|
|
subnet: net.IPNet{
|
2020-07-11 21:03:55 +00:00
|
|
|
IP: net.IP{192, 168, 2, 0},
|
2020-04-12 08:55:13 -04:00
|
|
|
Mask: net.IPMask{255, 255, 255, 0},
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
"error only": {
|
|
|
|
|
subnet: net.IPNet{
|
2020-07-11 21:03:55 +00:00
|
|
|
IP: net.IP{192, 168, 2, 0},
|
2020-04-12 08:55:13 -04:00
|
|
|
Mask: net.IPMask{255, 255, 255, 0},
|
|
|
|
|
},
|
|
|
|
|
runErr: fmt.Errorf("error"),
|
2020-07-11 21:03:55 +00:00
|
|
|
err: fmt.Errorf("cannot delete route for 192.168.2.0/24: : error"),
|
2020-04-12 08:55:13 -04:00
|
|
|
},
|
|
|
|
|
"error and output": {
|
|
|
|
|
subnet: net.IPNet{
|
2020-07-11 21:03:55 +00:00
|
|
|
IP: net.IP{192, 168, 2, 0},
|
2020-04-12 08:55:13 -04:00
|
|
|
Mask: net.IPMask{255, 255, 255, 0},
|
|
|
|
|
},
|
|
|
|
|
runErr: fmt.Errorf("error"),
|
|
|
|
|
runOutput: "output",
|
2020-07-11 21:03:55 +00:00
|
|
|
err: fmt.Errorf("cannot delete route for 192.168.2.0/24: output: error"),
|
2020-04-12 08:55:13 -04:00
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
mockCtrl := gomock.NewController(t)
|
|
|
|
|
defer mockCtrl.Finish()
|
|
|
|
|
|
2020-07-11 21:03:55 +00:00
|
|
|
subnetStr := tc.subnet.String()
|
|
|
|
|
|
|
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
|
|
|
|
logger.EXPECT().Info("deleting route for %s")
|
|
|
|
|
commander := mock_command.NewMockCommander(mockCtrl)
|
|
|
|
|
commander.EXPECT().Run(ctx, "ip", "route", "del", subnetStr).
|
2020-04-12 08:55:13 -04:00
|
|
|
Return(tc.runOutput, tc.runErr).Times(1)
|
2020-07-11 21:03:55 +00:00
|
|
|
fileManager := mock_files.NewMockFileManager(mockCtrl)
|
|
|
|
|
routesData := []byte(`Iface Destination Gateway Flags RefCnt Use Metric Mask MTU Window IRTT
|
|
|
|
|
eth0 0002A8C0 0100000A 0003 0 0 0 00FFFFFF 0 0 0
|
|
|
|
|
`)
|
|
|
|
|
fileManager.EXPECT().ReadFile(string(constants.NetRoute)).Return(routesData, nil)
|
|
|
|
|
r := &routing{
|
|
|
|
|
logger: logger,
|
|
|
|
|
commander: commander,
|
|
|
|
|
fileManager: fileManager,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := r.DeleteRouteVia(ctx, tc.subnet)
|
2020-04-12 08:55:13 -04:00
|
|
|
if tc.err != nil {
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
assert.Equal(t, tc.err.Error(), err.Error())
|
|
|
|
|
} else {
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|