Critical fixes: - Fix security-hardening.sh live hook: removed broken source from /build/src/ which doesn't exist during live-build; made hook self-contained by inlining all config generation - Fix firewall-setup.sh live hook: removed broken source from /build/src/; hook already had inline nftables config - Fix install-scripts.sh: replaced /workspace/src/ references with embedded inline scripts (installed system has no /workspace) - Fix UKI cmdline in standalone uki_build(): added lockdown=confidentiality and module.sig_enforce=1 to match the inline Secure Boot hook - Fix WiFi blacklist: expanded from 6 entries to 19, now covers all PRD FR-005 driver families (rtl*, iwl*, ath*, brcm*, mwifi*, rt2*) Missing PRD requirements added: - kernel-hardening.sh (FR-007): sysctl parameters for ASLR, ptrace restriction, kptr_restrict, dmesg_restrict, kexec disabled, SUID dumpable disabled, hardlink/symlink protection, network hardening - service-hardening.sh (FR-007): disables and masks avahi-daemon, cups, bluetooth, NetworkManager, ModemManager, whoopsie, apport - sudo-hardening.sh (FR-007): requiretty, logging (input/output), timestamp timeout, env_reset, restricted football user commands - mount-hardening.sh (FR-007): nodev/nosuid/noexec on /tmp, nodev/nosuid on /home, /dev/shm hardening Test improvements: - Rewrote security-hardening_comprehensive_test.bats: tests now source scripts, call functions, and verify generated output files - Rewrote firewall-setup_comprehensive_test.bats: tests now create WireGuard configs, call parse_wg_endpoint, verify nftables output - Added new-hooks_test.bats: 42 tests for kernel hardening, service hardening, sudo hardening, mount hardening, self-containment verification, and WiFi blacklist completeness - Total: 788 tests passing, 0 failures, 0 shellcheck warnings Reference: docs/PRD.md FR-005, FR-007, security-model.md 💘 Generated with Crush Assisted-by: GLM-5.1 via Crush <crush@charm.land>
127 lines
3.9 KiB
Bash
127 lines
3.9 KiB
Bash
#!/usr/bin/env bats
|
|
# Behavioral tests for firewall-setup.sh
|
|
# Reference: PRD FR-004
|
|
|
|
setup() {
|
|
export TEST_TMPDIR=$(mktemp -d)
|
|
}
|
|
|
|
teardown() {
|
|
rm -rf "$TEST_TMPDIR"
|
|
}
|
|
|
|
# =============================================================================
|
|
# parse_wg_endpoint - PRD FR-004
|
|
# =============================================================================
|
|
|
|
@test "parse_wg_endpoint extracts endpoint from valid config" {
|
|
source /workspace/src/firewall-setup.sh
|
|
cat >"$TEST_TMPDIR/wg0.conf" <<'EOF'
|
|
[Interface]
|
|
PrivateKey = test123
|
|
Address = 10.0.0.2/24
|
|
|
|
[Peer]
|
|
PublicKey = peer123
|
|
Endpoint = 203.0.113.1:51820
|
|
AllowedIPs = 0.0.0.0/0
|
|
EOF
|
|
run parse_wg_endpoint "$TEST_TMPDIR/wg0.conf"
|
|
[ "$status" -eq 0 ]
|
|
[ "$output" = "203.0.113.1:51820" ]
|
|
}
|
|
|
|
@test "parse_wg_endpoint fails when config missing" {
|
|
source /workspace/src/firewall-setup.sh
|
|
run parse_wg_endpoint "$TEST_TMPDIR/nonexistent.conf"
|
|
[ "$status" -ne 0 ]
|
|
}
|
|
|
|
@test "parse_wg_endpoint fails when no Endpoint line" {
|
|
source /workspace/src/firewall-setup.sh
|
|
cat >"$TEST_TMPDIR/wg0.conf" <<'EOF'
|
|
[Interface]
|
|
PrivateKey = test123
|
|
EOF
|
|
run parse_wg_endpoint "$TEST_TMPDIR/wg0.conf"
|
|
[ "$status" -ne 0 ]
|
|
}
|
|
|
|
# =============================================================================
|
|
# generate_nftables_rules - PRD FR-004
|
|
# =============================================================================
|
|
|
|
@test "generate_nftables_rules produces valid nftables config" {
|
|
source /workspace/src/firewall-setup.sh
|
|
run generate_nftables_rules "203.0.113.1:51820"
|
|
[ "$status" -eq 0 ]
|
|
echo "$output" | grep -q "flush ruleset"
|
|
echo "$output" | grep -q "table inet filter"
|
|
}
|
|
|
|
@test "Firewall input chain has DROP policy" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "type filter hook input priority 0; policy drop"
|
|
}
|
|
|
|
@test "Firewall forward chain has DROP policy" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "type filter hook forward priority 0; policy drop"
|
|
}
|
|
|
|
@test "Firewall output chain has DROP policy" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "type filter hook output priority 0; policy drop"
|
|
}
|
|
|
|
@test "Firewall allows loopback traffic" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "iif lo accept"
|
|
echo "$result" | grep -q "oif lo accept"
|
|
}
|
|
|
|
@test "Firewall allows WireGuard traffic to specific endpoint" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "203.0.113.1"
|
|
echo "$result" | grep -q "51820"
|
|
}
|
|
|
|
@test "Firewall allows ICMP ping" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "203.0.113.1:51820")
|
|
echo "$result" | grep -q "echo-request"
|
|
}
|
|
|
|
@test "generate_nftables_rules extracts IP and port correctly" {
|
|
source /workspace/src/firewall-setup.sh
|
|
result=$(generate_nftables_rules "10.20.30.40:12345")
|
|
echo "$result" | grep -q "10.20.30.40"
|
|
echo "$result" | grep -q "12345"
|
|
}
|
|
|
|
# =============================================================================
|
|
# Script Structure
|
|
# =============================================================================
|
|
|
|
@test "firewall-setup.sh uses strict mode" {
|
|
head -5 /workspace/src/firewall-setup.sh | grep -q "set -euo pipefail"
|
|
}
|
|
|
|
@test "firewall-setup.sh is executable" {
|
|
[ -x "/workspace/src/firewall-setup.sh" ]
|
|
}
|
|
|
|
@test "firewall-setup.sh has valid bash syntax" {
|
|
run bash -n /workspace/src/firewall-setup.sh
|
|
[ "$status" -eq 0 ]
|
|
}
|
|
|
|
@test "firewall-setup.sh runs main when executed directly" {
|
|
grep -q 'BASH_SOURCE\[0\]' /workspace/src/firewall-setup.sh
|
|
}
|