Skip to content
This repository has been archived by the owner on Dec 20, 2024. It is now read-only.

Commit

Permalink
fix: checkStatusCode after download
Browse files Browse the repository at this point in the history
Signed-off-by: 慕陶 <[email protected]>
  • Loading branch information
慕陶 committed Jan 15, 2020
1 parent 0f1a3a5 commit 2dee5c0
Show file tree
Hide file tree
Showing 4 changed files with 68 additions and 7 deletions.
17 changes: 14 additions & 3 deletions supernode/daemon/mgr/cdn/downloader.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ import (
// Body which the caller is expected to close.
func (cm *Manager) download(ctx context.Context, taskID, url string, headers map[string]string,
startPieceNum int, httpFileLength int64, pieceContSize int32) (*http.Response, error) {
var checkCode = http.StatusOK | http.StatusPartialContent
checkCode := []int{http.StatusOK, http.StatusPartialContent}

if startPieceNum > 0 {
breakRange, err := util.CalculateBreakRange(startPieceNum, int(pieceContSize), httpFileLength)
Expand All @@ -50,9 +50,20 @@ func (cm *Manager) download(ctx context.Context, taskID, url string, headers map
if _, ok := headers["Range"]; !ok {
headers["Range"] = httputils.ConstructRangeStr(breakRange)
}
checkCode = http.StatusPartialContent
checkCode = []int{http.StatusPartialContent}
}

logrus.Infof("start to download for taskId(%s) with fileUrl: %s header: %v checkCode: %d", taskID, url, headers, checkCode)
return cm.originClient.Download(url, headers, checkCode)
return cm.originClient.Download(url, headers, checkStatusCode(checkCode))
}

func checkStatusCode(statusCode []int) func(int) bool {
return func(status int) bool {
for _, s := range statusCode {
if status == s {
return true
}
}
return false
}
}
46 changes: 46 additions & 0 deletions supernode/daemon/mgr/cdn/downloader_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"io/ioutil"
"net/http"
"net/http/httptest"
"reflect"
"testing"

"github.com/dragonflyoss/Dragonfly/pkg/errortypes"
Expand Down Expand Up @@ -114,3 +115,48 @@ func (s *CDNDownloadTestSuite) TestDownload(c *check.C) {
c.Check(string(result), check.Equals, string(v.exceptedBody))
}
}

func Test_checkStatusCode(t *testing.T) {
type args struct {
statusCode []int
targetStatusCode int
}
tests := []struct {
name string
args args
statusCode int
want bool
}{
{
name: "200",
args: args{
statusCode: []int{http.StatusOK},
targetStatusCode: 200,
},
want: true,
},
{
name: "200|206",
args: args{
statusCode: []int{http.StatusOK, http.StatusPartialContent},
targetStatusCode: 206,
},
want: true,
},
{
name: "204",
args: args{
statusCode: []int{http.StatusOK, http.StatusPartialContent},
targetStatusCode: 204,
},
want: false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := checkStatusCode(tt.args.statusCode)(tt.args.targetStatusCode); !reflect.DeepEqual(got, tt.want) {
t.Errorf("checkStatusCode() = %v, want %v", got, tt.want)
}
})
}
}
4 changes: 3 additions & 1 deletion supernode/httpclient/mock/mock_origin_http_client.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 5 additions & 3 deletions supernode/httpclient/origin_http_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,13 +35,15 @@ import (
"github.com/pkg/errors"
)

type StatusCodeChecker func(int) bool

// OriginHTTPClient supply apis that interact with the source.
type OriginHTTPClient interface {
RegisterTLSConfig(rawURL string, insecure bool, caBlock []strfmt.Base64)
GetContentLength(url string, headers map[string]string) (int64, int, error)
IsSupportRange(url string, headers map[string]string) (bool, error)
IsExpired(url string, headers map[string]string, lastModified int64, eTag string) (bool, error)
Download(url string, headers map[string]string, checkCode int) (*http.Response, error)
Download(url string, headers map[string]string, checkCode StatusCodeChecker) (*http.Response, error)
}

// OriginClient is an implementation of the interface of OriginHTTPClient.
Expand Down Expand Up @@ -156,14 +158,14 @@ func (client *OriginClient) IsExpired(url string, headers map[string]string, las
}

// Download downloads the file from the original address
func (client *OriginClient) Download(url string, headers map[string]string, checkCode int) (*http.Response, error) {
func (client *OriginClient) Download(url string, headers map[string]string, checkCode StatusCodeChecker) (*http.Response, error) {
// TODO: add timeout
resp, err := client.HTTPWithHeaders("GET", url, headers, 0)
if err != nil {
return nil, err
}

if (resp.StatusCode & checkCode) == resp.StatusCode {
if checkCode(resp.StatusCode) {
return resp, nil
}
return nil, fmt.Errorf("unexpected status code: %d", resp.StatusCode)
Expand Down

0 comments on commit 2dee5c0

Please sign in to comment.