mirror of
https://github.com/tw93/Mole.git
synced 2026-02-04 22:04:43 +00:00
This commit addresses several code quality issues identified in the
recent bash 3.2 compatibility fixes:
1. Remove redundant array length check in is_whitelisted()
- The second check for array length > 0 is unnecessary after
already checking for length == 0
2. Clean up commented dangerous cleanup code in dev.sh
- Replace commented-out code with clear documentation
- Add explicit notes explaining why certain paths are excluded
- Improves maintainability by preventing confusion
3. Enhance test coverage for excluded paths
- Add tests to verify Mix archives are NOT cleaned
- Add tests to verify Stack programs are NOT cleaned
- Add tests to verify VS Code workspace storage is NOT cleaned
- These tests ensure critical data remains protected
All changes pass ShellCheck, syntax validation, and formatting checks.
118 lines
3.4 KiB
Bash
118 lines
3.4 KiB
Bash
#!/usr/bin/env bats
|
|
|
|
setup_file() {
|
|
PROJECT_ROOT="$(cd "${BATS_TEST_DIRNAME}/.." && pwd)"
|
|
export PROJECT_ROOT
|
|
|
|
ORIGINAL_HOME="${HOME:-}"
|
|
export ORIGINAL_HOME
|
|
|
|
HOME="$(mktemp -d "${BATS_TEST_DIRNAME}/tmp-dev-extended.XXXXXX")"
|
|
export HOME
|
|
|
|
mkdir -p "$HOME"
|
|
}
|
|
|
|
teardown_file() {
|
|
rm -rf "$HOME"
|
|
if [[ -n "${ORIGINAL_HOME:-}" ]]; then
|
|
export HOME="$ORIGINAL_HOME"
|
|
fi
|
|
}
|
|
|
|
@test "clean_dev_elixir cleans hex cache" {
|
|
mkdir -p "$HOME/.mix" "$HOME/.hex"
|
|
run env HOME="$HOME" PROJECT_ROOT="$PROJECT_ROOT" bash --noprofile --norc <<'EOF'
|
|
set -euo pipefail
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/lib/clean/dev.sh"
|
|
safe_clean() { echo "$2"; }
|
|
clean_dev_elixir
|
|
EOF
|
|
|
|
[ "$status" -eq 0 ]
|
|
[[ "$output" == *"Hex cache"* ]]
|
|
}
|
|
|
|
@test "clean_dev_elixir does not clean mix archives" {
|
|
mkdir -p "$HOME/.mix/archives"
|
|
touch "$HOME/.mix/archives/test_tool.ez"
|
|
|
|
# Source and run the function
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/bin/clean.sh"
|
|
clean_dev_elixir > /dev/null 2>&1 || true
|
|
|
|
# Verify the file still exists
|
|
[ -f "$HOME/.mix/archives/test_tool.ez" ]
|
|
}
|
|
|
|
@test "clean_dev_haskell cleans cabal install cache" {
|
|
mkdir -p "$HOME/.cabal" "$HOME/.stack"
|
|
run env HOME="$HOME" PROJECT_ROOT="$PROJECT_ROOT" bash --noprofile --norc <<'EOF'
|
|
set -euo pipefail
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/lib/clean/dev.sh"
|
|
safe_clean() { echo "$2"; }
|
|
clean_dev_haskell
|
|
EOF
|
|
|
|
[ "$status" -eq 0 ]
|
|
[[ "$output" == *"Cabal install cache"* ]]
|
|
}
|
|
|
|
@test "clean_dev_haskell does not clean stack programs" {
|
|
mkdir -p "$HOME/.stack/programs/x86_64-osx"
|
|
touch "$HOME/.stack/programs/x86_64-osx/ghc-9.2.8.tar.xz"
|
|
|
|
# Source and run the function
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/bin/clean.sh"
|
|
clean_dev_haskell > /dev/null 2>&1 || true
|
|
|
|
# Verify the file still exists
|
|
[ -f "$HOME/.stack/programs/x86_64-osx/ghc-9.2.8.tar.xz" ]
|
|
}
|
|
|
|
@test "clean_dev_ocaml cleans opam cache" {
|
|
mkdir -p "$HOME/.opam"
|
|
run env HOME="$HOME" PROJECT_ROOT="$PROJECT_ROOT" bash --noprofile --norc <<'EOF'
|
|
set -euo pipefail
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/lib/clean/dev.sh"
|
|
safe_clean() { echo "$2"; }
|
|
clean_dev_ocaml
|
|
EOF
|
|
|
|
[ "$status" -eq 0 ]
|
|
[[ "$output" == *"Opam cache"* ]]
|
|
}
|
|
|
|
@test "clean_dev_editors cleans VS Code and Zed caches" {
|
|
mkdir -p "$HOME/Library/Caches/com.microsoft.VSCode" "$HOME/Library/Application Support/Code" "$HOME/Library/Caches/Zed"
|
|
run env HOME="$HOME" PROJECT_ROOT="$PROJECT_ROOT" bash --noprofile --norc <<'EOF'
|
|
set -euo pipefail
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/lib/clean/dev.sh"
|
|
safe_clean() { echo "$2"; }
|
|
clean_dev_editors
|
|
EOF
|
|
|
|
[ "$status" -eq 0 ]
|
|
[[ "$output" == *"VS Code cached data"* ]]
|
|
[[ "$output" == *"Zed cache"* ]]
|
|
}
|
|
|
|
@test "clean_dev_editors does not clean VS Code workspace storage" {
|
|
mkdir -p "$HOME/Library/Application Support/Code/User/workspaceStorage/abc123"
|
|
touch "$HOME/Library/Application Support/Code/User/workspaceStorage/abc123/workspace.json"
|
|
|
|
# Source and run the function
|
|
source "$PROJECT_ROOT/lib/core/common.sh"
|
|
source "$PROJECT_ROOT/bin/clean.sh"
|
|
clean_dev_editors > /dev/null 2>&1 || true
|
|
|
|
# Verify the file still exists
|
|
[ -f "$HOME/Library/Application Support/Code/User/workspaceStorage/abc123/workspace.json" ]
|
|
}
|