mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 16:02:45 +00:00 
			
		
		
		
	 616b3dc718
			
		
	
	
		616b3dc718
		
	
	
	
	
		
			
			basename from GNU coreutils 8.32 (the default on Debian Bullseye, as bash 5.2.0 does not include basename as a built-in command) does not accept multiple arguments. This will cause the command to fail with no output, and the error code not being propagated for some reason. This means that the loop never gets executed, and thus the check never actually does anything. This commit fixes that behavior by calling 'basename' multiple times.
		
			
				
	
	
		
			25 lines
		
	
	
	
		
			793 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			25 lines
		
	
	
	
		
			793 B
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| 
 | |
| set -eo pipefail
 | |
| 
 | |
| script_path=$(cd -P -- "$(dirname -- "$0")" && pwd -P)
 | |
| cd "${script_path}/.."
 | |
| 
 | |
| MISSING_FILES=n
 | |
| 
 | |
| while IFS= read -r FILENAME; do
 | |
|     # Simply search whether the CMakeLists.txt *ever* mention the test files.
 | |
|     if ! grep -qF "${FILENAME}" Tests/AK/CMakeLists.txt ; then
 | |
|         echo "Tests/AK/CMakeLists.txt is either missing the test file ${FILENAME} or is not in the commit's staged changes"
 | |
|         MISSING_FILES=y
 | |
|     fi
 | |
| done < <(
 | |
|     git ls-files 'Tests/AK/Test*.cpp' | xargs -n1 basename
 | |
| )
 | |
| 
 | |
| if [ "n" != "${MISSING_FILES}" ] ; then
 | |
|     echo "Some files are missing from the Tests/AK/CMakeLists.txt."
 | |
|     echo "If a new test file is being added, ensure it is in the CMakeLists.txt."
 | |
|     echo "This ensures the new tests are always run."
 | |
|     exit 1
 | |
| fi
 |