Skip to main content

Pacote para testes automatizados em Python, com integração ao pytest e cobertura de código.

Project description

📚 SmartTestPy - Framework Inteligente para Testes em Python

SmartTestPy é um pacote robusto e flexível para a criação de testes automatizados em Python. Com suporte ao pytest, unittest, geração de dados fake, mocks avançados e integração com APIs e bancos de dados, ele foi projetado para simplificar o processo de testes, desde o básico até casos avançados.


Funcionalidades Principais

  • Assertions personalizadas para validações detalhadas.
  • 🏷 Fixtures reutilizáveis para cenários complexos.
  • 🎭 Mocks inteligentes para testes isolados.
  • 🌐 Testes de API com validação de payloads, headers e status.
  • 🏦 Gerenciamento de banco de dados para testes integrados.
  • Manipulação de tempo com suporte ao freezegun.
  • 📊 Cobertura de código com relatórios automatizados.
  • Execução paralela de testes para maior performance.
  • 🛠 Compatível com frameworks como Django, Flask e FastAPI.
  • 🌍 Internacionalização (i18n) para mensagens e logs de testes.

Instalação

Instale o SmartTestPy diretamente do PyPI:

pip install SmartTestPy

💡 Requisitos: Python 3.6 ou superior.


🚀 Como Usar

Assertions Customizadas

from SmartTestPy.assertions import assert_status_code

class MockResponse:
    def __init__(self, status_code, text):
        self.status_code = status_code
        self.text = text

response = MockResponse(200, "OK")
assert_status_code(response, 200)

🧪 Fixtures e Mocks

from SmartTestPy.fixtures import fake_user

user = fake_user()
assert user['email'] is not None

🌐 Testes de API

from SmartTestPy.response_helpers import assert_json_response

response = client.get("/api/user/1/")
assert_json_response(response, {"id": 1, "name": "John Doe"})

Manipulação de Tempo

from SmartTestPy.time_utils import fixed_time

assert fixed_time().strftime("%Y-%m-%d") == "2025-01-01"

🏃 Executando os Testes

pytest tests/ --maxfail=1 --disable-warnings -v

📈 Para gerar relatório de cobertura:

pytest --cov=SmartTestPy --cov-report=html

🏰 Estrutura do Projeto

SmartTestPy/
│
├── SmartTestPy/                # 📞 Código do pacote
│   ├── __init__.py
│   ├── assertions.py           # ✅ Assertions personalizadas
│   ├── fixtures.py             # 🏷 Fixtures e mocks reutilizáveis
│   ├── response_helpers.py     # 🌐 Testes e validações de APIs
│   ├── time_utils.py           # ⏳ Manipulação de tempo
│
├── tests/                      # 🧪 Testes unitários
│   ├── test_assertions.py
│   ├── test_fixtures.py
│   ├── test_response_helpers.py
│   └── test_time_utils.py
│
├── setup.py                    # ⚙️ Configuração do pacote
├── pyproject.toml              # 📚 Configuração moderna
├── README.md                   # 📚 Documentação do projeto
├── LICENSE                     # 🌍 Licença MIT
└── MANIFEST.in                 # 🗉 Inclusão de arquivos extras

🌐 Compatibilidade

  • ✅ Python 3.6+
  • 🚀 Compatível com Django, Flask e FastAPI.
  • 🐍 Suporte a pytest, unittest e execução paralela com pytest-xdist.

📝 Licença

Distribuído sob a Licença MIT. Veja o arquivo LICENSE para mais detalhes.


👨‍💻 Autor

Desenvolvido por Roberto Lima 🚀✨


💬 Contato


Gostou do projeto?

Deixe uma ⭐ no repositório e compartilhe com a comunidade! 🚀✨

git clone https://github.com/robertolima-dev/SmartTestPy.git
cd SmartTestPy
pip install -e .

🌟 O que este README oferece?

  • 🎯 Descrição clara do projeto e seu propósito.
  • 🛠 Instruções detalhadas de instalação e uso prático.
  • 🧪 Guia de testes para garantir que o código funciona.
  • 🏰 Estrutura do projeto para facilitar a navegação.
  • 🔄 Seção de contribuição para quem deseja ajudar no desenvolvimento.
  • 📝 Licença e informações do autor para transparência.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

smarttestpy-1.1.2.tar.gz (8.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

smarttestpy-1.1.2-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file smarttestpy-1.1.2.tar.gz.

File metadata

  • Download URL: smarttestpy-1.1.2.tar.gz
  • Upload date:
  • Size: 8.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.7

File hashes

Hashes for smarttestpy-1.1.2.tar.gz
Algorithm Hash digest
SHA256 74a5da6fd3a4f63b5fa7e4bdbfbdff4953bf842fb0d35a72d5def0ffdd5227ab
MD5 a6afe614741de3841cb37367cc75318e
BLAKE2b-256 81e1dd069d406cb66e1beea0f878f6f64c7e6cd771128eb06331edbfc0db5954

See more details on using hashes here.

File details

Details for the file smarttestpy-1.1.2-py3-none-any.whl.

File metadata

  • Download URL: smarttestpy-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 10.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.7

File hashes

Hashes for smarttestpy-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4dcb4e7a73d456a5f5d998bd83dc1e57bf922cde47fd3f408d4d65aea88c8074
MD5 5801855b19c21ba34e9c1d83b83d82ec
BLAKE2b-256 5b98a2a93fc16bf58596e1c9b4f34cbba926e89aa1bc602f823a54f7cb126f1a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page