|
| 1 | +// Copyright 2025 Datum Cloud, Inc. |
| 2 | +// |
| 3 | +// SPDX-License-Identifier: AGPL-3.0-or-later |
| 4 | + |
| 5 | +package sysctl |
| 6 | + |
| 7 | +import ( |
| 8 | + "bytes" |
| 9 | + "log/slog" |
| 10 | + "strings" |
| 11 | + "testing" |
| 12 | +) |
| 13 | + |
| 14 | +func TestConfigureInterfaceSysctls_nonexistentInterface(t *testing.T) { |
| 15 | + // Use a name guaranteed to not exist on any real system. |
| 16 | + // gosysctl.Set will fail for every sysctl, but the function |
| 17 | + // must still return nil (gracefully skipping missing entries). |
| 18 | + const fakeIf = "this_interface_does_not_exist_xk9z2m" |
| 19 | + |
| 20 | + var buf bytes.Buffer |
| 21 | + origLogger := logger |
| 22 | + logger = slog.New(slog.NewTextHandler(&buf, nil)) |
| 23 | + defer func() { logger = origLogger }() |
| 24 | + |
| 25 | + if err := ConfigureInterfaceSysctls(fakeIf); err != nil { |
| 26 | + t.Fatalf("expected nil error for nonexistent interface, got: %v", err) |
| 27 | + } |
| 28 | + |
| 29 | + logs := buf.String() |
| 30 | + // Verify that a WARN was logged for each failed sysctl |
| 31 | + if !strings.Contains(logs, "failed to set sysctl") { |
| 32 | + t.Errorf("expected WARN log for failed sysctl, got: %q", logs) |
| 33 | + } |
| 34 | +} |
| 35 | + |
| 36 | +func TestConfigureInterfaceSysctls_returnsNil(t *testing.T) { |
| 37 | + // Even when some sysctls fail to set, the function must return nil. |
| 38 | + const fakeIf = "nonexistent_iface_abc123" |
| 39 | + |
| 40 | + if err := ConfigureInterfaceSysctls(fakeIf); err != nil { |
| 41 | + t.Fatalf("ConfigureInterfaceSysctls must always return nil, got error: %v", err) |
| 42 | + } |
| 43 | +} |
| 44 | + |
| 45 | +func TestConfigureTapSysctls_returnsNil(t *testing.T) { |
| 46 | + // Same guarantee: ConfigureTapSysctls must always return nil. |
| 47 | + const fakeIf = "nonexistent_tap_xyz789" |
| 48 | + |
| 49 | + if err := ConfigureTapSysctls(fakeIf); err != nil { |
| 50 | + t.Fatalf("ConfigureTapSysctls must always return nil, got error: %v", err) |
| 51 | + } |
| 52 | +} |
| 53 | + |
| 54 | +func TestInterfaceSettings_hasAllEntries(t *testing.T) { |
| 55 | + // Verify that interfaceSettings contains all expected sysctl types. |
| 56 | + expected := map[string]bool{ |
| 57 | + "rp_filter": false, |
| 58 | + "forwarding": false, |
| 59 | + "proxy_arp": false, |
| 60 | + "proxy_ndp": false, |
| 61 | + } |
| 62 | + for _, entry := range interfaceSettings { |
| 63 | + for name := range expected { |
| 64 | + if strings.Contains(entry.format, name) { |
| 65 | + expected[name] = true |
| 66 | + } |
| 67 | + } |
| 68 | + } |
| 69 | + for name, found := range expected { |
| 70 | + if !found { |
| 71 | + t.Errorf("interfaceSettings missing expected sysctl: %s", name) |
| 72 | + } |
| 73 | + } |
| 74 | +} |
0 commit comments