2021-03-16 10:57:48 +00:00
|
|
|
package backend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"io"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewHTTPReader(t *testing.T) {
|
|
|
|
type args struct {
|
2021-03-16 15:21:28 +00:00
|
|
|
url string
|
|
|
|
options *Options
|
2021-03-16 10:57:48 +00:00
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
|
|
|
wantURL string
|
2021-04-06 10:58:48 +00:00
|
|
|
wantErr error
|
2021-03-16 10:57:48 +00:00
|
|
|
}{
|
|
|
|
{
|
2021-03-16 15:21:28 +00:00
|
|
|
name: "Should fail with wrong URL",
|
2021-03-16 10:57:48 +00:00
|
|
|
args: args{
|
|
|
|
url: "wrong_url",
|
2021-03-16 15:21:28 +00:00
|
|
|
options: &Options{
|
|
|
|
Headers: map[string]string{},
|
|
|
|
},
|
2021-03-16 10:57:48 +00:00
|
|
|
},
|
|
|
|
wantURL: "",
|
2021-04-06 10:58:48 +00:00
|
|
|
wantErr: errors.New("Get \"wrong_url\": unsupported protocol scheme \"\""),
|
2021-03-16 10:57:48 +00:00
|
|
|
},
|
|
|
|
{
|
2021-03-16 15:21:28 +00:00
|
|
|
name: "Should fetch URL with auth header",
|
2021-03-16 10:57:48 +00:00
|
|
|
args: args{
|
|
|
|
url: "https://raw.githubusercontent.com/cloudskiff/driftctl/main/.dockerignore",
|
2021-03-16 15:21:28 +00:00
|
|
|
options: &Options{
|
|
|
|
Headers: map[string]string{
|
|
|
|
"Authorization": "Basic Test",
|
|
|
|
},
|
|
|
|
},
|
2021-03-16 10:57:48 +00:00
|
|
|
},
|
|
|
|
wantURL: "https://raw.githubusercontent.com/cloudskiff/driftctl/main/.dockerignore",
|
2021-04-06 10:58:48 +00:00
|
|
|
wantErr: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "Should fail with bad status code",
|
|
|
|
args: args{
|
|
|
|
url: "https://raw.githubusercontent.com/cloudskiff/driftctl-test/main/.dockerignore",
|
|
|
|
options: &Options{
|
|
|
|
Headers: map[string]string{},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantURL: "https://raw.githubusercontent.com/cloudskiff/driftctl-badprojecturl",
|
2021-04-07 13:12:30 +00:00
|
|
|
wantErr: errors.New("error requesting HTTP(s) backend state: status code: 404"),
|
2021-03-16 10:57:48 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2021-03-16 15:21:28 +00:00
|
|
|
got, err := NewHTTPReader(tt.args.url, tt.args.options)
|
2021-04-06 10:58:48 +00:00
|
|
|
if tt.wantErr != nil {
|
|
|
|
assert.EqualError(t, err, tt.wantErr.Error())
|
2021-03-16 10:57:48 +00:00
|
|
|
return
|
|
|
|
} else {
|
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
assert.NotNil(t, got)
|
|
|
|
assert.Equal(t, tt.wantURL, got.url)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHTTPBackend_Close(t *testing.T) {
|
|
|
|
type fields struct {
|
|
|
|
url string
|
|
|
|
reader func() io.ReadCloser
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields fields
|
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "should fail to close reader",
|
|
|
|
fields: fields{
|
|
|
|
url: "",
|
|
|
|
reader: func() io.ReadCloser {
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "should close reader",
|
|
|
|
fields: fields{
|
|
|
|
url: "",
|
|
|
|
reader: func() io.ReadCloser {
|
|
|
|
m := &MockReaderMock{}
|
|
|
|
m.On("Close").Return(nil)
|
|
|
|
return m
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
h := &HTTPBackend{
|
|
|
|
url: tt.fields.url,
|
|
|
|
reader: tt.fields.reader(),
|
|
|
|
}
|
|
|
|
if err := h.Close(); (err != nil) != tt.wantErr {
|
|
|
|
t.Errorf("Close() error = %v, wantErr %v", err, tt.wantErr)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHTTPBackend_Read(t *testing.T) {
|
|
|
|
type fields struct {
|
|
|
|
url string
|
|
|
|
reader func() io.ReadCloser
|
|
|
|
}
|
|
|
|
type args struct {
|
|
|
|
p []byte
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
fields fields
|
|
|
|
args args
|
|
|
|
wantN int
|
|
|
|
wantErr error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "should fail to read because of nil reader",
|
|
|
|
fields: fields{
|
|
|
|
url: "",
|
|
|
|
reader: func() io.ReadCloser {
|
|
|
|
return nil
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: errors.New("Reader not initialized"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "should fail to read",
|
|
|
|
fields: fields{
|
|
|
|
url: "",
|
|
|
|
reader: func() io.ReadCloser {
|
|
|
|
m := &MockReaderMock{}
|
|
|
|
m.On("Read", mock.Anything).Return(0, errors.New("test"))
|
|
|
|
return m
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: errors.New("test"),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "should read",
|
|
|
|
fields: fields{
|
|
|
|
url: "",
|
|
|
|
reader: func() io.ReadCloser {
|
|
|
|
m := &MockReaderMock{}
|
|
|
|
m.On("Read", mock.Anything).Return(0, nil)
|
|
|
|
return m
|
|
|
|
},
|
|
|
|
},
|
|
|
|
wantErr: nil,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
h := &HTTPBackend{
|
|
|
|
url: tt.fields.url,
|
|
|
|
reader: tt.fields.reader(),
|
|
|
|
}
|
|
|
|
gotN, err := h.Read(tt.args.p)
|
|
|
|
|
|
|
|
if tt.wantErr != nil {
|
|
|
|
assert.EqualError(t, err, tt.wantErr.Error())
|
|
|
|
} else {
|
|
|
|
assert.NoError(t, err)
|
|
|
|
}
|
|
|
|
if gotN != tt.wantN {
|
|
|
|
t.Errorf("Read() gotN = %v, want %v", gotN, tt.wantN)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|