aboutsummaryrefslogtreecommitdiffstats
path: root/swarm/api/http/error_test.go
diff options
context:
space:
mode:
authorholisticode <holistic.computing@gmail.com>2017-09-09 02:29:09 +0800
committerFelix Lange <fjl@users.noreply.github.com>2017-09-09 02:29:09 +0800
commitac193e36ce4bce752717124433a8ce84c347dbf7 (patch)
treeaa94c7b2db1557d05db6bb8e83828749026255cf /swarm/api/http/error_test.go
parent5ba9225fe3b06d5512976b808bc87d92d03d54ba (diff)
downloadgo-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar.gz
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar.bz2
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar.lz
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar.xz
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.tar.zst
go-tangerine-ac193e36ce4bce752717124433a8ce84c347dbf7.zip
swarm/api/http: add error pages (#14967)
Diffstat (limited to 'swarm/api/http/error_test.go')
-rw-r--r--swarm/api/http/error_test.go143
1 files changed, 143 insertions, 0 deletions
diff --git a/swarm/api/http/error_test.go b/swarm/api/http/error_test.go
new file mode 100644
index 000000000..465fbf4ca
--- /dev/null
+++ b/swarm/api/http/error_test.go
@@ -0,0 +1,143 @@
+// Copyright 2016 The go-ethereum Authors
+// This file is part of the go-ethereum library.
+//
+// The go-ethereum library is free software: you can redistribute it and/or modify
+// it under the terms of the GNU Lesser General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// The go-ethereum library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public License
+// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
+
+package http_test
+
+import (
+ "encoding/json"
+ "golang.org/x/net/html"
+ "io/ioutil"
+ "net/http"
+ "strings"
+ "testing"
+
+ "github.com/ethereum/go-ethereum/swarm/testutil"
+)
+
+func TestError(t *testing.T) {
+
+ srv := testutil.NewTestSwarmServer(t)
+ defer srv.Close()
+
+ var resp *http.Response
+ var respbody []byte
+
+ url := srv.URL + "/this_should_fail_as_no_bzz_protocol_present"
+ resp, err := http.Get(url)
+
+ if err != nil {
+ t.Fatalf("Request failed: %v", err)
+ }
+ defer resp.Body.Close()
+ respbody, err = ioutil.ReadAll(resp.Body)
+
+ if resp.StatusCode != 400 && !strings.Contains(string(respbody), "Invalid URI &#34;/this_should_fail_as_no_bzz_protocol_present&#34;: unknown scheme") {
+ t.Fatalf("Response body does not match, expected: %v, to contain: %v; received code %d, expected code: %d", string(respbody), "Invalid bzz URI: unknown scheme", 400, resp.StatusCode)
+ }
+
+ _, err = html.Parse(strings.NewReader(string(respbody)))
+ if err != nil {
+ t.Fatalf("HTML validation failed for error page returned!")
+ }
+}
+
+func Test404Page(t *testing.T) {
+ srv := testutil.NewTestSwarmServer(t)
+ defer srv.Close()
+
+ var resp *http.Response
+ var respbody []byte
+
+ url := srv.URL + "/bzz:/1234567890123456789012345678901234567890123456789012345678901234"
+ resp, err := http.Get(url)
+
+ if err != nil {
+ t.Fatalf("Request failed: %v", err)
+ }
+ defer resp.Body.Close()
+ respbody, err = ioutil.ReadAll(resp.Body)
+
+ if resp.StatusCode != 404 || !strings.Contains(string(respbody), "404") {
+ t.Fatalf("Invalid Status Code received, expected 404, got %d", resp.StatusCode)
+ }
+
+ _, err = html.Parse(strings.NewReader(string(respbody)))
+ if err != nil {
+ t.Fatalf("HTML validation failed for error page returned!")
+ }
+}
+
+func Test500Page(t *testing.T) {
+ srv := testutil.NewTestSwarmServer(t)
+ defer srv.Close()
+
+ var resp *http.Response
+ var respbody []byte
+
+ url := srv.URL + "/bzz:/thisShouldFailWith500Code"
+ resp, err := http.Get(url)
+
+ if err != nil {
+ t.Fatalf("Request failed: %v", err)
+ }
+ defer resp.Body.Close()
+ respbody, err = ioutil.ReadAll(resp.Body)
+
+ if resp.StatusCode != 500 || !strings.Contains(string(respbody), "500") {
+ t.Fatalf("Invalid Status Code received, expected 500, got %d", resp.StatusCode)
+ }
+
+ _, err = html.Parse(strings.NewReader(string(respbody)))
+ if err != nil {
+ t.Fatalf("HTML validation failed for error page returned!")
+ }
+}
+
+func TestJsonResponse(t *testing.T) {
+ srv := testutil.NewTestSwarmServer(t)
+ defer srv.Close()
+
+ var resp *http.Response
+ var respbody []byte
+
+ url := srv.URL + "/bzz:/thisShouldFailWith500Code/"
+ req, err := http.NewRequest("GET", url, nil)
+ if err != nil {
+ t.Fatalf("Request failed: %v", err)
+ }
+ req.Header.Set("Accept", "application/json")
+ resp, err = http.DefaultClient.Do(req)
+ if err != nil {
+ t.Fatalf("Request failed: %v", err)
+ }
+
+ defer resp.Body.Close()
+ respbody, err = ioutil.ReadAll(resp.Body)
+
+ if resp.StatusCode != 500 {
+ t.Fatalf("Invalid Status Code received, expected 500, got %d", resp.StatusCode)
+ }
+
+ if !isJSON(string(respbody)) {
+ t.Fatalf("Expected repsonse to be JSON, received invalid JSON: %s", string(respbody))
+ }
+
+}
+
+func isJSON(s string) bool {
+ var js map[string]interface{}
+ return json.Unmarshal([]byte(s), &js) == nil
+}