Skip to content

Commit

Permalink
run-vmtest: rewrite test list merging script
Browse files Browse the repository at this point in the history
  • Loading branch information
theihor committed Jan 14, 2025
1 parent 71b5936 commit 05b25cd
Show file tree
Hide file tree
Showing 6 changed files with 79 additions and 48 deletions.
41 changes: 0 additions & 41 deletions run-vmtest/merge_test_lists.py

This file was deleted.

70 changes: 70 additions & 0 deletions run-vmtest/normalize_bpf_test_names.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
#!/usr/bin/python3

# This script normalizes a list of selftests/bpf test names. These
# lists have the following format:
# * each line indicates a test name
# * a line can contain an end-line comment, starting with #
#
# The test names may contain spaces, commas, and potentially other characters.
#
# The purpose of this script is to take in a composite allow/denylist
# (usually produced as an append of multiple different lists) and
# transform it into one clean deduplicated list.
#
# In addition to dedup of tests by exact match, subtests are taken
# into account. For example, one source denylist may contain a test
# "a_test/subtest2", and another may contain simply "a_test". In such
# case "a_test" indicates that no subtest of "a_test" should run, and
# so "a_test/subtest2" shouldn't be in the list.
#
# The result is printed to stdout

import sys

def clean_line(line: str) -> str:
line = line.split('#')[0] # remove comment
line = line.strip() # strip whitespace
return line

def read_clean_and_sort_input(file) -> list[str]:
input = []
for line in file:
line = clean_line(line)
if len(line) == 0:
continue
input.append(line)
input.sort()
return input

# Deduplicate subtests and yield the next unique test name
def next_test(lines: list[str]):

if not lines:
return

prev = lines[0]

def is_subtest(line: str) -> bool:
return ('/' in line) and ('/' not in prev) and line.startswith(prev)

yield lines[0]
for line in lines[1:]:
if prev == line or is_subtest(line):
continue
yield line
prev = line


if __name__ == '__main__':

if len(sys.argv) != 2:
print("Usage: merge_test_lists.py <filename>", file=sys.stderr)
sys.exit(1)

lines = []
with open(sys.argv[1]) as file:
lines = read_clean_and_sort_input(file)

for line in next_test(lines):
print(line)

14 changes: 8 additions & 6 deletions run-vmtest/prepare-bpf-selftests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,20 @@ function merge_test_lists_into() {
local out="$1"
shift
local files=("$@")
echo -n > "$out"

# first, append all the input lists into one
local list=$(mktemp)
echo -n > "$list"
# append all the source lists into one
for file in "${files[@]}"; do
if [[ -f "$file" ]]; then
echo "cat $file >> $out"
cat "$file" >> "$out"
echo "Include $file"
cat "$file" >> "$list"
fi
done

# then merge the list of test names
cat "$out" | python3 "$(dirname $0)/merge_test_lists.py" > "$out"
# then normalize the list of test names
$GITHUB_ACTION_PATH/normalize_bpf_test_names.py "$list" > "$out"
rm "$list"
}

# Read arrays from pipe-separated strings
Expand Down
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,6 @@ set -euo pipefail
GITHUB_ACTION_PATH=$(realpath ../..)

rm -f output.txt
cat input.txt | $GITHUB_ACTION_PATH/merge_test_lists.py 2>&1 > output.txt
$GITHUB_ACTION_PATH/normalize_bpf_test_names.py input.txt 2>&1 > output.txt
diff expected-output.txt output.txt

0 comments on commit 05b25cd

Please sign in to comment.