feat: Set up comprehensive Python testing infrastructure with Poetry #39
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 kubestriker project using Poetry as the package manager and pytest as the testing framework. The setup provides a solid foundation for writing and maintaining tests with proper coverage reporting and test organization.
Changes Made
Package Management
requirements.txt
to Poetry for better dependency managementpyproject.toml
: Centralized project configuration including dependencies, test settings, and coverage configurationTesting Framework
Test Configuration
kubestriker
packagehtmlcov/
directoryDirectory Structure
Test Fixtures
Created comprehensive fixtures in
conftest.py
:temp_dir
: Temporary directory managementmock_config
: Mock configuration datamock_kubeconfig
: Mock Kubernetes configurationmock_k8s_response
: Mock API responsesmock_vulnerability_data
: Mock security scan dataclean_env
: Environment variable isolationmock_requests_response
: HTTP response mockingcapture_logs
: Log capture utilitymock_websocket_client
: WebSocket mockingDevelopment Tools
.gitignore
: Added patterns for test artifacts, coverage reports, virtual environments, and IDE filespoetry run test
andpoetry run tests
commands available for running testsHow to Use
Install dependencies:
Run all tests:
Run specific test categories:
View coverage reports:
htmlcov/index.html
in a browsercoverage.xml
for CI toolsNotes
--cov-fail-under
value inpyproject.toml
to enforce coverage requirements (recommended: 80%)SelectMenu
package was removed from dependencies due to compatibility issues with modern Python versionsNext Steps
With this infrastructure in place, developers can now:
tests/unit/
directorytests/integration/
directory