Files
BrowserOS/packages/browseros-agent/tools/dev/proc/ports_test.go
Dani Akash 290ee91a8b Add 'packages/browseros-agent/' from commit '90bd4be3008285bf3825aad3702aff98f872671a'
git-subtree-dir: packages/browseros-agent
git-subtree-mainline: 8f148d0918
git-subtree-split: 90bd4be300
2026-03-13 21:22:09 +05:30

173 lines
5.1 KiB
Go

package proc
import (
"fmt"
"math/rand"
"net"
"testing"
)
func TestSelectPreferredPortUsesPreferredWhenAvailable(t *testing.T) {
reserved := map[int]struct{}{}
preferred := findFreePortInRange(t, randomPortMin)
port, listener, err := selectPreferredPort(preferred, reserved)
if err != nil {
t.Fatalf("selectPreferredPort returned error: %v", err)
}
defer listener.Close()
if port != preferred {
t.Fatalf("expected preferred port %d, got %d", preferred, port)
}
if _, ok := reserved[port]; !ok {
t.Fatalf("expected port %d to be reserved", port)
}
}
func TestSelectPreferredPortFallsBackWhenPreferredUnavailable(t *testing.T) {
preferred := findFreePortInRange(t, randomPortMin)
listener := listenOnPort(t, preferred)
defer listener.Close()
reserved := map[int]struct{}{}
port, reservedListener, err := selectPreferredPort(preferred, reserved)
if err != nil {
t.Fatalf("selectPreferredPort returned error: %v", err)
}
defer reservedListener.Close()
if port == preferred {
t.Fatalf("expected fallback port when preferred port %d is unavailable", preferred)
}
if port < randomPortMin || port > randomPortMax {
t.Fatalf("expected fallback port in range %d-%d, got %d", randomPortMin, randomPortMax, port)
}
if _, ok := reserved[port]; !ok {
t.Fatalf("expected fallback port %d to be reserved", port)
}
}
func TestSelectRandomPortUsesRangeAndUniqueness(t *testing.T) {
rng := rand.New(rand.NewSource(1))
reserved := map[int]struct{}{}
first, firstListener, err := selectRandomPort(rng, reserved)
if err != nil {
t.Fatalf("selectRandomPort returned error: %v", err)
}
defer firstListener.Close()
second, secondListener, err := selectRandomPort(rng, reserved)
if err != nil {
t.Fatalf("selectRandomPort returned error: %v", err)
}
defer secondListener.Close()
third, thirdListener, err := selectRandomPort(rng, reserved)
if err != nil {
t.Fatalf("selectRandomPort returned error: %v", err)
}
defer thirdListener.Close()
assertPortInRange(t, first)
assertPortInRange(t, second)
assertPortInRange(t, third)
if first == second || first == third || second == third {
t.Fatalf("expected unique ports, got %d, %d, %d", first, second, third)
}
}
func TestResolveWatchPortsRandomUsesUniquePortsInRange(t *testing.T) {
ports, reservations, err := ResolveWatchPorts(true)
if err != nil {
t.Fatalf("ResolveWatchPorts returned error: %v", err)
}
defer reservations.ReleaseAll()
assertPortInRange(t, ports.CDP)
assertPortInRange(t, ports.Server)
assertPortInRange(t, ports.Extension)
if ports.CDP == ports.Server || ports.CDP == ports.Extension || ports.Server == ports.Extension {
t.Fatalf("expected unique ports, got %+v", ports)
}
if IsPortAvailable(ports.CDP) || IsPortAvailable(ports.Server) || IsPortAvailable(ports.Extension) {
t.Fatalf("expected reserved ports to stay bound until release, got %+v", ports)
}
}
func TestResolveWatchPortsDefaultFallsBackWhenPreferredUnavailable(t *testing.T) {
defaults := findUniqueFreePorts(t, 3)
originalDefaults := defaultLocalPorts
defaultLocalPorts = defaults
defer func() {
defaultLocalPorts = originalDefaults
}()
cdpListener := listenOnPort(t, defaults.CDP)
defer cdpListener.Close()
serverListener := listenOnPort(t, defaults.Server)
defer serverListener.Close()
extensionListener := listenOnPort(t, defaults.Extension)
defer extensionListener.Close()
ports, reservations, err := ResolveWatchPorts(false)
if err != nil {
t.Fatalf("ResolveWatchPorts returned error: %v", err)
}
defer reservations.ReleaseAll()
if ports == defaults {
t.Fatalf("expected fallback ports when defaults are occupied, got %+v", ports)
}
if ports.CDP == ports.Server || ports.CDP == ports.Extension || ports.Server == ports.Extension {
t.Fatalf("expected unique fallback ports, got %+v", ports)
}
if IsPortAvailable(ports.CDP) || IsPortAvailable(ports.Server) || IsPortAvailable(ports.Extension) {
t.Fatalf("expected fallback ports to stay bound until release, got %+v", ports)
}
}
func assertPortInRange(t *testing.T, port int) {
t.Helper()
if port < randomPortMin || port > randomPortMax {
t.Fatalf("expected port in range %d-%d, got %d", randomPortMin, randomPortMax, port)
}
}
func findFreePortInRange(t *testing.T, start int) int {
t.Helper()
for port := start; port <= randomPortMax; port++ {
if IsPortAvailable(port) {
return port
}
}
t.Fatalf("failed to find free port in range %d-%d", start, randomPortMax)
return 0
}
func findUniqueFreePorts(t *testing.T, count int) Ports {
t.Helper()
found := Ports{}
values := make([]int, 0, count)
for port := randomPortMin; port <= randomPortMax && len(values) < count; port++ {
if IsPortAvailable(port) {
values = append(values, port)
}
}
if len(values) != count {
t.Fatalf("failed to find %d unique free ports", count)
}
found.CDP = values[0]
found.Server = values[1]
found.Extension = values[2]
return found
}
func listenOnPort(t *testing.T, port int) net.Listener {
t.Helper()
listener, err := net.Listen("tcp", fmt.Sprintf("127.0.0.1:%d", port))
if err != nil {
t.Fatalf("failed to listen on port %d: %v", port, err)
}
return listener
}