-
-
Notifications
You must be signed in to change notification settings - Fork 88
Description
Seu pedido de recurso está relacionado a um problema? Por favor, descreva.
Gostaria de implementar uma função para validar a CNH (Carteira Nacional de Habilitação) brasileira. Essa funcionalidade é útil para verificar a autenticidade e a validade do número da CNH fornecido, garantindo que ele esteja em conformidade com os critérios de formatação e validação.
Descreva a solução que você gostaria
- Uma função
is_valid_cnh
, que recebe um número de CNH (string) e retornaTrue
se a CNH for válida eFalse
caso contrário. - A função deve considerar os seguintes casos:
- O formato deve ser de 11 a 15 caracteres, incluindo números e letras.
- Deve validar se a CNH contém apenas caracteres permitidos (números e letras).
- Deve lidar com CNHs com e sem o caractere de verificação no final.
- Deve considerar CNHs que já foram canceladas ou que estão expiradas.
- A lógica da função deve ser implementada no futuro.
Descreva alternativas que você considerou
-
Seguir até o passo 8 do guia de contribuição.
-
Como parte do passo 8, criar o arquivo:
brutils-python/brutils/cnh.py
.def is_valid_cnh(cnh: str) -> bool: """ Validates the Brazilian CNH (Carteira Nacional de Habilitação). This function checks if the given CNH is valid based on the format and allowed characters. It considers the CNH with or without the verification character. Args: cnh (str): The CNH number to be validated. Returns: bool: True if the CNH is valid, False otherwise. Example: >>> is_valid_cnh('12345678900') True >>> is_valid_cnh('AB123456789') False >>> is_valid_cnh('123456789012345') True >>> is_valid_cnh('12345') False """ # implementar a lógica da função aqui
Importar a nova função no arquivo
brutils-python/brutils/__init__.py
:# CNH Imports from brutils.cnh import ( is_valid_cnh, )
E adicionar o nome da nova função na lista
__all__
do mesmo arquivobrutils-python/brutils/__init__.py
:__all__ = [ ... # CNH 'is_valid_cnh', ]
-
Como parte do passo 9, criar o arquivo de teste:
brutils-python/tests/test_cnh.py
.from unittest import TestCase from brutils.cnh import is_valid_cnh class TestCNH(TestCase): def test_is_valid_cnh(self): # Testes para CNHs válidas self.assertTrue(is_valid_cnh('12345678900')) self.assertTrue(is_valid_cnh('123456789012345')) self.assertTrue(is_valid_cnh('ABCDE123456789')) # Testes para CNHs inválidas self.assertFalse(is_valid_cnh('AB123456789')) # Formato inválido self.assertFalse(is_valid_cnh('12345')) # Muito curto self.assertFalse(is_valid_cnh('1234567890123456')) # Muito longo self.assertFalse(is_valid_cnh('1234-5678')) # Caracteres não permitidos self.assertFalse(is_valid_cnh('')) # Vazio # implementar mais casos de teste aqui se necessário
-
Seguir os passos seguintes do guia de contribuição.
Contexto adicional
Activity
LucasAlvws commentedon Oct 23, 2024
Posso pegar?
LucasAlvws commentedon Oct 23, 2024
@camilamaia
LucasAlvws commentedon Oct 25, 2024
Este é outro caso que não achei uma documentação de validação disso, eu deveria então apenas verifcar o tamanho da string se ele é numerica?
devid8642 commentedon Feb 2, 2025
Bora!
github-actions commentedon Feb 2, 2025
Issue 431 atribuida a devid8642 🚀"
"Verifique o guia de contribuição para mais informações sobre como submeter sua Pull Request."
github-actions commentedon May 13, 2025
devid8642 commentedon May 14, 2025
@camilamaia Vi agora que a pr foi fechada por mim (acho que fechei sem querer) foi por isso que o bot marcou inatividade? Posso reabri-lá para revisão novamente ou você acha que as validações que eu fiz não cumpriram com o objetivo da issue e é melhor manter a pr fechada mesmo?
camilamaia commentedon May 15, 2025
Oii @devid8642! Olha, vou te dizer que não sei o quê deu hah porque olhando parece só que vc fechou o PR duas vezes e não o bot. Mas vai entender, que doideira.
O bot foi só para tirar o assign da issue. Mas então posso te redicionar no assign da issue e aí vc reabre o PR, pode ser?
devid8642 commentedon May 15, 2025
@camilamaia Blz, então foi eu mesmo que fechei a PR, devo estar ficando louco mesmo com esse negócio de código kk. Vou reabrir aqui obrigado
github-actions commentedon Jul 20, 2025
github-actions commentedon Sep 21, 2025