Skip to content

Pradeep241094/pythonrules

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

4 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

PyRules Runner

A simple, efficient Python testing framework that provides test discovery at the method level, code coverage reporting, and basic linting capabilities. Unlike more complex testing frameworks, this lightweight solution focuses on simplicity and ease of use while still providing detailed test results.

Features

  • Method-level test discovery: Identifies individual test methods within unittest.TestCase classes
  • Multiple test types: Support for unit, integration, end-to-end, and regression tests
  • Code coverage reporting: Console and HTML coverage reports
  • Basic linting: PEP8 style checking with flake8
  • Simple configuration: JSON-based configuration for test groups and patterns
  • Clear reporting: Emoji-enhanced console output with detailed error information
  • Easy installation: Installable via pip with command-line interface

Installation

From PyPI (when published)

pip pyrulesrunner

From PyPI (when published)

pip install pyrulesrunner

From Source

git clone <repository-url>
cd pyrulesrunner
pip install -e .

With Optional Dependencies

# Install with coverage support
pip install pyrulesrunner[coverage]

# Install with linting support
pip install pyrulesrunner[lint]

# Install with all optional features
pip install pyrulesrunner[all]

Legacy Installation (Single File)

You can also use the standalone testrules.py script:

# Download testrules.py to your project
# Install dependencies
pip install coverage flake8

Usage

After installation, you can use the testrules command from anywhere:

# Run all tests
testrules
testrules --all

# Run specific test types
testrules unit
testrules integration
testrules e2e
testrules regression

# Run specific modules
testrules test_module1 test_module2

# Run test groups (defined in config)
testrules core
testrules api

# Run linting only
testrules lint
testrules --lint-only

# Run comprehensive check (linting + all tests)
testrules check
testrules --check

# Use custom configuration
testrules --config my_config.json

# Disable coverage
testrules --no-coverage

# Show help
testrules --help

Alternative Usage

You can also run it as a Python module:

python -m testrules --all
python -m testrules unit

Legacy Usage (Single File)

If using the standalone script:

# Run all tests
python testrules.py

# Run specific test types
python testrules.py unit
python testrules.py integration
python testrules.py e2e
python testrules.py regression

# Run specific modules
python testrules.py test_module1 test_module2

# Run linting
python testrules.py lint
python testrules.py check

Configuration

The test runner uses a testrules.json configuration file to define test patterns, groups, and settings:

{
  "test_patterns": {
    "unit": ["test_*.py", "*_test.py", "unit_test_*.py"],
    "integration": ["integration_test_*.py", "*_integration_test.py"],
    "e2e": ["e2e_test_*.py", "*_e2e_test.py"],
    "regression": ["regression_test_*.py", "*_regression_test.py"]
  },
  "test_groups": {
    "all": [],
    "core": ["test_core1", "test_core2"],
    "api": ["test_api1", "test_api2"],
    "fast": ["test_quick1", "test_quick2"],
    "slow": ["test_slow1", "test_slow2"]
  },
  "coverage_enabled": true,
  "html_coverage": true,
  "html_coverage_dir": "htmlcov",
  "coverage_config": {
    "source": ["."],
    "omit": [
      "*/tests/*",
      "*/test_*",
      "*/__pycache__/*",
      "*/venv/*",
      "*/env/*",
      "setup.py"
    ]
  },
  "lint_config": {
    "enabled": true,
    "max_line_length": 88,
    "ignore": ["E203", "W503"]
  }
}

Using in Your Project

  1. Install the package:

    pip install pyrulesrunner[all]
  2. Create a testrules.json configuration file in your project root:

    {
      "test_patterns": {
        "unit": ["test_*.py", "*_test.py"],
        "integration": ["integration_*.py"],
        "e2e": ["e2e_*.py"]
      },
      "test_groups": {
        "fast": ["test_utils", "test_models"],
        "slow": ["test_integration", "test_e2e"]
      },
      "coverage_enabled": true,
      "html_coverage": true
    }
  3. Run your tests:

    # Run all tests
    testrules
    
    # Run only fast tests
    testrules fast
    
    # Run unit tests with coverage
    testrules unit
    
    # Run tests and linting
    testrules check

Example Output

πŸš€ Lightweight Test Runner
==================================================
πŸ“„ Loaded configuration from testrules.json
Command: all tests

πŸ” Discovering tests...
πŸ“ Found 4 test files

πŸ§ͺ Discovering test methods...
🎯 Total test methods discovered: 15

πŸš€ Running tests...
πŸ“¦ Running tests in module: test_calculator
  [1/15] test_calculator.TestCalculator.test_add ... βœ… PASS (0.001s)
  [2/15] test_calculator.TestCalculator.test_subtract ... βœ… PASS (0.001s)

============================================================
πŸ§ͺ TEST SUMMARY
============================================================
βœ… Passed:        14
❌ Failed:        1
πŸ’₯ Errors:        0
πŸ“Š Total:         15
πŸ“ˆ Success Rate:  93.33%
⏱️  Execution Time: 0.05 seconds

πŸ“Š COVERAGE REPORT
============================================================
Name                 Stmts   Miss  Cover
----------------------------------------
calculator.py           20      2    90%
utils.py               15      0   100%
----------------------------------------
TOTAL                   35      2    94%

βœ… All checks passed successfully!

Writing Tests

The test runner works with standard Python unittest framework:

import unittest

class TestExample(unittest.TestCase):
    def test_addition(self):
        """Test basic addition."""
        self.assertEqual(2 + 2, 4)

    def test_subtraction(self):
        """Test basic subtraction."""
        self.assertEqual(5 - 3, 2)

if __name__ == '__main__':
    unittest.main()

Test Types

Unit Tests

  • File patterns: test_*.py, *_test.py, unit_test_*.py
  • Purpose: Test individual functions or classes in isolation
  • Example: test_calculator.py

Integration Tests

  • File patterns: integration_test_*.py, *_integration_test.py
  • Purpose: Test interaction between multiple components
  • Example: integration_test_database.py

End-to-End Tests

  • File patterns: e2e_test_*.py, *_e2e_test.py
  • Purpose: Test complete user workflows
  • Example: e2e_test_user_registration.py

Regression Tests

  • File patterns: regression_test_*.py, *_regression_test.py
  • Purpose: Test previously fixed bugre they don't reoccur
  • Example: regression_test_issue_123.py

Programmatic Usage

You can also use the test runner programmatically:

from testrules import TestRunner, Config

# Create configuration
config = Config({
    "test_patterns": {
        "unit": ["test_*.py"]
    },
    "coverage_enabled": True
})

# Create and run test runner
runner = TestRunner(config)
test_results, coverage_obj = runner.run_tests(test_type="unit")

print(f"Tests run: {test_results.total}")
print(f"Passed: {test_results.passed}")
print(f"Failed: {test_results.failed}")

Project Structure

your_project/
β”œβ”€β”€ testrules.json           # Configuration file (optional)
β”œβ”€β”€ src/                     # Your source code
β”‚   β”œβ”€β”€ module1.py
β”‚   └── module2.py
β”œβ”€β”€ tests/                   # Your test files
β”‚   β”œβ”€β”€ test_module1.py      # Unit tests
β”‚   β”œβ”€β”€ test_module2.py      # Unit tests
β”‚   β”œβ”€β”€ integration_test_api.py    # Integration tests
β”‚   β”œβ”€β”€ e2e_test_workflow.py       # End-to-end tests
β”‚   └── regression_test_bug_fix.py # Regression tests
└── htmlcov/                 # HTML coverage reports (generated)

Development

To contribute to the project:

git clone <repository-url>
cd pyrulesrunner
pip install -e .[dev]

# Run the test runner's own tests
testrules test_testrules

# Run all example tests
testrules comprehensive

Requirements

  • Python 3.7+
  • Optional: coverage>=6.0 for coverage reporting
  • Optional: flake8>=4.0 for linting

Troubleshooting

Common Issues

  1. Module Import Errors

    • Ensure your test files are in the Python path
    • Check that all dependencies are installed
    • Verify file names match the expected patterns
  2. Coverage Not Working

    • Install coverage: pip install pyrulesrunner[coverage]
    • Ensure coverage is enabled in configuration
  3. Linting Not Working

    • Install flake8: pip install pyrulesrunner[lint]
    • Check that your Python files are accessible

Getting Help

If you encounter issues:

  1. Check that all dependencies are installed
  2. Verify your test file naming follows the expected patterns
  3. Ensure your test files contain valid unittest.TestCase classes
  4. Check the configuration file syntax if using custom settings

Contributing

This is a lightweight test runner designed for simplicity. If you need more advanced features, consider using pytest or other full-featured testing frameworks.

License

This project is open source under the MIT License. Feel free to modify and distribut

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors