aboutsummaryrefslogtreecommitdiffstats
path: root/swarm/api/http/server_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'swarm/api/http/server_test.go')
-rw-r--r--swarm/api/http/server_test.go68
1 files changed, 41 insertions, 27 deletions
diff --git a/swarm/api/http/server_test.go b/swarm/api/http/server_test.go
index e8bc1bdae..dfa8a5187 100644
--- a/swarm/api/http/server_test.go
+++ b/swarm/api/http/server_test.go
@@ -443,11 +443,6 @@ func TestBzzGetPath(t *testing.T) {
testBzzGetPath(true, t)
}
-func TestBzzTar(t *testing.T) {
- testBzzTar(false, t)
- testBzzTar(true, t)
-}
-
func testBzzGetPath(encrypted bool, t *testing.T) {
var err error
@@ -561,24 +556,35 @@ func testBzzGetPath(encrypted bool, t *testing.T) {
ref := addr[2].Hex()
for _, c := range []struct {
- path string
- json string
- html string
+ path string
+ json string
+ pageFragments []string
}{
{
path: "/",
json: `{"common_prefixes":["a/"]}`,
- html: fmt.Sprintf("<!DOCTYPE html>\n<html>\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n\t\t<link rel=\"shortcut icon\" type=\"image/x-icon\" href=\"\"/>\n\t<title>Swarm index of bzz:/%s/</title>\n</head>\n\n<body>\n <h1>Swarm index of bzz:/%s/</h1>\n <hr>\n <table>\n <thead>\n <tr>\n\t<th>Path</th>\n\t<th>Type</th>\n\t<th>Size</th>\n </tr>\n </thead>\n\n <tbody>\n \n\t<tr>\n\t <td><a href=\"a/\">a/</a></td>\n\t <td>DIR</td>\n\t <td>-</td>\n\t</tr>\n \n\n \n </table>\n <hr>\n</body>\n", ref, ref),
+ pageFragments: []string{
+ fmt.Sprintf("Swarm index of bzz:/%s/", ref),
+ `<a class="normal-link" href="a/">a/</a>`,
+ },
},
{
path: "/a/",
json: `{"common_prefixes":["a/b/"],"entries":[{"hash":"011b4d03dd8c01f1049143cf9c4c817e4b167f1d1b83e5c6f0f10d89ba1e7bce","path":"a/a","mod_time":"0001-01-01T00:00:00Z"}]}`,
- html: fmt.Sprintf("<!DOCTYPE html>\n<html>\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n\t\t<link rel=\"shortcut icon\" type=\"image/x-icon\" href=\"\"/>\n\t<title>Swarm index of bzz:/%s/a/</title>\n</head>\n\n<body>\n <h1>Swarm index of bzz:/%s/a/</h1>\n <hr>\n <table>\n <thead>\n <tr>\n\t<th>Path</th>\n\t<th>Type</th>\n\t<th>Size</th>\n </tr>\n </thead>\n\n <tbody>\n \n\t<tr>\n\t <td><a href=\"b/\">b/</a></td>\n\t <td>DIR</td>\n\t <td>-</td>\n\t</tr>\n \n\n \n\t<tr>\n\t <td><a href=\"a\">a</a></td>\n\t <td></td>\n\t <td>0</td>\n\t</tr>\n \n </table>\n <hr>\n</body>\n", ref, ref),
+ pageFragments: []string{
+ fmt.Sprintf("Swarm index of bzz:/%s/a/", ref),
+ `<a class="normal-link" href="b/">b/</a>`,
+ `<a class="normal-link" href="a">a</a>`,
+ },
},
{
path: "/a/b/",
json: `{"entries":[{"hash":"011b4d03dd8c01f1049143cf9c4c817e4b167f1d1b83e5c6f0f10d89ba1e7bce","path":"a/b/b","mod_time":"0001-01-01T00:00:00Z"},{"hash":"011b4d03dd8c01f1049143cf9c4c817e4b167f1d1b83e5c6f0f10d89ba1e7bce","path":"a/b/c","mod_time":"0001-01-01T00:00:00Z"}]}`,
- html: fmt.Sprintf("<!DOCTYPE html>\n<html>\n<head>\n <meta http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\">\n <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n\t\t<link rel=\"shortcut icon\" type=\"image/x-icon\" href=\"\"/>\n\t<title>Swarm index of bzz:/%s/a/b/</title>\n</head>\n\n<body>\n <h1>Swarm index of bzz:/%s/a/b/</h1>\n <hr>\n <table>\n <thead>\n <tr>\n\t<th>Path</th>\n\t<th>Type</th>\n\t<th>Size</th>\n </tr>\n </thead>\n\n <tbody>\n \n\n \n\t<tr>\n\t <td><a href=\"b\">b</a></td>\n\t <td></td>\n\t <td>0</td>\n\t</tr>\n \n\t<tr>\n\t <td><a href=\"c\">c</a></td>\n\t <td></td>\n\t <td>0</td>\n\t</tr>\n \n </table>\n <hr>\n</body>\n", ref, ref),
+ pageFragments: []string{
+ fmt.Sprintf("Swarm index of bzz:/%s/a/b/", ref),
+ `<a class="normal-link" href="b">b</a>`,
+ `<a class="normal-link" href="c">c</a>`,
+ },
},
{
path: "/x",
@@ -628,21 +634,25 @@ func testBzzGetPath(encrypted bool, t *testing.T) {
t.Fatalf("HTTP request: %v", err)
}
defer resp.Body.Close()
- respbody, err := ioutil.ReadAll(resp.Body)
+ b, err := ioutil.ReadAll(resp.Body)
if err != nil {
t.Fatalf("Read response body: %v", err)
}
- if string(respbody) != c.html {
- isexpectedfailrequest := false
+ body := string(b)
- for _, r := range expectedfailrequests {
- if k[:] == r {
- isexpectedfailrequest = true
+ for _, f := range c.pageFragments {
+ if !strings.Contains(body, f) {
+ isexpectedfailrequest := false
+
+ for _, r := range expectedfailrequests {
+ if k[:] == r {
+ isexpectedfailrequest = true
+ }
+ }
+ if !isexpectedfailrequest {
+ t.Errorf("Response list body %q does not contain %q: body %q", k, f, body)
}
- }
- if !isexpectedfailrequest {
- t.Errorf("Response list body %q does not match, expected: %q, got %q", k, c.html, string(respbody))
}
}
})
@@ -657,11 +667,11 @@ func testBzzGetPath(encrypted bool, t *testing.T) {
}
nonhashresponses := []string{
- "cannot resolve name: no DNS to resolve name: &#34;name&#34;",
- "cannot resolve nonhash: immutable address not a content hash: &#34;nonhash&#34;",
- "cannot resolve nonhash: no DNS to resolve name: &#34;nonhash&#34;",
- "cannot resolve nonhash: no DNS to resolve name: &#34;nonhash&#34;",
- "cannot resolve nonhash: no DNS to resolve name: &#34;nonhash&#34;",
+ `cannot resolve name: no DNS to resolve name: "name"`,
+ `cannot resolve nonhash: immutable address not a content hash: "nonhash"`,
+ `cannot resolve nonhash: no DNS to resolve name: "nonhash"`,
+ `cannot resolve nonhash: no DNS to resolve name: "nonhash"`,
+ `cannot resolve nonhash: no DNS to resolve name: "nonhash"`,
}
for i, url := range nonhashtests {
@@ -684,6 +694,11 @@ func testBzzGetPath(encrypted bool, t *testing.T) {
}
}
+func TestBzzTar(t *testing.T) {
+ testBzzTar(false, t)
+ testBzzTar(true, t)
+}
+
func testBzzTar(encrypted bool, t *testing.T) {
srv := testutil.NewTestSwarmServer(t, serverFunc)
defer srv.Close()
@@ -738,7 +753,6 @@ func testBzzTar(encrypted bool, t *testing.T) {
}
swarmHash, err := ioutil.ReadAll(resp2.Body)
resp2.Body.Close()
- t.Logf("uploaded tarball successfully and got manifest address at %s", string(swarmHash))
if err != nil {
t.Fatal(err)
}
@@ -887,7 +901,7 @@ func TestMethodsNotAllowed(t *testing.T) {
} {
res, _ := http.Post(c.url, "text/plain", bytes.NewReader([]byte(databytes)))
if res.StatusCode != c.code {
- t.Fatal("should have failed")
+ t.Fatalf("should have failed. requested url: %s, expected code %d, got %d", c.url, c.code, res.StatusCode)
}
}