Files
mattermost/app/download_test.go
Sayantan Das 288ed40e8f Retry on failed download of plugins from marketplace. (#14176)
* Retry on failed download of plugins from marketplace.

* minor polishing.

* Handling http errors during downloading
Adding unit test for DownloadFromURL

* Adding suggested changes from the PR
Close response body before returning error during progressive retry
Remove separate struct for the downloadURL parameter in download_test
Adding comment to clarify the share retries variable
Changing to NoError and Error in the test assertion.

* Added license header to download_test.go

Co-authored-by: mattermod <mattermod@users.noreply.github.com>
2020-05-13 08:36:43 +05:30

73 lines
1.7 KiB
Go

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
package app
import (
"fmt"
"github.com/mattermost/mattermost-server/v5/model"
"github.com/stretchr/testify/require"
"net/http"
"net/http/httptest"
"testing"
)
func TestDownloadFromURL(t *testing.T) {
th := Setup(t).InitBasic()
defer th.TearDown()
app := th.App
app.Config().PluginSettings.AllowInsecureDownloadUrl = model.NewBool(true)
// To keep track of how many times an endpoint is retried. This needs to be reset
// for each test run.
retries := 0
mux := http.NewServeMux()
mux.HandleFunc("/succeeds-after-retry", func(w http.ResponseWriter, r *http.Request) {
if retries < 2 {
http.Error(w, "Request Timed out", http.StatusGatewayTimeout)
retries++
return
}
_, _ = w.Write([]byte("Your request is successful."))
})
mux.HandleFunc("/fails-forever", func(w http.ResponseWriter, r *http.Request) {
http.Error(w, "This would fail forever", http.StatusInternalServerError)
})
testServer := httptest.NewServer(mux)
tests := []struct {
name string
downloadURL string
wantErr bool
}{
{
name: "Should succeed after two retries",
downloadURL: fmt.Sprintf("%s/succeeds-after-retry", testServer.URL),
wantErr: false,
},
{
name: "Should not retry forever",
downloadURL: fmt.Sprintf("%s/fails-forever", testServer.URL),
wantErr: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
retries = 0 // reset the retires
_, err := th.App.DownloadFromURL(tt.downloadURL)
if tt.wantErr {
require.Error(t, err)
} else {
require.NoError(t, err)
}
})
}
}