feat: Set up comprehensive Python testing infrastructure with Poetry #43
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 SimMIM project using Poetry as the package manager and pytest as the testing framework. The setup provides a ready-to-use testing environment where developers can immediately start writing tests.
Changes Made
Package Management
pyproject.toml
requirements.txt
to Poetrypackage-mode = false
for dependency management onlyTesting Dependencies
Added the following development dependencies:
pytest
(^7.4.0) - Core testing frameworkpytest-cov
(^4.1.0) - Coverage reportingpytest-mock
(^3.11.0) - Mocking utilitiesTesting Configuration
Configured pytest in
pyproject.toml
with:test_*.py
and*_test.py
filesdata
,models
, and root Python filesunit
,integration
,slow
Directory Structure
Created proper testing directory structure:
Shared Fixtures
Created comprehensive fixtures in
conftest.py
:temp_dir
- Temporary directory for test filesmock_config
- Mock configuration objectsample_yaml_config
- Sample YAML configuration filemock_dataset
- Mock dataset objectmock_model
- Mock model objectsample_image_tensor
- Sample image tensor for testingcaptured_output
- Capture stdout/stderr for testingreset_modules
- Auto-reset modules between testsAdditional Files
test_setup_validation.py
to verify the testing infrastructureConfiguration Updates
.gitignore
to include.claude/*
for Claude-specific settingsHow to Use
Install Dependencies
Run Tests
You can run tests using any of these methods:
Coverage Reports
Coverage reports are generated in multiple formats:
htmlcov/
directorycoverage.xml
Notes
__pycache__
from coverage reporting_pil_interp
import issue fromtimm
is handled gracefully in the validation testsNext Steps
Developers can now:
tests/unit/
tests/integration/