package weapp import ( "encoding/json" "net/http" "net/http/httptest" "testing" ) func TestSearchSubmitPages(t *testing.T) { ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { if r.Method != "POST" { t.Fatalf("Expect 'POST' get '%s'", r.Method) } path := r.URL.EscapedPath() if path != apiSearchSubmitPages { t.Fatalf("Except to path '%s',get '%s'", apiSearchSubmitPages, path) } if err := r.ParseForm(); err != nil { t.Fatal(err) } if r.Form.Get("access_token") == "" { t.Fatalf("access_token can not be empty") } params := struct { Pages []struct { Path string `json:"path"` Query string `json:"query"` } `json:"pages"` }{} if err := json.NewDecoder(r.Body).Decode(¶ms); err != nil { t.Fatal(err) } if len(params.Pages) != 1 { t.Fatal("param pages can not be empty") } w.WriteHeader(http.StatusOK) raw := `{ "errcode": 0, "errmsg": "ok" }` if _, err := w.Write([]byte(raw)); err != nil { t.Fatal(err) } })) defer ts.Close() sender := SearchSubmitPages{ []SearchSubmitPage{ { Path: "/pages/index/index", Query: "id=test", }, }, } _, err := sender.send(ts.URL+apiSearchSubmitPages, "mock-access-token") if err != nil { t.Fatal(err) } }