Merge pull request #2672 from ikaven1024/ut-download
[ut] improve download from httptest
This commit is contained in:
commit
f54375d974
|
@ -21,11 +21,16 @@ type Downloader struct {
|
||||||
// Read Implementation of Downloader
|
// Read Implementation of Downloader
|
||||||
func (d *Downloader) Read(p []byte) (n int, err error) {
|
func (d *Downloader) Read(p []byte) (n int, err error) {
|
||||||
n, err = d.Reader.Read(p)
|
n, err = d.Reader.Read(p)
|
||||||
|
if err != nil {
|
||||||
|
if err != io.EOF {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Println("\nDownload complete.")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
d.Current += int64(n)
|
d.Current += int64(n)
|
||||||
fmt.Printf("\rDownloading...[ %.2f%% ]", float64(d.Current*10000/d.Total)/100)
|
fmt.Printf("\rDownloading...[ %.2f%% ]", float64(d.Current*10000/d.Total)/100)
|
||||||
if d.Current == d.Total {
|
|
||||||
fmt.Printf("\nDownload complete.")
|
|
||||||
}
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,26 +1,81 @@
|
||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"archive/tar"
|
||||||
|
"bytes"
|
||||||
|
"compress/gzip"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
|
||||||
filePath = "./crds.tar.gz"
|
|
||||||
folder = "./crds"
|
|
||||||
)
|
|
||||||
|
|
||||||
// TestDownloadFile test DownloadFile
|
// TestDownloadFile test DownloadFile
|
||||||
func TestDownloadFile(t *testing.T) {
|
func TestDownloadFile(t *testing.T) {
|
||||||
defer os.Remove(filePath)
|
const testFileName = "test.txt"
|
||||||
defer os.RemoveAll(folder)
|
testFileContent := []byte("test")
|
||||||
|
|
||||||
url := "https://github.com/karmada-io/karmada/releases/download/v0.9.0/crds.tar.gz"
|
serverTar := func() io.Reader {
|
||||||
if err := DownloadFile(url, filePath); err != nil {
|
buf := bytes.NewBuffer(nil)
|
||||||
panic(err)
|
gw := gzip.NewWriter(buf)
|
||||||
|
defer func() {
|
||||||
|
if err := gw.Close(); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
tw := tar.NewWriter(gw)
|
||||||
|
defer func() {
|
||||||
|
if err := tw.Close(); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
hdr := &tar.Header{
|
||||||
|
Name: testFileName,
|
||||||
|
Mode: 0600,
|
||||||
|
Size: int64(len(testFileContent)),
|
||||||
|
}
|
||||||
|
if err := tw.WriteHeader(hdr); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if _, err := tw.Write(testFileContent); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
return buf
|
||||||
|
}()
|
||||||
|
|
||||||
|
s := httptest.NewServer(http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) {
|
||||||
|
if _, err := io.Copy(rw, serverTar); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}))
|
||||||
|
defer s.Close()
|
||||||
|
|
||||||
|
tmpDir, err := os.MkdirTemp("", "karmada-test-download-")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
_ = os.RemoveAll(tmpDir)
|
||||||
|
}()
|
||||||
|
|
||||||
|
downloadTar := filepath.Join(tmpDir, "test.tar.gz")
|
||||||
|
err = DownloadFile(s.URL, downloadTar)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
err = DeCompress(downloadTar, tmpDir)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := DeCompress(filePath, "./"); err != nil {
|
got, err := os.ReadFile(filepath.Join(tmpDir, testFileName))
|
||||||
panic(err)
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if want := testFileContent; !bytes.Equal(got, want) {
|
||||||
|
t.Errorf("DeCompress() got %v, want %v", got, want)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue