You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tailscale/cmd/derper
Brad Fitzpatrick 15fc6cd966 derp/derphttp: fix netcheck HTTPS probes
The netcheck client, when no UDP is available, probes distance using
HTTPS.

Several problems:

* It probes using /derp/latency-check.
* But cmd/derper serves the handler at /derp/probe
* Despite the difference, it work by accident until c8f4dfc8c0
  which made netcheck's probe require a 2xx status code.
* in tests, we only use derphttp.Handler, so the cmd/derper-installed
  mux routes aren't preesnt, so there's no probe. That breaks
  tests in airplane mode. netcheck.Client then reports "unexpected
  HTTP status 426" (Upgrade Required)

This makes derp handle both /derp/probe and /derp/latency-check
equivalently, and in both cmd/derper and derphttp.Handler standalone
modes.

I notice this when wgengine/magicsock TestActiveDiscovery was failing
in airplane mode (no wifi). It still doesn't pass, but it gets
further.

Fixes #11989

Change-Id: I45213d4bd137e0f29aac8bd4a9ac92091065113f
7 months ago
..
bootstrap_dns.go
bootstrap_dns_test.go cmd/derper,tstest/nettest: skip network-needing test in airplane mode 7 months ago
cert.go
depaware.txt net/{interfaces,netmon}, all: merge net/interfaces package into net/netmon 7 months ago
derper.go derp/derphttp: fix netcheck HTTPS probes 7 months ago
derper_test.go cmd/{derper,stund},net/stunserver: add standalone stun server 11 months ago
mesh.go net/netns, net/dns/resolver, etc: make netmon required in most places 7 months ago
websocket.go net/wsconn: accept a remote addr string and plumb it through 1 year ago