Fix bad http GET parameter encoding, add unit test
This commit is contained in:
parent
918c3fb260
commit
69e4f16b13
|
@ -188,10 +188,10 @@ func (h *HttpJson) sendRequest(serverURL string) (string, float64, error) {
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case h.Method == "GET":
|
case h.Method == "GET":
|
||||||
requestURL.RawQuery = params.Encode()
|
|
||||||
for k, v := range h.Parameters {
|
for k, v := range h.Parameters {
|
||||||
params.Add(k, v)
|
params.Add(k, v)
|
||||||
}
|
}
|
||||||
|
requestURL.RawQuery = params.Encode()
|
||||||
|
|
||||||
case h.Method == "POST":
|
case h.Method == "POST":
|
||||||
requestURL.RawQuery = ""
|
requestURL.RawQuery = ""
|
||||||
|
|
|
@ -222,7 +222,14 @@ func TestHttpJson200(t *testing.T) {
|
||||||
|
|
||||||
// Test litecoin sample output
|
// Test litecoin sample output
|
||||||
func TestHttpJsonLiteCoin(t *testing.T) {
|
func TestHttpJsonLiteCoin(t *testing.T) {
|
||||||
|
params := map[string]string{
|
||||||
|
"api_key": "mykey",
|
||||||
|
}
|
||||||
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
err := r.ParseForm()
|
||||||
|
assert.NoError(t, err)
|
||||||
|
key := r.Form.Get("api_key")
|
||||||
|
assert.Equal(t, "mykey", key)
|
||||||
w.WriteHeader(http.StatusOK)
|
w.WriteHeader(http.StatusOK)
|
||||||
fmt.Fprintln(w, validJSON2)
|
fmt.Fprintln(w, validJSON2)
|
||||||
}))
|
}))
|
||||||
|
@ -232,6 +239,7 @@ func TestHttpJsonLiteCoin(t *testing.T) {
|
||||||
Servers: []string{ts.URL},
|
Servers: []string{ts.URL},
|
||||||
Name: "",
|
Name: "",
|
||||||
Method: "GET",
|
Method: "GET",
|
||||||
|
Parameters: params,
|
||||||
client: RealHTTPClient{client: &http.Client{}},
|
client: RealHTTPClient{client: &http.Client{}},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue