A testing library for running language/compiler tests from YAML metadata.
Project description
Compiler Testing Lib
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.
Features
- 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.
Directory Structure
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
Installation
As a Python Library
pip install compiler-testing-lib
For Local Development
pip install -e .
Install Example Requirements
pip install -r compiler-testing-example/requirements.txt
Usage
1. Run Tests via Python
from 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)
2. Run Tests via Example Scripts
python3 compiler-testing-example/test.sh # Python runner (default)
python3 compiler-testing-example/test.sh js # Node.js runner
3. Run in Docker
Build the image:
cd images
./mount.sh
Run the container (auto-clones the example repo and runs tests):
./run.sh
Docker Image Details
- 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.
Adding/Updating Tests
- 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.
Syncing Generated Tests
- 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.
Additional code syntax checking
- 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.
Contributing
- 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.
License
MIT
For more examples, see the compiler-testing-example submodule.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file compiler_testing_lib-0.1.13.tar.gz.
File metadata
- Download URL: compiler_testing_lib-0.1.13.tar.gz
- Upload date:
- Size: 36.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f12f486b1b452258140787cef5c12e2161e7a31f81cab8130e829493b06f3183
|
|
| MD5 |
072264739c3a4af05a7acec7b1fe129f
|
|
| BLAKE2b-256 |
004043f3cc5986f56ba4f4a7d91e3295be817a922844b43e8aaa118e5c2e31ee
|
File details
Details for the file compiler_testing_lib-0.1.13-py3-none-any.whl.
File metadata
- Download URL: compiler_testing_lib-0.1.13-py3-none-any.whl
- Upload date:
- Size: 122.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
698f3ecbb9a12ac5f4c5b374267a3da18d58d2cfe7aa6c3905542d4275a3cace
|
|
| MD5 |
1459918f4cc865a93b8e993cf573ba77
|
|
| BLAKE2b-256 |
6df3dfe0b5d0bdd8f9fd6d3b6f24c99885ff9cd1f3b6a1a745c6465781c62e98
|