A ausência de testes unitários pode indicar falta de maturidade no desenvolvimento

A ausência de testes unitários pode indicar falta de maturidade no desenvolvimento

A quantidade de boas práticas que são deixadas de lado em TI pode ser assustadora… Na semana passada, por exemplo, escrevi sobre documentação, um processo que, embora trabalhoso, contém um grande número de benefícios para as equipes de tecnologia.

Aproveitando a reflexão, parei para pensar em outras coisas que deveriam acontecer nos times de tecnologia para assegurar a qualidade de processos e de produtos, mas que geralmente não acontecem. Uma delas me chamou a atenção: a prática recorrente de testes unitários.

Em teoria, os testes unitários deveriam ser realizados pelos desenvolvedores assim que uma função é desenvolvida. Mas o que geralmente se vê é que há certa relutância em desenvolver esses testes. Afinal, por que alguém iria querer criar mais código para testar o que já foi desenvolvido?

Bom, não é difícil entender o porquê. Precisamos, a todo o momento, entregar novas funcionalidades, evoluir fluxos e aprimorar a experiência do cliente, certo? E entregar dentro do prazo, com rapidez, não é mais suficiente. As entregas têm que ter, cada vez mais, qualidade.

Por isso, é inviável negar o papel do teste unitário — que, por si só, garante o funcionamento do código em sua menor fração. 

Ou seja, testes unitários são essenciais para testar módulos, métodos, classes, funcionalidades, entre outros, e assegurar que aquela unidade está performando de acordo com o que é esperado dela.

Na minha visão, o teste unitário, assim como qualquer outro teste automatizado, é importante para assegurar que um produto ou funcionalidade vai performar mesmo depois de alguma alteração. É papel dos testes regressivos trazer essa segurança a um time, especialmente em um ambiente em que há tanta pressão para que inovações sejam colocadas em produção.

Se um time de desenvolvimento tem uma rotina para verificar se o código desenvolvido está fazendo o que deveria fazer, então esse time está protegido por uma “camada de segurança” que aumenta a confiança na entrega. Isso evita que um produto apresente falhas e que gere retrabalho.

Outra vantagem? Testes unitários, geralmente, levam segundos para testar toda uma aplicação, mesmo depois que diversas alterações foram feitas nela. Sem falar que, quando comparados aos testes de interface do usuário (que também devem existir, porque são igualmente importantes), eles são bem menos custosos.

Portanto, o cenário que temos quando decidimos levar os testes unitários a sério são várias rotinas de testes isoladas que podem ser executadas inúmeras vezes. Isso permite que anomalias no código sejam rapidamente identificadas e priorizadas para correção, especialmente aquelas que surgem depois de modificações e alterações. É como um sistema de alarmes minucioso que pisca toda vez que algo errado acontece. Parece conveniente, não é?

Vou até mais além. Não acho que testes de unidade sejam simplesmente um processo — eles são, na verdade, parte de uma cultura de qualidade em que o desenvolvedor e o QA trabalham juntos, sem a crença popular de que esses dois papéis estão sempre em guerra.

Na minha visão, os testes unitários e regressivos são componentes imprescindíveis do ágil. E por que? Porque sem isso, não tem progresso. É tentar codificar uma feature, e quebrar um código que funcionava e ninguém consegue rapidamente enteder o motivo.

Em times que prezam pela qualidade acima de tudo, fica claro que os testes unitários estão ali para ajudar na evolução da arquitetura, incentivar a refatoração e construir produtos que não deixem o usuário na mão. Por isso pode ser confuso entender o motivo pelo qual esses testes são deixados de lado com tanta frequência.

Não é incomum ver times de desenvolvimento ignorando a prática quando prazos apertam, ou preferindo que QAs façam testes unitários. Tudo bem que o QA faça um teste unitário aqui ou ali, mas quando falamos de cultura de qualidade, o papel do desenvolvedor é, também, de garantir a qualidade do que ele desenvolve.

Em outras palavras: todo mundo é responsável pela qualidade e o desenvolvedor não é exceção. No entanto, ainda falta maturidade para construir esse mindset na prática. E, enquanto os testes unitários não estiverem sendo feitos com mais frequência, é melhor duvidar que essa maturidade existe.


Esse artigo foi orginalmente publicado em daniloferreira.com

Thatyane Pontes

Software Engineering Specialist | @ Picpay

4 a

O uso de TDD ajuda bastante tbm. Assim não dá aquela sensação de “tempo perdido” depois da feature pronta e o desenvolvimento fica até mais tranquilo depois. Bem bacana os assuntos que você tem abordado. Beijo!

Vanessa Kounrouzan Matos

Experte Gouvernance du cycle de livraison

4 a

Concordo e reitero o que vc disse: teste unitário tem que ser feito pelo desenvolvedor. Para garantir que todos o façam minha dica é se aliar com o mais senior dos devs e fazer dele um coach quando devs mais juniors entram no time. O tech lead apresenta as boas práticas de desenvolvimento bem documentadas no confluence (opa olha aí o tópico da documentação lembrada de novo 😉) e eles seguem o exemplo.

Guilherme Kato

CTO at dr.consulta | CIO | AI | Product Management

4 a

👏🏻

Aline Vaz Monteiro

Coordenadora de Engenharia | PagBank PagSeguro

4 a

Muito bom ! 👏🏽👏🏽

Alexandre Ostafij

Agile Master | Agile Coach | Kanban Coach | Scrum Master | Gestão de Projetos | Gestão de Pessoas | Produtos

4 a

Ótimo material como sempre , Danilo estou utilizando os QA antes de tudo juntamente com os PO assim consigo diminuir os retrabalho com as escritas dos caras e ganho na velho idade da codificação

Entre para ver ou adicionar um comentário

Outros artigos de Danilo Ferreira

Outras pessoas também visualizaram

Conferir tópicos