ooni-probe-cli/internal/cmd/oohelperd/main_test.go
Simone Basso df0e099b73
feat(oohelperd): follow (and record) TH and probe endpoints (#890)
This diff introduces the following `oohelperd` enhancements:

1. measure both IP addresses resolved by the TH and IP addresses resolved by the probe;

2. when the URL scheme is http and there's no explicit port, measure both 80 and 443 (which will pay off big once we introduce support for optionally performing TLS handshakes);

3. include information about the probe and TH IP addresses into the results: who resolved each IP address, whether an address is a bogon, the ASN associated to an address.

This diff is part of https://github.com/ooni/probe/issues/2237
2022-08-28 13:49:24 +02:00

83 lines
1.9 KiB
Go

package main
import (
"bytes"
"context"
"encoding/json"
"net/http"
"net/url"
"strings"
"testing"
"github.com/ooni/probe-cli/v3/internal/model"
"github.com/ooni/probe-cli/v3/internal/netxlite"
"github.com/ooni/probe-cli/v3/internal/runtimex"
)
func TestMainWorkingAsIntended(t *testing.T) {
// let the kernel pick a random free port
*endpoint = "127.0.0.1:0"
// run the main function in a background goroutine
go main()
// prepare the HTTP request body
jsonReq := ctrlRequest{
HTTPRequest: "https://dns.google",
HTTPRequestHeaders: map[string][]string{
"Accept": {model.HTTPHeaderAccept},
"Accept-Language": {model.HTTPHeaderAcceptLanguage},
"User-Agent": {model.HTTPHeaderUserAgent},
},
TCPConnect: []string{
"8.8.8.8:443",
"8.8.4.4:443",
},
}
data, err := json.Marshal(jsonReq)
runtimex.PanicOnError(err, "cannot marshal request")
// construct the test helper's URL
endpoint := <-srvAddr
URL := &url.URL{
Scheme: "http",
Host: endpoint,
Path: "/",
}
req, err := http.NewRequest("POST", URL.String(), bytes.NewReader(data))
runtimex.PanicOnError(err, "cannot create new HTTP request")
// issue the request and get the response
resp, err := http.DefaultClient.Do(req)
if err != nil {
t.Fatal(err)
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
t.Fatal("unexpected status code", resp.StatusCode)
}
// read the response body
data, err = netxlite.ReadAllContext(context.Background(), resp.Body)
if err != nil {
t.Fatal(err)
}
// parse the response
var jsonResp ctrlResponse
if err := json.Unmarshal(data, &jsonResp); err != nil {
t.Fatal(err)
}
// very simple correctness check
if !strings.Contains(jsonResp.HTTPRequest.Title, "Google") {
t.Fatal("expected the response title to contain the string Google")
}
// tear down the TH
srvCancel()
// wait for the background goroutine to join
srvWg.Wait()
}