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:
		
							parent
							
								
									8e26dbae8e
								
							
						
					
					
						commit
						34062cb177
					
				| @ -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", | ||||||
|  | |||||||
| @ -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 ( | ||||||
|  | |||||||
| @ -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 |  | ||||||
| @ -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, | ||||||
| 			} | 			} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user