From f053e761ec6be5b77536dc7a9f982fb6db846d02 Mon Sep 17 00:00:00 2001 From: Fabian Meumertzheim Date: Mon, 24 May 2021 18:16:32 +0200 Subject: [PATCH] [infra] Allow shell script targets for all languages (#5802) For proper support of Bazel's runfiles tree, a shell script wrapper is also needed for C++ targets, see https://github.com/bazelbuild/rules_fuzzing/pull/149. This commit allows shell script fuzz targets for all languages. This also helps to consolidate the various fuzz target checks in OSS-Fuzz by removing a dependence on fuzzing_language. --- infra/base-images/base-runner/test_all.py | 31 +++++++++++-------- .../base-images/base-runner/test_all_test.py | 4 +-- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/infra/base-images/base-runner/test_all.py b/infra/base-images/base-runner/test_all.py index 70414688f..e7865ea4e 100755 --- a/infra/base-images/base-runner/test_all.py +++ b/infra/base-images/base-runner/test_all.py @@ -67,7 +67,15 @@ def is_elf(filepath): return b'ELF' in result.stdout -def find_fuzz_targets(directory, fuzzing_language): +def is_shell_script(filepath): + """Returns True if |filepath| is a shell script.""" + result = subprocess.run(['file', filepath], + stdout=subprocess.PIPE, + check=False) + return b'shell script' in result.stdout + + +def find_fuzz_targets(directory): """Returns paths to fuzz targets in |directory|.""" # TODO(https://github.com/google/oss-fuzz/issues/4585): Use libClusterFuzz for # this. @@ -84,10 +92,10 @@ def find_fuzz_targets(directory, fuzzing_language): continue if not os.stat(path).st_mode & EXECUTABLE: continue - # Fuzz targets are expected to be ELF binaries for languages other than - # Python and Java. - if (fuzzing_language != 'python' and fuzzing_language != 'jvm' and - not is_elf(path)): + # Fuzz targets can either be ELF binaries or shell scripts (e.g. wrapper + # scripts for Python and JVM targets or rules_fuzzing builds with runfiles + # trees). + if not is_elf(path) and not is_shell_script(path): continue if os.getenv('FUZZING_ENGINE') != 'none': with open(path, 'rb') as file_handle: @@ -156,16 +164,16 @@ def use_different_out_dir(): os.environ['OUT'] = initial_out -def test_all_outside_out(fuzzing_language, allowed_broken_targets_percentage): +def test_all_outside_out(allowed_broken_targets_percentage): """Wrapper around test_all that changes OUT and returns the result.""" with use_different_out_dir() as out: - return test_all(out, fuzzing_language, allowed_broken_targets_percentage) + return test_all(out, allowed_broken_targets_percentage) -def test_all(out, fuzzing_language, allowed_broken_targets_percentage): +def test_all(out, allowed_broken_targets_percentage): """Do bad_build_check on all fuzz targets.""" # TODO(metzman): Refactor so that we can convert test_one to python. - fuzz_targets = find_fuzz_targets(out, fuzzing_language) + fuzz_targets = find_fuzz_targets(out) if not fuzz_targets: print('ERROR: No fuzz targets found.') return False @@ -226,11 +234,8 @@ def get_allowed_broken_targets_percentage(): def main(): """Does bad_build_check on all fuzz targets in parallel. Returns 0 on success. Returns 1 on failure.""" - # Set these environment variables here so that stdout - fuzzing_language = os.getenv('FUZZING_LANGUAGE') allowed_broken_targets_percentage = get_allowed_broken_targets_percentage() - if not test_all_outside_out(fuzzing_language, - allowed_broken_targets_percentage): + if not test_all_outside_out(allowed_broken_targets_percentage): return 1 return 0 diff --git a/infra/base-images/base-runner/test_all_test.py b/infra/base-images/base-runner/test_all_test.py index 3771ec231..0cd067afc 100644 --- a/infra/base-images/base-runner/test_all_test.py +++ b/infra/base-images/base-runner/test_all_test.py @@ -28,11 +28,9 @@ class TestTestAll(unittest.TestCase): def test_test_all_no_fuzz_targets(self, mocked_print, _): """Tests that test_all returns False when there are no fuzz targets.""" outdir = '/out' - fuzzing_language = 'c++' allowed_broken_targets_percentage = 0 self.assertFalse( - test_all.test_all(outdir, fuzzing_language, - allowed_broken_targets_percentage)) + test_all.test_all(outdir, allowed_broken_targets_percentage)) mocked_print.assert_called_with('ERROR: No fuzz targets found.')