feat: set up complete Python testing infrastructure with Poetry #117
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 complete testing infrastructure for the Python project using Poetry as the package manager and pytest as the testing framework. The setup provides a ready-to-use environment for writing and running tests with comprehensive tooling and configuration.
Changes Made
Package Management
pyproject.toml
with Poetry configurationrequirements.txt
to PoetryTesting Configuration
pytest configuration in
pyproject.toml
:test_*.py
and*_test.py
filesunit
,integration
,slow
Coverage configuration:
app
,lib
,task
,util
__init__.py
fileshtmlcov/
), and XML (coverage.xml
)Directory Structure
Test Fixtures (conftest.py)
temp_dir
: Temporary directory for file operationsmock_env_vars
: Mock environment variablesmock_config
: Test configuration dictionarymock_discord_client
: Mocked Discord clientmock_fastapi_client
: Mocked FastAPI clientsample_discord_message
: Sample Discord message datasample_api_response
: Sample API response datareset_environment
: Auto-reset environment variablesmock_async_context
: Mock async context managercapture_logs
: Log capture utilityDevelopment Commands
poetry run test
- Run all testspoetry run tests
- Alternative command (both work)Additional Updates
.gitignore
with:.pytest_cache/
,.coverage
,htmlcov/
, etc.).claude/*
)How to Use
Install dependencies:
Run all tests:
Run specific test categories:
Run with coverage:
Run without coverage:
poetry run test --no-cov
Validation
The setup includes validation tests (
test_setup_validation.py
) that verify:All validation tests pass successfully, confirming the infrastructure is properly configured.
Notes