| # Copyright 2022 Google Inc. All rights reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| import argparse |
| import platform |
| import subprocess |
| from pathlib import Path |
| |
| parser = argparse.ArgumentParser() |
| parser.add_argument( |
| "--flatc", help="path of the Flat C compiler relative to the root directory" |
| ) |
| |
| args = parser.parse_args() |
| |
| # Get the path where this script is located so we can invoke the script from |
| # any directory and have the paths work correctly. |
| script_path = Path(__file__).parent.resolve() |
| |
| # Get the root path as an absolute path, so all derived paths are absolute. |
| root_path = script_path.parent.parent.absolute() |
| |
| # Get the location of the flatc executable, reading from the first command line |
| # argument or defaulting to default names. |
| flatc_exe = Path( |
| ("flatc" if not platform.system() == "Windows" else "flatc.exe") |
| if not args.flatc |
| else args.flatc |
| ) |
| |
| # Find and assert flatc compiler is present. |
| if root_path in flatc_exe.parents: |
| flatc_exe = flatc_exe.relative_to(root_path) |
| flatc_path = Path(root_path, flatc_exe) |
| assert flatc_path.exists(), "Cannot find the flatc compiler " + str(flatc_path) |
| |
| # Execute the flatc compiler with the specified parameters |
| def flatc(options, cwd=script_path): |
| cmd = [str(flatc_path)] + options |
| subprocess.check_call(cmd, cwd=str(cwd)) |
| |
| |
| def reflection_fbs_path(): |
| return Path(root_path).joinpath("reflection", "reflection.fbs") |
| |
| |
| def make_absolute(filename, path=script_path): |
| return str(Path(path, filename).absolute()) |
| |
| |
| def assert_file_exists(filename, path=script_path): |
| file = Path(path, filename) |
| assert file.exists(), "could not find file: " + filename |
| return file |
| |
| |
| def assert_file_doesnt_exists(filename, path=script_path): |
| file = Path(path, filename) |
| assert not file.exists(), "file exists but shouldn't: " + filename |
| return file |
| |
| |
| def get_file_contents(filename, path=script_path): |
| file = Path(path, filename) |
| contents = "" |
| with open(file) as file: |
| contents = file.read() |
| return contents |
| |
| |
| def assert_file_contains(file, needles): |
| with open(file) as file: |
| contents = file.read() |
| for needle in [needles] if isinstance(needles, str) else needles: |
| assert needle in contents, ( |
| "coudn't find '" + needle + "' in file: " + str(file) |
| ) |
| return file |
| |
| |
| def assert_file_doesnt_contains(file, needles): |
| with open(file) as file: |
| contents = file.read() |
| for needle in [needles] if isinstance(needles, str) else needles: |
| assert needle not in contents, ( |
| "Found unexpected '" + needle + "' in file: " + str(file) |
| ) |
| return file |
| |
| |
| def assert_file_and_contents( |
| file, needle, doesnt_contain=None, path=script_path, unlink=True |
| ): |
| assert_file_contains(assert_file_exists(file, path), needle) |
| if doesnt_contain: |
| assert_file_doesnt_contains(assert_file_exists(file, path), doesnt_contain) |
| if unlink: |
| Path(path, file).unlink() |
| |
| |
| def run_all(*modules): |
| failing = 0 |
| passing = 0 |
| for module in modules: |
| methods = [ |
| func |
| for func in dir(module) |
| if callable(getattr(module, func)) and not func.startswith("__") |
| ] |
| module_failing = 0 |
| module_passing = 0 |
| for method in methods: |
| try: |
| print("{0}.{1}".format(module.__name__, method)) |
| getattr(module, method)(module) |
| print(" [PASSED]") |
| module_passing = module_passing + 1 |
| except Exception as e: |
| print(" [FAILED]: " + str(e)) |
| module_failing = module_failing + 1 |
| print( |
| "{0}: {1} of {2} passsed".format( |
| module.__name__, module_passing, module_passing + module_failing |
| ) |
| ) |
| passing = passing + module_passing |
| failing = failing + module_failing |
| return passing, failing |