28ce79eff1
* feat(ooapi): add toplevel client and simplify API This diff should simplify using ooapi from other packages by adding more abstraction that wraps the existing code. Part of https://github.com/ooni/probe/issues/1355. * fix(ooapi): use correct comment for cloners See https://github.com/ooni/probe-cli/pull/248#discussion_r590663843 * fix(ooapi): make sure the documentation is current See https://github.com/ooni/probe-cli/pull/248#discussion_r590665773 * fix(ooapi): automate copying APIs See https://github.com/ooni/probe-cli/pull/248#discussion_r590665837 * feat(ooapi): add unit tests for clientcall.go See https://github.com/ooni/probe-cli/pull/248#discussion_r590666297 * fix(ooapi): rewrite integration tests to use toplevel API See https://github.com/ooni/probe-cli/pull/248#discussion_r590665084
166 lines
4.0 KiB
Go
166 lines
4.0 KiB
Go
package ooapi_test
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/engine/ooapi"
|
|
"github.com/ooni/probe-cli/v3/internal/engine/ooapi/apimodel"
|
|
)
|
|
|
|
func TestWithRealServerDoCheckIn(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.CheckInRequest{
|
|
Charging: true,
|
|
OnWiFi: true,
|
|
Platform: "android",
|
|
ProbeASN: "AS12353",
|
|
ProbeCC: "IT",
|
|
RunType: "timed",
|
|
SoftwareName: "ooniprobe-android",
|
|
SoftwareVersion: "2.7.1",
|
|
WebConnectivity: apimodel.CheckInRequestWebConnectivity{
|
|
CategoryCodes: []string{"NEWS", "CULTR"},
|
|
},
|
|
}
|
|
httpClnt := &ooapi.VerboseHTTPClient{T: t}
|
|
clnt := &ooapi.Client{HTTPClient: httpClnt, KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.CheckIn(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
for idx, url := range resp.Tests.WebConnectivity.URLs {
|
|
if idx >= 3 {
|
|
break
|
|
}
|
|
t.Logf("- %+v", url)
|
|
}
|
|
}
|
|
|
|
func TestWithRealServerDoCheckReportID(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.CheckReportIDRequest{
|
|
ReportID: "20210223T093606Z_ndt_JO_8376_n1_kDYToqrugDY54Soy",
|
|
}
|
|
clnt := &ooapi.Client{KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.CheckReportID(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp)
|
|
}
|
|
|
|
func TestWithRealServerDoMeasurementMeta(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.MeasurementMetaRequest{
|
|
ReportID: "20210223T093606Z_ndt_JO_8376_n1_kDYToqrugDY54Soy",
|
|
}
|
|
clnt := &ooapi.Client{KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.MeasurementMeta(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp)
|
|
}
|
|
|
|
func TestWithRealServerDoOpenReport(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.OpenReportRequest{
|
|
DataFormatVersion: "0.2.0",
|
|
Format: "json",
|
|
ProbeASN: "AS137",
|
|
ProbeCC: "IT",
|
|
SoftwareName: "miniooni",
|
|
SoftwareVersion: "0.1.0-dev",
|
|
TestName: "example",
|
|
TestStartTime: "2018-11-01 15:33:20",
|
|
TestVersion: "0.1.0",
|
|
}
|
|
clnt := &ooapi.Client{KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.OpenReport(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp)
|
|
}
|
|
|
|
func TestWithRealServerDoPsiphonConfig(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.PsiphonConfigRequest{}
|
|
httpClnt := &ooapi.VerboseHTTPClient{T: t}
|
|
clnt := &ooapi.Client{HTTPClient: httpClnt, KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.PsiphonConfig(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp != nil)
|
|
}
|
|
|
|
func TestWithRealServerDoTorTargets(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.TorTargetsRequest{}
|
|
httpClnt := &ooapi.VerboseHTTPClient{T: t}
|
|
clnt := &ooapi.Client{HTTPClient: httpClnt, KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.TorTargets(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp != nil)
|
|
}
|
|
|
|
func TestWithRealServerDoURLs(t *testing.T) {
|
|
if testing.Short() {
|
|
t.Skip("skip test in short mode")
|
|
}
|
|
req := &apimodel.URLsRequest{
|
|
CountryCode: "IT",
|
|
Limit: 3,
|
|
}
|
|
clnt := &ooapi.Client{KVStore: &ooapi.MemKVStore{}}
|
|
ctx := context.Background()
|
|
resp, err := clnt.URLs(ctx, req)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if resp == nil {
|
|
t.Fatal("expected non nil pointer here")
|
|
}
|
|
t.Logf("%+v", resp)
|
|
}
|