FedP2P/tracker/udp_test.go

192 lines
4.6 KiB
Go
Raw Normal View History

package tracker
import (
"bytes"
"context"
"crypto/rand"
2021-06-22 20:36:43 +08:00
"errors"
2015-08-17 17:52:47 +08:00
"fmt"
2015-03-12 17:07:10 +08:00
"io/ioutil"
"net"
2015-03-12 17:07:10 +08:00
"net/url"
2014-03-16 23:30:10 +08:00
"sync"
"testing"
2021-06-22 20:36:43 +08:00
"time"
2019-08-10 16:46:07 +08:00
"github.com/anacrolix/dht/v2/krpc"
_ "github.com/anacrolix/envpprof"
2021-06-22 20:36:43 +08:00
"github.com/anacrolix/torrent/tracker/udp"
2015-08-17 17:52:47 +08:00
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
2018-02-12 20:49:05 +08:00
var trackers = []string{
2021-06-22 20:45:56 +08:00
"udp://tracker.opentrackr.org:1337/announce",
"udp://tracker.openbittorrent.com:6969/announce",
2018-02-12 20:49:05 +08:00
}
2015-08-17 17:52:47 +08:00
func TestAnnounceLocalhost(t *testing.T) {
t.Parallel()
2015-08-17 17:52:47 +08:00
srv := server{
t: map[[20]byte]torrent{
2016-11-22 11:01:09 +08:00
{0xa3, 0x56, 0x41, 0x43, 0x74, 0x23, 0xe6, 0x26, 0xd9, 0x38, 0x25, 0x4a, 0x6b, 0x80, 0x49, 0x10, 0xa6, 0x67, 0xa, 0xc1}: {
2015-08-17 17:52:47 +08:00
Seeders: 1,
Leechers: 2,
Peers: krpc.CompactIPv4NodeAddrs{
2015-08-17 17:52:47 +08:00
{[]byte{1, 2, 3, 4}, 5},
{[]byte{6, 7, 8, 9}, 10},
},
},
},
}
var err error
srv.pc, err = net.ListenPacket("udp", ":0")
require.NoError(t, err)
defer srv.pc.Close()
go func() {
require.NoError(t, srv.serveOne())
}()
req := AnnounceRequest{
NumWant: -1,
Event: Started,
}
rand.Read(req.PeerId[:])
copy(req.InfoHash[:], []uint8{0xa3, 0x56, 0x41, 0x43, 0x74, 0x23, 0xe6, 0x26, 0xd9, 0x38, 0x25, 0x4a, 0x6b, 0x80, 0x49, 0x10, 0xa6, 0x67, 0xa, 0xc1})
go func() {
require.NoError(t, srv.serveOne())
}()
2018-02-19 13:19:18 +08:00
ar, err := Announce{
TrackerUrl: fmt.Sprintf("udp://%s/announce", srv.pc.LocalAddr().String()),
Request: req,
}.Do()
2015-08-17 17:52:47 +08:00
require.NoError(t, err)
assert.EqualValues(t, 1, ar.Seeders)
assert.EqualValues(t, 2, len(ar.Peers))
}
func TestUDPTracker(t *testing.T) {
t.Parallel()
if testing.Short() {
t.SkipNow()
}
req := AnnounceRequest{
NumWant: -1,
}
rand.Read(req.PeerId[:])
2014-03-16 23:30:10 +08:00
copy(req.InfoHash[:], []uint8{0xa3, 0x56, 0x41, 0x43, 0x74, 0x23, 0xe6, 0x26, 0xd9, 0x38, 0x25, 0x4a, 0x6b, 0x80, 0x49, 0x10, 0xa6, 0x67, 0xa, 0xc1})
2021-06-22 20:45:50 +08:00
ctx, cancel := context.WithTimeout(context.Background(), DefaultTrackerAnnounceTimeout)
defer cancel()
2021-06-22 20:36:43 +08:00
if dl, ok := t.Deadline(); ok {
var cancel func()
ctx, cancel = context.WithDeadline(context.Background(), dl.Add(-time.Second))
defer cancel()
}
2018-02-19 13:19:18 +08:00
ar, err := Announce{
TrackerUrl: trackers[0],
Request: req,
2021-06-22 20:36:43 +08:00
Context: ctx,
2018-02-19 13:19:18 +08:00
}.Do()
// Skip any net errors as we don't control the server.
2021-06-22 20:36:43 +08:00
var ne net.Error
if errors.As(err, &ne) {
t.Skip(err)
2016-05-07 16:17:40 +08:00
}
2015-08-17 17:52:47 +08:00
require.NoError(t, err)
t.Log(ar)
}
2014-03-16 23:30:10 +08:00
2015-08-17 17:52:47 +08:00
func TestAnnounceRandomInfoHashThirdParty(t *testing.T) {
t.Parallel()
if testing.Short() {
2015-08-17 17:52:47 +08:00
// This test involves contacting third party servers that may have
2018-11-28 09:02:25 +08:00
// unpredictable results.
t.SkipNow()
}
req := AnnounceRequest{
Event: Stopped,
2014-12-04 02:51:49 +08:00
}
rand.Read(req.PeerId[:])
rand.Read(req.InfoHash[:])
2014-03-16 23:30:10 +08:00
wg := sync.WaitGroup{}
2021-06-22 20:45:50 +08:00
ctx, cancel := context.WithTimeout(context.Background(), DefaultTrackerAnnounceTimeout)
2021-06-22 20:36:43 +08:00
defer cancel()
if dl, ok := t.Deadline(); ok {
var cancel func()
ctx, cancel = context.WithDeadline(ctx, dl.Add(-time.Second))
defer cancel()
}
2018-02-12 20:49:05 +08:00
for _, url := range trackers {
2015-08-17 17:52:47 +08:00
wg.Add(1)
2014-03-16 23:30:10 +08:00
go func(url string) {
defer wg.Done()
2018-02-19 13:19:18 +08:00
resp, err := Announce{
TrackerUrl: url,
Request: req,
Context: ctx,
2018-02-19 13:19:18 +08:00
}.Do()
2014-03-16 23:30:10 +08:00
if err != nil {
t.Logf("error announcing to %s: %s", url, err)
return
2014-03-16 23:30:10 +08:00
}
if resp.Leechers != 0 || resp.Seeders != 0 || len(resp.Peers) != 0 {
2015-08-17 17:52:47 +08:00
// The info hash we generated was random in 2^160 space. If we
// get a hit, something is weird.
2014-03-16 23:30:10 +08:00
t.Fatal(resp)
}
2015-08-17 17:52:47 +08:00
t.Logf("announced to %s", url)
cancel()
2014-03-16 23:30:10 +08:00
}(url)
}
wg.Wait()
2021-02-03 16:42:46 +08:00
cancel()
2014-03-16 23:30:10 +08:00
}
2015-03-12 17:07:10 +08:00
// Check that URLPath option is done correctly.
func TestURLPathOption(t *testing.T) {
conn, err := net.ListenUDP("udp", nil)
if err != nil {
panic(err)
}
defer conn.Close()
2021-06-22 20:36:43 +08:00
announceErr := make(chan error)
2015-03-12 17:07:10 +08:00
go func() {
2018-02-19 13:19:18 +08:00
_, err := Announce{
TrackerUrl: (&url.URL{
Scheme: "udp",
Host: conn.LocalAddr().String(),
Path: "/announce",
}).String(),
}.Do()
2021-06-22 20:36:43 +08:00
defer conn.Close()
announceErr <- err
2015-03-12 17:07:10 +08:00
}()
var b [512]byte
_, addr, _ := conn.ReadFrom(b[:])
r := bytes.NewReader(b[:])
2021-06-22 20:36:43 +08:00
var h udp.RequestHeader
udp.Read(r, &h)
2015-03-12 17:07:10 +08:00
w := &bytes.Buffer{}
2021-06-22 20:36:43 +08:00
udp.Write(w, udp.ResponseHeader{
Action: udp.ActionConnect,
2015-03-12 17:07:10 +08:00
TransactionId: h.TransactionId,
})
2021-06-22 20:36:43 +08:00
udp.Write(w, udp.ConnectionResponse{42})
2015-03-12 17:07:10 +08:00
conn.WriteTo(w.Bytes(), addr)
n, _, _ := conn.ReadFrom(b[:])
r = bytes.NewReader(b[:n])
2021-06-22 20:36:43 +08:00
udp.Read(r, &h)
udp.Read(r, &AnnounceRequest{})
2015-03-12 17:07:10 +08:00
all, _ := ioutil.ReadAll(r)
if string(all) != "\x02\x09/announce" {
t.FailNow()
}
w = &bytes.Buffer{}
2021-06-22 20:36:43 +08:00
udp.Write(w, udp.ResponseHeader{
Action: udp.ActionAnnounce,
2015-03-12 17:07:10 +08:00
TransactionId: h.TransactionId,
})
2021-06-22 20:36:43 +08:00
udp.Write(w, udp.AnnounceResponseHeader{})
2015-03-12 17:07:10 +08:00
conn.WriteTo(w.Bytes(), addr)
2021-06-22 20:36:43 +08:00
require.NoError(t, <-announceErr)
2015-03-12 17:07:10 +08:00
}