This repository was archived by the owner on Jul 30, 2025. It is now read-only.
feat: Set up comprehensive Python testing infrastructure with Poetry #109
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Set Up Python Testing Infrastructure
Summary
This PR establishes a comprehensive testing infrastructure for the Radiata project using Poetry as the package manager and pytest as the testing framework.
Changes Made
Package Management
pyproject.tomlwith complete Poetry setuprequirements/*.txtfiles to PoetryTesting Framework Setup
Pytest Configuration:
test_*.pyand*_test.pyfilesapi,lib, andmodulesdirectoriesTest Markers: Added custom markers for test organization:
@pytest.mark.unit- For unit tests@pytest.mark.integration- For integration tests@pytest.mark.slow- For slow-running testsDirectory Structure
Shared Fixtures (conftest.py)
Created comprehensive fixtures for common testing needs:
temp_dir- Temporary directory managementmock_config- Mock configuration dictionariesmock_model- Mock diffusion modelssample_image_path- Test image generationmock_gradio_interface- Mock Gradio interfacesenv_vars- Environment variable managementmock_torch- Mock PyTorch for CPU-only testsmock_pipeline- Mock diffusion pipelinescapture_logs- Log capturing during testsConfiguration Files
Running Tests
Install Dependencies
Run Tests
You can run tests using either command:
Run Specific Test Markers
Coverage Reports
htmlcov/index.htmlin a browsercoverage.xmlfor CI integrationNotes
poetry.lockfile should be committed to ensure reproducible builds.Validation
The setup includes validation tests (
test_setup_validation.py) that verify:All validation tests pass successfully, confirming the infrastructure is ready for use.