func TestFooJSON(t *testing.T) { seed := time.Now().UnixNano() popr := math_rand.New(math_rand.NewSource(seed)) p := NewPopulatedFoo(popr, true) marshaler := github_com_gogo_protobuf_jsonpb.Marshaler{} jsondata, err := marshaler.MarshalToString(p) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } msg := &Foo{} err = github_com_gogo_protobuf_jsonpb.UnmarshalString(jsondata, msg) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } if !p.Equal(msg) { t.Fatalf("seed = %d, %#v !Json Equal %#v", seed, msg, p) } }
func TestEncodedAuthorizationPolicyJSON(t *testing.T) { popr := math_rand.New(math_rand.NewSource(time.Now().UnixNano())) p := NewPopulatedEncodedAuthorizationPolicy(popr, true) marshaler := github_com_gogo_protobuf_jsonpb.Marshaler{} jsondata, err := marshaler.MarshalToString(p) if err != nil { t.Fatal(err) } msg := &EncodedAuthorizationPolicy{} err = github_com_gogo_protobuf_jsonpb.UnmarshalString(jsondata, msg) if err != nil { t.Fatal(err) } if err := p.VerboseEqual(msg); err != nil { t.Fatalf("%#v !VerboseProto %#v, since %v", msg, p, err) } if !p.Equal(msg) { t.Fatalf("%#v !Json Equal %#v", msg, p) } }
func TestMessageWithMapJSON(t *testing.T) { seed := time.Now().UnixNano() popr := math_rand.New(math_rand.NewSource(seed)) p := NewPopulatedMessageWithMap(popr, true) marshaler := github_com_gogo_protobuf_jsonpb.Marshaler{} jsondata, err := marshaler.MarshalToString(p) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } msg := &MessageWithMap{} err = github_com_gogo_protobuf_jsonpb.UnmarshalString(jsondata, msg) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } if err := p.VerboseEqual(msg); err != nil { t.Fatalf("seed = %d, %#v !VerboseProto %#v, since %v", seed, msg, p, err) } if !p.Equal(msg) { t.Fatalf("seed = %d, %#v !Json Equal %#v", seed, msg, p) } }
func TestEmailProofByClientCertJSON(t *testing.T) { seed := time.Now().UnixNano() popr := math_rand.New(math_rand.NewSource(seed)) p := NewPopulatedEmailProofByClientCert(popr, true) marshaler := github_com_andres_erbsen_protobuf_jsonpb.Marshaler{} jsondata, err := marshaler.MarshalToString(p) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } msg := &EmailProofByClientCert{} err = github_com_andres_erbsen_protobuf_jsonpb.UnmarshalString(jsondata, msg) if err != nil { t.Fatalf("seed = %d, err = %v", seed, err) } if err := p.VerboseEqual(msg); err != nil { t.Fatalf("seed = %d, %#v !VerboseProto %#v, since %v", seed, msg, p, err) } if !p.Equal(msg) { t.Fatalf("seed = %d, %#v !Json Equal %#v", seed, msg, p) } }
func (h *HTTPFront) ServeHTTP(w http.ResponseWriter, r *http.Request) { path := r.URL.Path userid, err := auth(r) if err != nil { http.Error(w, err.Error(), http.StatusUnauthorized) return } if r.Method != "POST" || (path != "/lookup" && path != "/update") { http.Error(w, `this server only supports queries of the POST /lookup or POST /update`, http.StatusNotFound) return } pf := &proto.LookupProof{} ctx := context.Background() if path == "/lookup" { pf, err = h.doLookup(r.Body, ctx) if err != nil { http.Error(w, err.Error(), http.StatusBadRequest) return } } else if path == "/update" { pf, err = h.doUpdate(r.Body, ctx, userid) if err != nil { http.Error(w, err.Error(), http.StatusBadRequest) return } } marshaler := jsonpb.Marshaler{} err = marshaler.Marshal(w, pf) if err != nil { http.Error(w, `Internal server error`, http.StatusInternalServerError) return } w.Header().Set("Content-Type", "application/json") return }