package quicdialer_test import ( "context" "crypto/tls" "testing" "github.com/lucas-clemente/quic-go" "github.com/ooni/probe-cli/v3/internal/engine/netx/errorx" "github.com/ooni/probe-cli/v3/internal/engine/netx/quicdialer" "github.com/ooni/probe-cli/v3/internal/engine/netx/trace" ) func TestSystemDialerInvalidIPFailure(t *testing.T) { tlsConf := &tls.Config{ NextProtos: []string{"h3"}, ServerName: "www.google.com", } saver := &trace.Saver{} systemdialer := quicdialer.SystemDialer{ Saver: saver, } sess, err := systemdialer.DialContext(context.Background(), "udp", "a.b.c.d:0", tlsConf, &quic.Config{}) if err == nil { t.Fatal("expected an error here") } if sess != nil { t.Fatal("expected nil sess here") } if err.Error() != "quicdialer: invalid IP representation" { t.Fatal("expected another error here") } } func TestSystemDialerSuccessWithReadWrite(t *testing.T) { // This is the most common use case for collecting reads, writes tlsConf := &tls.Config{ NextProtos: []string{"h3"}, ServerName: "www.google.com", } saver := &trace.Saver{} systemdialer := quicdialer.SystemDialer{Saver: saver} _, err := systemdialer.DialContext(context.Background(), "udp", "216.58.212.164:443", tlsConf, &quic.Config{}) if err != nil { t.Fatal(err) } ev := saver.Read() if len(ev) < 2 { t.Fatal("unexpected number of events") } last := len(ev) - 1 for idx := 1; idx < last; idx++ { if ev[idx].Data == nil { t.Fatal("unexpected Data") } if ev[idx].Duration <= 0 { t.Fatal("unexpected Duration") } if ev[idx].Err != nil { t.Fatal("unexpected Err") } if ev[idx].NumBytes <= 0 { t.Fatal("unexpected NumBytes") } switch ev[idx].Name { case errorx.ReadFromOperation, errorx.WriteToOperation: default: t.Fatal("unexpected Name") } if ev[idx].Time.Before(ev[idx-1].Time) { t.Fatal("unexpected Time", ev[idx].Time, ev[idx-1].Time) } } }