- Fix CLI operation not setting DNS server - Fix periodic operation not setting DNS server - Set DNS address for resolution once at start for both CLI and periodic operation - Inject resolver to each provider instead of creating it within - Use resolver settings on every call to `.Resolve` method, instead of passing it to constructor - Move out minServers check from resolver
113 lines
3.0 KiB
Go
113 lines
3.0 KiB
Go
package expressvpn
|
|
|
|
import (
|
|
"errors"
|
|
"math/rand"
|
|
"net"
|
|
"testing"
|
|
|
|
"github.com/golang/mock/gomock"
|
|
"github.com/qdm12/gluetun/internal/configuration/settings"
|
|
"github.com/qdm12/gluetun/internal/constants"
|
|
"github.com/qdm12/gluetun/internal/constants/providers"
|
|
"github.com/qdm12/gluetun/internal/constants/vpn"
|
|
"github.com/qdm12/gluetun/internal/models"
|
|
"github.com/qdm12/gluetun/internal/provider/common"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func Test_Provider_GetConnection(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
const provider = providers.Expressvpn
|
|
|
|
errTest := errors.New("test error")
|
|
boolPtr := func(b bool) *bool { return &b }
|
|
|
|
testCases := map[string]struct {
|
|
filteredServers []models.Server
|
|
storageErr error
|
|
selection settings.ServerSelection
|
|
connection models.Connection
|
|
errWrapped error
|
|
errMessage string
|
|
panicMessage string
|
|
}{
|
|
"error": {
|
|
storageErr: errTest,
|
|
errWrapped: errTest,
|
|
errMessage: "cannot filter servers: test error",
|
|
},
|
|
"default OpenVPN TCP port": {
|
|
filteredServers: []models.Server{
|
|
{IPs: []net.IP{net.IPv4(1, 1, 1, 1)}},
|
|
},
|
|
selection: settings.ServerSelection{
|
|
OpenVPN: settings.OpenVPNSelection{
|
|
TCP: boolPtr(true),
|
|
},
|
|
}.WithDefaults(provider),
|
|
panicMessage: "no default OpenVPN TCP port is defined!",
|
|
},
|
|
"default OpenVPN UDP port": {
|
|
filteredServers: []models.Server{
|
|
{IPs: []net.IP{net.IPv4(1, 1, 1, 1)}},
|
|
},
|
|
selection: settings.ServerSelection{
|
|
OpenVPN: settings.OpenVPNSelection{
|
|
TCP: boolPtr(false),
|
|
},
|
|
}.WithDefaults(provider),
|
|
connection: models.Connection{
|
|
Type: vpn.OpenVPN,
|
|
IP: net.IPv4(1, 1, 1, 1),
|
|
Port: 1195,
|
|
Protocol: constants.UDP,
|
|
},
|
|
},
|
|
"default Wireguard port": {
|
|
filteredServers: []models.Server{
|
|
{IPs: []net.IP{net.IPv4(1, 1, 1, 1)}},
|
|
},
|
|
selection: settings.ServerSelection{
|
|
VPN: vpn.Wireguard,
|
|
}.WithDefaults(provider),
|
|
panicMessage: "no default Wireguard port is defined!",
|
|
},
|
|
}
|
|
|
|
for name, testCase := range testCases {
|
|
testCase := testCase
|
|
t.Run(name, func(t *testing.T) {
|
|
t.Parallel()
|
|
ctrl := gomock.NewController(t)
|
|
|
|
storage := common.NewMockStorage(ctrl)
|
|
storage.EXPECT().FilterServers(provider, testCase.selection).
|
|
Return(testCase.filteredServers, testCase.storageErr)
|
|
randSource := rand.NewSource(0)
|
|
|
|
unzipper := (common.Unzipper)(nil)
|
|
warner := (common.Warner)(nil)
|
|
parallelResolver := (common.ParallelResolver)(nil)
|
|
provider := New(storage, randSource, unzipper, warner, parallelResolver)
|
|
|
|
if testCase.panicMessage != "" {
|
|
assert.PanicsWithValue(t, testCase.panicMessage, func() {
|
|
_, _ = provider.GetConnection(testCase.selection)
|
|
})
|
|
return
|
|
}
|
|
|
|
connection, err := provider.GetConnection(testCase.selection)
|
|
|
|
assert.ErrorIs(t, err, testCase.errWrapped)
|
|
if testCase.errWrapped != nil {
|
|
assert.EqualError(t, err, testCase.errMessage)
|
|
}
|
|
|
|
assert.Equal(t, testCase.connection, connection)
|
|
})
|
|
}
|
|
}
|