2020-02-06 20:42:46 -05:00
|
|
|
package dns
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
2020-02-08 17:47:25 +00:00
|
|
|
"net"
|
2020-02-06 20:42:46 -05:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
filesmocks "github.com/qdm12/golibs/files/mocks"
|
|
|
|
|
loggingmocks "github.com/qdm12/golibs/logging/mocks"
|
|
|
|
|
"github.com/qdm12/private-internet-access-docker/internal/constants"
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
2020-02-08 17:47:25 +00:00
|
|
|
func Test_UseDNSSystemWide(t *testing.T) {
|
2020-02-06 20:42:46 -05:00
|
|
|
t.Parallel()
|
|
|
|
|
tests := map[string]struct {
|
|
|
|
|
data []byte
|
|
|
|
|
writtenData []byte
|
|
|
|
|
readErr error
|
|
|
|
|
writeErr error
|
|
|
|
|
err error
|
|
|
|
|
}{
|
|
|
|
|
"no data": {
|
|
|
|
|
writtenData: []byte("nameserver 127.0.0.1"),
|
|
|
|
|
},
|
|
|
|
|
"read error": {
|
|
|
|
|
readErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
|
|
|
|
"write error": {
|
|
|
|
|
writtenData: []byte("nameserver 127.0.0.1"),
|
|
|
|
|
writeErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
|
|
|
|
"lines without nameserver": {
|
|
|
|
|
data: []byte("abc\ndef\n"),
|
|
|
|
|
writtenData: []byte("abc\ndef\nnameserver 127.0.0.1"),
|
|
|
|
|
},
|
|
|
|
|
"lines with nameserver": {
|
|
|
|
|
data: []byte("abc\nnameserver abc def\ndef\n"),
|
|
|
|
|
writtenData: []byte("abc\nnameserver 127.0.0.1\ndef"),
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
fileManager := &filesmocks.FileManager{}
|
|
|
|
|
fileManager.On("ReadFile", string(constants.ResolvConf)).
|
|
|
|
|
Return(tc.data, tc.readErr).Once()
|
|
|
|
|
if tc.readErr == nil {
|
|
|
|
|
fileManager.On("WriteToFile", string(constants.ResolvConf), tc.writtenData).
|
|
|
|
|
Return(tc.writeErr).Once()
|
|
|
|
|
}
|
|
|
|
|
logger := &loggingmocks.Logger{}
|
2020-02-08 17:47:25 +00:00
|
|
|
logger.On("Info", "%s: using DNS address %s system wide", logPrefix, "127.0.0.1").Once()
|
2020-02-06 20:42:46 -05:00
|
|
|
c := &configurator{
|
|
|
|
|
fileManager: fileManager,
|
|
|
|
|
logger: logger,
|
|
|
|
|
}
|
2020-02-08 17:47:25 +00:00
|
|
|
err := c.UseDNSSystemWide(net.IP{127, 0, 0, 1})
|
2020-02-06 20:42:46 -05:00
|
|
|
if tc.err != nil {
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
assert.Equal(t, tc.err.Error(), err.Error())
|
|
|
|
|
} else {
|
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
}
|
|
|
|
|
fileManager.AssertExpectations(t)
|
|
|
|
|
logger.AssertExpectations(t)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|