2020-02-06 20:42:46 -05:00
|
|
|
package dns
|
|
|
|
|
|
|
|
|
|
import (
|
2020-10-18 02:24:34 +00:00
|
|
|
"context"
|
2020-12-29 00:55:31 +00:00
|
|
|
"errors"
|
2020-02-06 20:42:46 -05:00
|
|
|
"fmt"
|
|
|
|
|
"net/http"
|
|
|
|
|
"testing"
|
|
|
|
|
|
2020-04-12 18:09:46 +00:00
|
|
|
"github.com/golang/mock/gomock"
|
2020-10-20 02:45:28 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/constants"
|
2020-12-29 00:55:31 +00:00
|
|
|
"github.com/qdm12/gluetun/internal/os"
|
|
|
|
|
"github.com/qdm12/gluetun/internal/os/mock_os"
|
2020-04-12 18:09:46 +00:00
|
|
|
"github.com/qdm12/golibs/logging/mock_logging"
|
|
|
|
|
"github.com/qdm12/golibs/network/mock_network"
|
2020-02-06 20:42:46 -05:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
)
|
|
|
|
|
|
2020-12-29 00:55:31 +00:00
|
|
|
func Test_downloadAndSave(t *testing.T) {
|
2020-02-06 20:42:46 -05:00
|
|
|
t.Parallel()
|
|
|
|
|
tests := map[string]struct {
|
|
|
|
|
content []byte
|
|
|
|
|
status int
|
|
|
|
|
clientErr error
|
2020-12-29 00:55:31 +00:00
|
|
|
openErr error
|
2020-02-06 20:42:46 -05:00
|
|
|
writeErr error
|
2020-12-29 00:55:31 +00:00
|
|
|
chownErr error
|
|
|
|
|
closeErr error
|
2020-02-06 20:42:46 -05:00
|
|
|
err error
|
|
|
|
|
}{
|
|
|
|
|
"no data": {
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
},
|
|
|
|
|
"bad status": {
|
|
|
|
|
status: http.StatusBadRequest,
|
2020-10-20 02:45:28 +00:00
|
|
|
err: fmt.Errorf("HTTP status code is 400 for https://raw.githubusercontent.com/qdm12/files/master/named.root.updated"), //nolint:lll
|
2020-02-06 20:42:46 -05:00
|
|
|
},
|
|
|
|
|
"client error": {
|
|
|
|
|
clientErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
2020-12-29 00:55:31 +00:00
|
|
|
"open error": {
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
openErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
2020-02-06 20:42:46 -05:00
|
|
|
"write error": {
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
writeErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
2020-12-29 00:55:31 +00:00
|
|
|
"chown error": {
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
chownErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
|
|
|
|
"close error": {
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
closeErr: fmt.Errorf("error"),
|
|
|
|
|
err: fmt.Errorf("error"),
|
|
|
|
|
},
|
2020-02-06 20:42:46 -05:00
|
|
|
"data": {
|
|
|
|
|
content: []byte("content"),
|
|
|
|
|
status: http.StatusOK,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
2020-04-12 18:09:46 +00:00
|
|
|
mockCtrl := gomock.NewController(t)
|
2020-12-29 00:55:31 +00:00
|
|
|
|
2020-10-18 02:24:34 +00:00
|
|
|
ctx := context.Background()
|
2020-04-12 18:09:46 +00:00
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
2020-12-29 00:55:31 +00:00
|
|
|
logger.EXPECT().Info("downloading %s from %s", "root hints", string(constants.NamedRootURL))
|
2020-04-12 18:09:46 +00:00
|
|
|
client := mock_network.NewMockClient(mockCtrl)
|
2020-10-18 02:24:34 +00:00
|
|
|
client.EXPECT().Get(ctx, string(constants.NamedRootURL)).
|
2020-12-28 01:52:30 +00:00
|
|
|
Return(tc.content, tc.status, tc.clientErr)
|
2020-12-29 00:55:31 +00:00
|
|
|
|
|
|
|
|
openFile := func(name string, flag int, perm os.FileMode) (os.File, error) {
|
|
|
|
|
return nil, nil
|
|
|
|
|
}
|
|
|
|
|
|
2020-02-06 20:42:46 -05:00
|
|
|
if tc.clientErr == nil && tc.status == http.StatusOK {
|
2020-12-29 00:55:31 +00:00
|
|
|
file := mock_os.NewMockFile(mockCtrl)
|
|
|
|
|
if tc.openErr == nil {
|
|
|
|
|
writeCall := file.EXPECT().Write(tc.content).
|
|
|
|
|
Return(0, tc.writeErr)
|
|
|
|
|
if tc.writeErr != nil {
|
|
|
|
|
file.EXPECT().Close().Return(tc.closeErr).After(writeCall)
|
|
|
|
|
} else {
|
|
|
|
|
chownCall := file.EXPECT().Chown(1000, 1000).Return(tc.chownErr).After(writeCall)
|
|
|
|
|
file.EXPECT().Close().Return(tc.closeErr).After(chownCall)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
openFile = func(name string, flag int, perm os.FileMode) (os.File, error) {
|
|
|
|
|
assert.Equal(t, string(constants.RootHints), name)
|
|
|
|
|
assert.Equal(t, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, flag)
|
|
|
|
|
assert.Equal(t, os.FileMode(0400), perm)
|
|
|
|
|
return file, tc.openErr
|
|
|
|
|
}
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
2020-12-29 00:55:31 +00:00
|
|
|
|
|
|
|
|
c := &configurator{
|
|
|
|
|
logger: logger,
|
|
|
|
|
client: client,
|
|
|
|
|
openFile: openFile,
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
err := c.downloadAndSave(ctx, "root hints",
|
|
|
|
|
string(constants.NamedRootURL), string(constants.RootHints),
|
|
|
|
|
1000, 1000)
|
|
|
|
|
|
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)
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-29 00:55:31 +00:00
|
|
|
func Test_DownloadRootHints(t *testing.T) {
|
2020-02-06 20:42:46 -05:00
|
|
|
t.Parallel()
|
2020-12-29 00:55:31 +00:00
|
|
|
mockCtrl := gomock.NewController(t)
|
|
|
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
|
|
|
|
logger.EXPECT().Info("downloading %s from %s", "root hints", string(constants.NamedRootURL))
|
|
|
|
|
client := mock_network.NewMockClient(mockCtrl)
|
|
|
|
|
client.EXPECT().Get(ctx, string(constants.NamedRootURL)).
|
|
|
|
|
Return(nil, http.StatusOK, errors.New("test"))
|
|
|
|
|
|
|
|
|
|
c := &configurator{
|
|
|
|
|
logger: logger,
|
|
|
|
|
client: client,
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
2020-12-29 00:55:31 +00:00
|
|
|
|
|
|
|
|
err := c.DownloadRootHints(ctx, 1000, 1000)
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
assert.Equal(t, "test", err.Error())
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Test_DownloadRootKey(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
mockCtrl := gomock.NewController(t)
|
|
|
|
|
|
|
|
|
|
ctx := context.Background()
|
|
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
|
|
|
|
logger.EXPECT().Info("downloading %s from %s", "root key", string(constants.RootKeyURL))
|
|
|
|
|
client := mock_network.NewMockClient(mockCtrl)
|
|
|
|
|
client.EXPECT().Get(ctx, string(constants.RootKeyURL)).
|
|
|
|
|
Return(nil, http.StatusOK, errors.New("test"))
|
|
|
|
|
|
|
|
|
|
c := &configurator{
|
|
|
|
|
logger: logger,
|
|
|
|
|
client: client,
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
2020-12-29 00:55:31 +00:00
|
|
|
|
|
|
|
|
err := c.DownloadRootKey(ctx, 1000, 1000)
|
|
|
|
|
require.Error(t, err)
|
|
|
|
|
assert.Equal(t, "test", err.Error())
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|