2021-03-03 11:28:39 +01:00
|
|
|
package sessionresolver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
2021-06-22 13:00:29 +02:00
|
|
|
"github.com/ooni/probe-cli/v3/internal/bytecounter"
|
2022-06-08 14:06:22 +02:00
|
|
|
"github.com/ooni/probe-cli/v3/internal/model"
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/model/mocks"
|
2021-03-03 11:28:39 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestDefaultLogger(t *testing.T) {
|
2022-06-08 14:06:22 +02:00
|
|
|
t.Run("when using a different logger", func(t *testing.T) {
|
|
|
|
logger := &mocks.Logger{}
|
|
|
|
reso := &Resolver{Logger: logger}
|
|
|
|
lo := reso.logger()
|
|
|
|
if lo != logger {
|
|
|
|
t.Fatal("expected another logger here")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("when no logger is set", func(t *testing.T) {
|
|
|
|
reso := &Resolver{Logger: nil}
|
|
|
|
lo := reso.logger()
|
|
|
|
if lo != model.DiscardLogger {
|
|
|
|
t.Fatal("expected another logger here")
|
|
|
|
}
|
|
|
|
})
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetResolverHTTPSStandard(t *testing.T) {
|
|
|
|
bc := bytecounter.New()
|
|
|
|
URL := "https://dns.google"
|
2022-06-08 14:06:22 +02:00
|
|
|
var closed bool
|
|
|
|
re := &mocks.Resolver{
|
|
|
|
MockCloseIdleConnections: func() {
|
|
|
|
closed = true
|
|
|
|
},
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
var (
|
|
|
|
savedURL string
|
|
|
|
savedH3 bool
|
|
|
|
)
|
|
|
|
reso := &Resolver{
|
|
|
|
ByteCounter: bc,
|
|
|
|
newChildResolverFn: func(h3 bool, URL string) (model.Resolver, error) {
|
|
|
|
savedURL = URL
|
|
|
|
savedH3 = h3
|
|
|
|
return re, nil
|
|
|
|
},
|
|
|
|
}
|
2021-03-03 11:28:39 +01:00
|
|
|
out, err := reso.getresolver(URL)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if out != re {
|
|
|
|
t.Fatal("not the result we expected")
|
|
|
|
}
|
|
|
|
o2, err := reso.getresolver(URL)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if out != o2 {
|
|
|
|
t.Fatal("not the result we expected")
|
|
|
|
}
|
|
|
|
reso.closeall()
|
2022-06-08 14:06:22 +02:00
|
|
|
if closed != true {
|
2021-03-03 11:28:39 +01:00
|
|
|
t.Fatal("was not closed")
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
if savedURL != URL {
|
2021-03-03 11:28:39 +01:00
|
|
|
t.Fatal("not the URL we expected")
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
if savedH3 {
|
|
|
|
t.Fatal("expected false")
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetResolverHTTP3(t *testing.T) {
|
|
|
|
bc := bytecounter.New()
|
|
|
|
URL := "http3://dns.google"
|
2022-06-08 14:06:22 +02:00
|
|
|
var closed bool
|
|
|
|
re := &mocks.Resolver{
|
|
|
|
MockCloseIdleConnections: func() {
|
|
|
|
closed = true
|
|
|
|
},
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
var (
|
|
|
|
savedURL string
|
|
|
|
savedH3 bool
|
|
|
|
)
|
|
|
|
reso := &Resolver{
|
|
|
|
ByteCounter: bc,
|
|
|
|
newChildResolverFn: func(h3 bool, URL string) (model.Resolver, error) {
|
|
|
|
savedURL = URL
|
|
|
|
savedH3 = h3
|
|
|
|
return re, nil
|
|
|
|
},
|
|
|
|
}
|
2021-03-03 11:28:39 +01:00
|
|
|
out, err := reso.getresolver(URL)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if out != re {
|
|
|
|
t.Fatal("not the result we expected")
|
|
|
|
}
|
|
|
|
o2, err := reso.getresolver(URL)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if out != o2 {
|
|
|
|
t.Fatal("not the result we expected")
|
|
|
|
}
|
|
|
|
reso.closeall()
|
2022-06-08 14:06:22 +02:00
|
|
|
if closed != true {
|
2021-03-03 11:28:39 +01:00
|
|
|
t.Fatal("was not closed")
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
if savedURL != strings.Replace(URL, "http3://", "https://", 1) {
|
2021-03-03 11:28:39 +01:00
|
|
|
t.Fatal("not the URL we expected")
|
|
|
|
}
|
2022-06-08 22:29:01 +02:00
|
|
|
if !savedH3 {
|
|
|
|
t.Fatal("expected true")
|
2021-03-03 11:28:39 +01:00
|
|
|
}
|
|
|
|
}
|