Skip to content

Commit

Permalink
Merge pull request #163 from hashicorp/checksum_pass_args
Browse files Browse the repository at this point in the history
Various fixes
  • Loading branch information
vancluever authored Feb 7, 2019
2 parents 244ff47 + 675f23e commit 062101f
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 21 deletions.
17 changes: 10 additions & 7 deletions checksum.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ func (c *fileChecksum) checksum(source string) error {
}
defer f.Close()

c.Hash.Reset()
if _, err := io.Copy(c.Hash, f); err != nil {
return fmt.Errorf("Failed to hash: %s", err)
}
Expand Down Expand Up @@ -179,13 +180,15 @@ func (c *Client) checksumFromFile(checksumFile string, src *url.URL) (*fileCheck
defer os.Remove(tempfile)

c2 := &Client{
Getters: c.Getters,
Decompressors: c.Decompressors,
Detectors: c.Detectors,
Pwd: c.Pwd,
Dir: false,
Src: checksumFile,
Dst: tempfile,
Ctx: c.Ctx,
Getters: c.Getters,
Decompressors: c.Decompressors,
Detectors: c.Detectors,
Pwd: c.Pwd,
Dir: false,
Src: checksumFile,
Dst: tempfile,
ProgressListener: c.ProgressListener,
}
if err = c2.Get(); err != nil {
return nil, fmt.Errorf(
Expand Down
4 changes: 1 addition & 3 deletions get_http.go
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,7 @@ func (g *HttpGetter) GetFile(dst string, src *url.URL) error {
if err != nil {
return err
}
defer f.Close()

if g.Client == nil {
g.Client = httpClient
Expand Down Expand Up @@ -211,9 +212,6 @@ func (g *HttpGetter) GetFile(dst string, src *url.URL) error {
if err == nil && n < resp.ContentLength {
err = io.ErrShortWrite
}
if err1 := f.Close(); err == nil {
err = err1
}
return err
}

Expand Down
39 changes: 28 additions & 11 deletions get_http_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package getter

import (
"crypto/sha256"
"encoding/hex"
"errors"
"fmt"
"io/ioutil"
Expand Down Expand Up @@ -167,12 +169,16 @@ func TestHttpGetter_none(t *testing.T) {

func TestHttpGetter_resume(t *testing.T) {
load := []byte(testHttpMetaStr)
sha := sha256.New()
if n, err := sha.Write(load); n != len(load) || err != nil {
t.Fatalf("sha write failed: %d, %s", n, err)
}
checksum := hex.EncodeToString(sha.Sum(nil))
downloadFrom := len(load) / 2

ln := testHttpServer(t)
defer ln.Close()

g := new(HttpGetter)
dst := tempDir(t)
defer os.RemoveAll(dst)

Expand All @@ -181,28 +187,39 @@ func TestHttpGetter_resume(t *testing.T) {
if err != nil {
t.Fatalf("create: %v", err)
}
f.Write(load[:downloadFrom])
f.Close()
if n, err := f.Write(load[:downloadFrom]); n != downloadFrom || err != nil {
t.Fatalf("partial file write failed: %d, %s", n, err)
}
if err := f.Close(); err != nil {
t.Fatalf("close failed: %s", err)
}

var u url.URL
u.Scheme = "http"
u.Host = ln.Addr().String()
u.Path = "/range"
u := url.URL{
Scheme: "http",
Host: ln.Addr().String(),
Path: "/range",
RawQuery: "checksum=" + checksum,
}
t.Logf("url: %s", u.String())

// Get it!
if err := g.GetFile(dst, &u); err != nil {
t.Fatalf("should not error: %v", err)
// Finish getting it!
if err := GetFile(dst, u.String()); err != nil {
t.Fatalf("finishing download should not error: %v", err)
}

b, err := ioutil.ReadFile(dst)
if err != nil {
t.Fatalf("should not error: %v", err)
t.Fatalf("readfile failed: %v", err)
}

if string(b) != string(load) {
t.Fatalf("file differs: got:\n%s\n expected:\n%s\n", string(b), string(load))
}

// Get it again
if err := GetFile(dst, u.String()); err != nil {
t.Fatalf("should not error: %v", err)
}
}

func TestHttpGetter_file(t *testing.T) {
Expand Down

0 comments on commit 062101f

Please sign in to comment.