feat: Set up comprehensive Python testing infrastructure with Poetry#13
Open
llbbl wants to merge 1 commit intoarchiki:mainfrom
Open
feat: Set up comprehensive Python testing infrastructure with Poetry#13llbbl wants to merge 1 commit intoarchiki:mainfrom
llbbl wants to merge 1 commit intoarchiki:mainfrom
Conversation
- Created pyproject.toml with Poetry configuration and testing dependencies - Added pytest, pytest-cov, and pytest-mock for comprehensive testing - Configured pytest with coverage reporting (80% threshold), custom markers, and HTML/XML output - Set up proper testing directory structure with unit/ and integration/ folders - Created shared pytest fixtures in conftest.py for common testing needs - Added validation tests to ensure testing infrastructure works correctly - Updated .gitignore with testing artifacts and development environment entries - Configured coverage reporting with source filtering and exclusion rules
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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 TextCraft research project using Poetry as the package manager and pytest as the testing framework.
Changes Made
Package Management
pyproject.tomlwith Poetry configurationpytest ^7.4.0- Main testing frameworkpytest-cov ^4.1.0- Coverage reportingpytest-mock ^3.11.1- Mocking utilitiesTesting Configuration
pyproject.tomlwith:htmlcov/andcoverage.xmltest_*.pyand*_test.pyfilesunit,integration, andslowfor test categorizationDirectory Structure
Shared Test Fixtures
Created comprehensive fixtures in
conftest.py:temp_dir/temp_file- Temporary file system operationsmock_openai_client- Mock OpenAI API clientmock_environment- Mock environment configurationsample_crafting_tree- Test data for crafting mechanicsmock_alfworld_env/mock_textcraft_env- Mock game environmentssample_prompt_data- Mock prompt templatesmock_file_system- File system mockingclean_environment- Environment variable cleanupDevelopment Environment
.gitignorewith testing artifacts, IDE files, and development environment entriesRunning Tests
Basic Usage
Coverage Reports
htmlcov/directorycoverage.xmlfor CI integrationValidation
All infrastructure validation tests pass, confirming:
unit,integration,slow)Next Steps
Developers can now:
tests/unit/tests/integration/poetry run pytestThe testing infrastructure is ready for immediate use and provides a solid foundation for maintaining code quality throughout the project.