feat: Set up comprehensive Python testing infrastructure with Poetry #87
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 Grover 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.tomlrequirements-gpu.txtandrequirements-tpu.txtTesting Framework
test_*.pyand*_test.pyfilesunit,integration, andslowDirectory Structure
Fixtures (in conftest.py)
temp_dir: Temporary directory for file operationsmock_config: Mock configuration dictionarysample_json_data: Sample JSON test datasample_jsonl_file: Creates temporary JSONL filesmock_model_checkpoint: Mock TensorFlow checkpoint structuremock_vocab_files: Mock vocabulary files for tokenizationsample_model_config: Model configuration matching project formatenvironment_variables: Common test environment setupcleanup_tensorflow: Automatic TensorFlow resource cleanupAdditional Configuration
.gitignorewith testing artifacts and Claude settingspoetry.lockfrom gitignore (should be committed)Running Tests
With Poetry (recommended):
Without Poetry:
Test Output
All validation tests pass successfully:
Notes
lm,sample, anddiscriminationpackagesNext Steps
Developers can now:
tests/unit/tests/integration/