A flexible, multi-language testing framework for compiler and language feature validation. Designed to run language-specific tests defined in YAML files, with support for running tests via Python, Docker, or as a CI/CD step.
- Multi-language support: Organize tests for Python, JavaScript, and more.
- YAML-based test definitions: Centralized, versioned test metadata.
- Pluggable runners: Run tests using Python, Node.js, or any command-line tool.
- Docker integration: Build and run tests in isolated containers, with support for auto-cloning test repos.
- PyPI package: Installable as
compiler-testing-lib. - Submodule example repo: See
compiler-testing-examplefor a ready-to-use test suite.
compiler-testing-lib/ # Main library package
compiler_testing_lib/
__init__.py
runner.py
languages/ # Test definitions and source files (per language/version)
python/
v1.0/
test001.py
test002.py
test.yaml
setup.py
MANIFEST.in
...
compiler-testing-example/ # Example repo (as a git submodule)
images/ # Docker build and run scripts
python/
Dockerfile
run_in_container.py
run.sh
mount.sh
clean.sh
pip install compiler-testing-libpip install -e .pip install -r compiler-testing-example/requirements.txtfrom compiler_testing_lib.runner import TestRunner
runner = TestRunner(language='python', version='v1.0', max_errors=3, timeout=10, file_extension='py')
result = runner.run_tests(command_template='python3 main.py')
print(result)python3 compiler-testing-example/test.sh # Python runner (default)
python3 compiler-testing-example/test.sh js # Node.js runnerBuild the image:
cd images
./mount.shRun the container (auto-clones the example repo and runs tests):
./run.sh- Installs the latest
compiler-testing-libfrom PyPI. - Accepts
--git_usernameand--git_repositoryto auto-clone a test repo. - Runs all tests and prints results to the terminal.
- Place new test files and update
test.yamlin the appropriatelanguages/<lang>/<version>/directory insidecompiler_testing_lib/. - Rebuild and upload the package to PyPI for distribution.
- Use
./copy.sh <language> <version>from the repo root to pull tests from../compiler-tests-generator/output/<language>/<version>/intocompiler_testing_lib/languages/<language>/<version>/(e.g.,./copy.sh C v0.0). - The script cleans the destination version folder before copying, so ensure you have the desired generator output ready.
- The lib also checks syntax based on struct.json file in the
syntax/<version>directory. The tested code must implement all the expected structure (including static features) designed in the file and can't have additional features. It also does some code quality check, like main clause. Only working for Python now. Pending: pep8 and snake_case check.
- Fork the repo and create a feature branch.
- Add or update tests in
compiler_testing_lib/languages/. - Update
test.yamlas needed. - Run tests locally or in Docker.
- Submit a pull request.
MIT
For more examples, see the compiler-testing-example submodule.