build/perfdata/client_test.go

207 строки
5.4 KiB
Go

// Copyright 2017 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package perfdata
import (
"bytes"
"context"
"fmt"
"io"
"net/http"
"net/http/httptest"
"reflect"
"testing"
"golang.org/x/build/internal/diff"
"golang.org/x/perf/storage/benchfmt"
)
func TestQueryError(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
http.Error(w, "invalid query", 500)
}))
defer ts.Close()
c := &Client{BaseURL: ts.URL}
s, err := c.Query(context.Background(), "invalid query")
if err == nil {
s.Close()
t.Error("Err = nil, want error")
}
}
func TestQuery(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if have, want := r.URL.RequestURI(), "/search?q=key1%3Avalue+key2%3Avalue"; have != want {
t.Errorf("RequestURI = %q, want %q", have, want)
}
fmt.Fprintf(w, "key: value\nBenchmarkOne 5 ns/op\nkey: value2\nBenchmarkTwo 10 ns/op\n")
}))
defer ts.Close()
c := &Client{BaseURL: ts.URL}
s, err := c.Query(context.Background(), "key1:value key2:value")
if err != nil {
t.Fatalf("Err: %v", err)
}
defer s.Close()
q := benchfmt.NewReader(s)
var buf bytes.Buffer
bp := benchfmt.NewPrinter(&buf)
for q.Next() {
if err := bp.Print(q.Result()); err != nil {
t.Fatalf("Print: %v", err)
}
}
if err := q.Err(); err != nil {
t.Fatalf("Err: %v", err)
}
want := "key: value\nBenchmarkOne 5 ns/op\nkey: value2\nBenchmarkTwo 10 ns/op\n"
if diff := diff.Diff("have", buf.Bytes(), "want", []byte(want)); diff != nil {
t.Errorf("wrong results:\n%s", diff)
}
}
func TestListUploads(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if have, want := r.URL.RequestURI(), "/uploads?extra_label=key1&extra_label=key2&limit=10&q=key1%3Avalue+key2%3Avalue"; have != want {
t.Errorf("RequestURI = %q, want %q", have, want)
}
fmt.Fprintf(w, "%s\n", `{"UploadID": "id", "Count": 100, "LabelValues": {"key1": "value"}}`)
}))
defer ts.Close()
c := &Client{BaseURL: ts.URL}
r := c.ListUploads(context.Background(), "key1:value key2:value", []string{"key1", "key2"}, 10)
defer r.Close()
if !r.Next() {
t.Errorf("Next = false, want true")
}
if have, want := r.Info(), (UploadInfo{Count: 100, UploadID: "id", LabelValues: benchfmt.Labels{"key1": "value"}}); !reflect.DeepEqual(have, want) {
t.Errorf("Info = %#v, want %#v", have, want)
}
if err := r.Err(); err != nil {
t.Fatalf("Err: %v", err)
}
}
func TestNewUpload(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if have, want := r.URL.RequestURI(), "/upload"; have != want {
t.Errorf("RequestURI = %q, want %q", have, want)
}
mr, err := r.MultipartReader()
if err != nil {
t.Error(err)
}
i := 0
for i = 0; ; i++ {
p, err := mr.NextPart()
if err == io.EOF {
break
}
name := p.FormName()
if name == "commit" {
continue
}
if name != "file" {
t.Errorf("unexpected field %q, want file", name)
}
if have, want := p.FileName(), fmt.Sprintf("want%d.txt", i); have != want {
t.Errorf("file name = %q, want %q", have, want)
}
content, _ := io.ReadAll(p)
if have, want := string(content), "content"; have != want {
t.Errorf("unexpected content %q, want %q", have, want)
}
}
if i != 3 {
t.Errorf("number of files = %d, want %d", i, 3)
}
fmt.Fprintf(w, "%s\n", `{"uploadid": "id", "fileids": ["id/1", "id/2"]}`)
}))
defer ts.Close()
c := &Client{BaseURL: ts.URL}
u := c.NewUpload(context.Background())
for i := 0; i < 2; i++ {
w, err := u.CreateFile(fmt.Sprintf("want%d.txt", i))
if err != nil {
t.Fatalf("CreateFile = %v", err)
}
if _, err := fmt.Fprintf(w, "content"); err != nil {
t.Fatalf("Write returned %v", err)
}
}
status, err := u.Commit()
if err != nil {
t.Errorf("Commit = %v", err)
}
if status.UploadID != "id" {
t.Errorf("status.UploadID = %q, want %q", status.UploadID, "id")
}
}
func TestNewUploadAbort(t *testing.T) {
ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if have, want := r.URL.RequestURI(), "/upload"; have != want {
t.Errorf("RequestURI = %q, want %q", have, want)
}
mr, err := r.MultipartReader()
if err != nil {
t.Error(err)
}
i := 0
for i = 0; ; i++ {
p, err := mr.NextPart()
if err == io.EOF {
break
}
name := p.FormName()
if name == "abort" {
continue
}
if name != "file" {
t.Errorf("unexpected field %q, want file or abort", name)
}
if have, want := p.FileName(), fmt.Sprintf("want%d.txt", i); have != want {
t.Errorf("file name = %q, want %q", have, want)
}
content, _ := io.ReadAll(p)
if have, want := string(content), "content"; have != want {
t.Errorf("unexpected content %q, want %q", have, want)
}
}
if i != 3 {
t.Errorf("number of files = %d, want %d", i, 3)
}
fmt.Fprintf(w, "%s\n", `{"uploadid": "id", "fileids": ["id/1", "id/2"]}`)
}))
defer ts.Close()
c := &Client{BaseURL: ts.URL}
u := c.NewUpload(context.Background())
for i := 0; i < 2; i++ {
w, err := u.CreateFile(fmt.Sprintf("want%d.txt", i))
if err != nil {
t.Fatalf("CreateFile = %v", err)
}
if _, err := fmt.Fprintf(w, "content"); err != nil {
t.Fatalf("Write returned %v", err)
}
}
if err := u.Abort(); err != nil {
t.Errorf("Abort = %v", err)
}
}