refactor(mlablocate*): use internal testing (#382)

This is not an external package and it's fine to just use internal testing.

It reduces the complexity a little bit.
This commit is contained in:
Simone Basso 2021-06-15 18:11:47 +02:00 committed by GitHub
parent 8e26dbae8e
commit 34062cb177
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 40 additions and 58 deletions

View File

@ -1,4 +1,4 @@
package mlablocate_test package mlablocate
import ( import (
"context" "context"
@ -9,11 +9,10 @@ import (
"testing" "testing"
"github.com/apex/log" "github.com/apex/log"
"github.com/ooni/probe-cli/v3/internal/engine/internal/mlablocate"
) )
func TestWithoutProxy(t *testing.T) { func TestWithoutProxy(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -28,7 +27,7 @@ func TestWithoutProxy(t *testing.T) {
} }
func Test404Response(t *testing.T) { func Test404Response(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -43,7 +42,7 @@ func Test404Response(t *testing.T) {
} }
func TestNewRequestFailure(t *testing.T) { func TestNewRequestFailure(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -59,7 +58,7 @@ func TestNewRequestFailure(t *testing.T) {
} }
func TestHTTPClientDoFailure(t *testing.T) { func TestHTTPClientDoFailure(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -86,7 +85,7 @@ func (txp *roundTripFails) RoundTrip(*http.Request) (*http.Response, error) {
} }
func TestCannotReadBody(t *testing.T) { func TestCannotReadBody(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -128,7 +127,7 @@ func (b *readingBodyFailsBody) Close() error {
} }
func TestInvalidJSON(t *testing.T) { func TestInvalidJSON(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",
@ -169,7 +168,7 @@ func (b *invalidJSONBody) Close() error {
} }
func TestEmptyFQDN(t *testing.T) { func TestEmptyFQDN(t *testing.T) {
client := mlablocate.NewClient( client := NewClient(
http.DefaultClient, http.DefaultClient,
log.Log, log.Log,
"miniooni/0.1.0-dev", "miniooni/0.1.0-dev",

View File

@ -1,4 +1,4 @@
// Package mlablocatev2 use m-lab locate services API v2. // Package mlablocatev2 implements m-lab locate services API v2.
package mlablocatev2 package mlablocatev2
import ( import (

View File

@ -1,16 +0,0 @@
package mlablocatev2
import "context"
type ResultRecord resultRecord
func (c Client) Query(ctx context.Context, path string) (ResultRecord, error) {
out, err := c.query(ctx, path)
if err != nil {
return ResultRecord{}, err
}
return ResultRecord(out), nil
}
type EntryRecord = entryRecord

View File

@ -1,4 +1,4 @@
package mlablocatev2_test package mlablocatev2
import ( import (
"context" "context"
@ -10,14 +10,13 @@ import (
"testing" "testing"
"github.com/apex/log" "github.com/apex/log"
"github.com/ooni/probe-cli/v3/internal/engine/internal/mlablocatev2"
) )
func TestSuccess(t *testing.T) { func TestSuccess(t *testing.T) {
if testing.Short() { if testing.Short() {
t.Skip("skip test in short mode") t.Skip("skip test in short mode")
} }
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
result, err := client.QueryNDT7(context.Background()) result, err := client.QueryNDT7(context.Background())
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
@ -51,9 +50,9 @@ func Test404Response(t *testing.T) {
if testing.Short() { if testing.Short() {
t.Skip("skip test in short mode") t.Skip("skip test in short mode")
} }
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
result, err := client.Query(context.Background(), "nonexistent") result, err := client.query(context.Background(), "nonexistent")
if !errors.Is(err, mlablocatev2.ErrRequestFailed) { if !errors.Is(err, ErrRequestFailed) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
if result.Results != nil { if result.Results != nil {
@ -62,9 +61,9 @@ func Test404Response(t *testing.T) {
} }
func TestNewRequestFailure(t *testing.T) { func TestNewRequestFailure(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
client.Hostname = "\t" client.Hostname = "\t"
result, err := client.Query(context.Background(), "nonexistent") result, err := client.query(context.Background(), "nonexistent")
if err == nil || !strings.Contains(err.Error(), "invalid URL escape") { if err == nil || !strings.Contains(err.Error(), "invalid URL escape") {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
@ -74,12 +73,12 @@ func TestNewRequestFailure(t *testing.T) {
} }
func TestHTTPClientDoFailure(t *testing.T) { func TestHTTPClientDoFailure(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
expected := errors.New("mocked error") expected := errors.New("mocked error")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{Err: expected}, Transport: FakeTransport{Err: expected},
} }
result, err := client.Query(context.Background(), "nonexistent") result, err := client.query(context.Background(), "nonexistent")
if !errors.Is(err, expected) { if !errors.Is(err, expected) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
@ -89,19 +88,19 @@ func TestHTTPClientDoFailure(t *testing.T) {
} }
func TestCannotReadBody(t *testing.T) { func TestCannotReadBody(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
expected := errors.New("mocked error") expected := errors.New("mocked error")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{ Transport: FakeTransport{
Resp: &http.Response{ Resp: &http.Response{
StatusCode: 200, StatusCode: 200,
Body: mlablocatev2.FakeBody{ Body: FakeBody{
Err: expected, Err: expected,
}, },
}, },
}, },
} }
result, err := client.Query(context.Background(), "nonexistent") result, err := client.query(context.Background(), "nonexistent")
if !errors.Is(err, expected) { if !errors.Is(err, expected) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
@ -111,19 +110,19 @@ func TestCannotReadBody(t *testing.T) {
} }
func TestInvalidJSON(t *testing.T) { func TestInvalidJSON(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{ Transport: FakeTransport{
Resp: &http.Response{ Resp: &http.Response{
StatusCode: 200, StatusCode: 200,
Body: mlablocatev2.FakeBody{ Body: FakeBody{
Err: io.EOF, Err: io.EOF,
Data: []byte(`{`), Data: []byte(`{`),
}, },
}, },
}, },
} }
result, err := client.Query(context.Background(), "nonexistent") result, err := client.query(context.Background(), "nonexistent")
if err == nil || !strings.Contains(err.Error(), "unexpected end of JSON input") { if err == nil || !strings.Contains(err.Error(), "unexpected end of JSON input") {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
@ -133,12 +132,12 @@ func TestInvalidJSON(t *testing.T) {
} }
func TestEmptyResponse(t *testing.T) { func TestEmptyResponse(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{ Transport: FakeTransport{
Resp: &http.Response{ Resp: &http.Response{
StatusCode: 200, StatusCode: 200,
Body: mlablocatev2.FakeBody{ Body: FakeBody{
Err: io.EOF, Err: io.EOF,
Data: []byte(`{}`), Data: []byte(`{}`),
}, },
@ -146,7 +145,7 @@ func TestEmptyResponse(t *testing.T) {
}, },
} }
result, err := client.QueryNDT7(context.Background()) result, err := client.QueryNDT7(context.Background())
if !errors.Is(err, mlablocatev2.ErrEmptyResponse) { if !errors.Is(err, ErrEmptyResponse) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
if result != nil { if result != nil {
@ -155,17 +154,17 @@ func TestEmptyResponse(t *testing.T) {
} }
func TestNDT7QueryFails(t *testing.T) { func TestNDT7QueryFails(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{ Transport: FakeTransport{
Resp: &http.Response{ Resp: &http.Response{
StatusCode: 404, StatusCode: 404,
Body: mlablocatev2.FakeBody{Err: io.EOF}, Body: FakeBody{Err: io.EOF},
}, },
}, },
} }
result, err := client.QueryNDT7(context.Background()) result, err := client.QueryNDT7(context.Background())
if !errors.Is(err, mlablocatev2.ErrRequestFailed) { if !errors.Is(err, ErrRequestFailed) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
if result != nil { if result != nil {
@ -174,12 +173,12 @@ func TestNDT7QueryFails(t *testing.T) {
} }
func TestNDT7InvalidURLs(t *testing.T) { func TestNDT7InvalidURLs(t *testing.T) {
client := mlablocatev2.NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev") client := NewClient(http.DefaultClient, log.Log, "miniooni/0.1.0-dev")
client.HTTPClient = &http.Client{ client.HTTPClient = &http.Client{
Transport: mlablocatev2.FakeTransport{ Transport: FakeTransport{
Resp: &http.Response{ Resp: &http.Response{
StatusCode: 200, StatusCode: 200,
Body: mlablocatev2.FakeBody{ Body: FakeBody{
Data: []byte( Data: []byte(
`{"results":[{"machine":"mlab3-mil04.mlab-oti.measurement-lab.org","urls":{"wss:///ndt/v7/download":":","wss:///ndt/v7/upload":":"}}]}`), `{"results":[{"machine":"mlab3-mil04.mlab-oti.measurement-lab.org","urls":{"wss:///ndt/v7/download":":","wss:///ndt/v7/upload":":"}}]}`),
Err: io.EOF, Err: io.EOF,
@ -188,7 +187,7 @@ func TestNDT7InvalidURLs(t *testing.T) {
}, },
} }
result, err := client.QueryNDT7(context.Background()) result, err := client.QueryNDT7(context.Background())
if !errors.Is(err, mlablocatev2.ErrEmptyResponse) { if !errors.Is(err, ErrEmptyResponse) {
t.Fatal("not the error we expected") t.Fatal("not the error we expected")
} }
if result != nil { if result != nil {
@ -220,7 +219,7 @@ func TestEntryRecordSite(t *testing.T) {
}} }}
for _, tt := range tests { for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) { t.Run(tt.name, func(t *testing.T) {
er := mlablocatev2.EntryRecord{ er := entryRecord{
Machine: tt.fields.Machine, Machine: tt.fields.Machine,
URLs: tt.fields.URLs, URLs: tt.fields.URLs,
} }