mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 10:09:17 +00:00 
			
		
		
		
	health: introduce captive-portal-detected Warnable (#12707)
Updates tailscale/tailscale#1634 This PR introduces a new `captive-portal-detected` Warnable which is set to an unhealthy state whenever a captive portal is detected on the local network, preventing Tailscale from connecting. ipn/ipnlocal: fix captive portal loop shutdown Change-Id: I7cafdbce68463a16260091bcec1741501a070c95 net/captivedetection: fix mutex misuse ipn/ipnlocal: ensure that we don't fail to start the timer Change-Id: I3e43fb19264d793e8707c5031c0898e48e3e7465 Signed-off-by: Andrew Dunham <andrew@du.nham.ca> Signed-off-by: Andrea Gottardo <andrea@gottardo.me>
This commit is contained in:
		
							
								
								
									
										58
									
								
								net/captivedetection/captivedetection_test.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								net/captivedetection/captivedetection_test.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| // Copyright (c) Tailscale Inc & AUTHORS | ||||
| // SPDX-License-Identifier: BSD-3-Clause | ||||
| 
 | ||||
| package captivedetection | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"runtime" | ||||
| 	"sync" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"tailscale.com/net/netmon" | ||||
| ) | ||||
| 
 | ||||
| func TestAvailableEndpointsAlwaysAtLeastTwo(t *testing.T) { | ||||
| 	endpoints := availableEndpoints(nil, 0, t.Logf, runtime.GOOS) | ||||
| 	if len(endpoints) == 0 { | ||||
| 		t.Errorf("Expected non-empty AvailableEndpoints, got an empty slice instead") | ||||
| 	} | ||||
| 	if len(endpoints) == 1 { | ||||
| 		t.Errorf("Expected at least two AvailableEndpoints for redundancy, got only one instead") | ||||
| 	} | ||||
| 	for _, e := range endpoints { | ||||
| 		if e.URL.Scheme != "http" { | ||||
| 			t.Errorf("Expected HTTP URL in Endpoint, got HTTPS") | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func TestDetectCaptivePortalReturnsFalse(t *testing.T) { | ||||
| 	d := NewDetector(t.Logf) | ||||
| 	found := d.Detect(context.Background(), netmon.NewStatic(), nil, 0) | ||||
| 	if found { | ||||
| 		t.Errorf("DetectCaptivePortal returned true, expected false.") | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func TestAllEndpointsAreUpAndReturnExpectedResponse(t *testing.T) { | ||||
| 	d := NewDetector(t.Logf) | ||||
| 	endpoints := availableEndpoints(nil, 0, t.Logf, runtime.GOOS) | ||||
| 
 | ||||
| 	var wg sync.WaitGroup | ||||
| 	for _, e := range endpoints { | ||||
| 		wg.Add(1) | ||||
| 		go func(endpoint Endpoint) { | ||||
| 			defer wg.Done() | ||||
| 			found, err := d.verifyCaptivePortalEndpoint(context.Background(), endpoint, 0) | ||||
| 			if err != nil { | ||||
| 				t.Errorf("verifyCaptivePortalEndpoint failed with endpoint %v: %v", endpoint, err) | ||||
| 			} | ||||
| 			if found { | ||||
| 				t.Errorf("verifyCaptivePortalEndpoint with endpoint %v says we're behind a captive portal, but we aren't", endpoint) | ||||
| 			} | ||||
| 		}(e) | ||||
| 	} | ||||
| 
 | ||||
| 	wg.Wait() | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Andrea Gottardo
					Andrea Gottardo