Poka Yoke: O que é e qual sua importância para testes automatizados?
Um dispositivo à prova de idiotas erros. Conceito desenvolvido pelo “gênio da engenharia” Shigeo Shingo e adotado no Lean Manufacturing (ou Sistema Toyota de Produção), a ideia e o sistema Poka-Yoke se consiste em construir dispositivos que evitem erros ou defeitos na produção ou utilização de produtos. Tomadas que só podem ser conectadas na posição correta, a chave do carro que só pode ser retirada em ponto-morto ou até mesmo a tampa redonda de um bueiro que, graças ao seu formato, evita problemas de encaixe e impede que a mesma, literalmente, vá pelo ralo, são exemplos práticos de Poka-Yoke.
Sumário
Mas o Poka Yoke tem a ver com os testes automatizados?
Na metodologia ágil de desenvolvimento de softwares, os requisitos funcionais são divididos e executados ao longo do tempo, de maneira que é possível implantar um sistema com funcionalidades priorizadas e, de acordo com o andamento das etapas, fazer alterações – ou evolutivas – no projeto. Entretanto, é preciso ficar atento ao fato de que o desenvolvimento de novas funcionalidades pode causar impacto no desempenho daquilo que foi anteriormente construído.
Por isso, os testes automatizados, que fazem parte da metodologia ágil, são responsáveis por garantir de forma eficiente um primeiro nível de testes para verificar se tudo o que está implementado continua operando de forma correta. O roteiro básico para escrevê-los consiste em partir de um cenário inicial, efetuar uma operação do sistema e checar se o resultado está de acordo com o esperado.
O maior desafio do desenvolvedor de testes automatizados é manter sua validade ao longo do tempo, pois dessa forma o resultado de uma determinada operação, quando feita a partir de um mesmo cenário, será sempre igual. No entanto, o cenário para testes muitas vezes parte de um banco de dados “vivo”, ou seja, que está sendo utilizado para outras finalidades, tornando difícil garantir o mesmo ponto de partida da base desse banco.
Para contornar a utilização do banco de dados, são implementadas soluções de mock que podem ser diretamente em código, em arquivos (“*.csv” por exemplo) ou em bancos de dados light. A definição da estratégia de mock depende da forma de implementação do sistema.
Exemplos de Poka Yoke aplicados na prática
Para o desenvolvimento de um sistema de Gestão de Fretes de uma grande locadora de ativos foi utilizada uma arquitetura envolvendo injeção de dependências e inversão de controle. A partir da injeção de dependências as camadas do sistema são desacopladas do núcleo de negócio e é possível, por exemplo, alterar a fonte de dados que alimenta o sistema.
A imagem apresentada acima é um exemplo de arquitetura na qual os clientes executam as regras de negócio e podem escolher se será utilizado o banco de dados real ou mocks em CSV. Seja por meio dela, ou de outras formas, a ideia Poka Yoke possui diversas maneiras de aplicação. Vale a pena relacionar qual mais se encaixa no seu perfil de negócio / organização.
Sintetizando e resumindo
Sendo assim, para os testes automatizados do sistema, a fim de garantir um cenário equivalente capaz de gerar o mesmo resultado em todas as execuções, foi utilizada a estratégia de mocks através de arquivos CSV: criamos um repositório para os arquivos CSV contendo os cenários pré-definidos. Sendo assim, quando for necessária a execução dos testes, os desenvolvedores têm apenas que criar uma cópia do repositório e executar os testes em cima deles, garantindo o resultado desejado.
Baseado na ideia e no sistema Poka yoke, os testes automatizados eliminam erros e impedem o desperdício de tempo – e esforço – na correção de problemas que podem ser evitados. Essa solução já existe na sua empresa? Compartilhe sua experiência com a gente!
Aqui na dti, tanto o Poka Yoke quanto outras ideias de automatização de testes, são vistos e encarados como necessários para um melhor aproveitamento do que é a metodologia ágil na prática, sobretudo quando ela é aplicada em contextos como esse. Se você tem interesse em conhecer mais sobre o universo da tecnologia atrelado à filosofia organizacional do futuro, recomendamos o Os Agilistas, podcast da dti apresentado por um de nossso CEOs, Marcelo Szuster.
Ao longo dos episódios, ele se une a diferentes convidados para conversar e debater sobre temas relacionados à metodologia ágil, e, sobretudo, desmistificar esse método e filosofia organizacional. Quer saber mais sobre o tema? Então corre lá e dê streaming na sua plataforma de áudio favorita!
Por: André Mayer e Jéssica Saliba
Produtos Digitais
Confira outros artigos
Inteligência Conversacional: conecte-se com seus clientes!
Em um mundo cada vez mais digital, a capacidade de se conectar com os clientes de forma personalizada e eficiente é crucial para o sucesso de qualquer negócio. Dessa forma, a Inteligência Conversacional surge como uma poderosa ferramenta para alcançar esse objetivo, revolucionando a forma como as empresas interagem com seu público e otimizam suas […]
Produtos Digitais
Produtos digitais: entregas contínuas com IA
Nas últimas semanas, lançamos uma série de artigos sobre o uso de inteligência artificial no processo de construção de produtos digitais. Neles, apresentamos alguns aceleradores que a dti tem utilizado para potencializar a eficiência dos times. Abordamos a fase de concepção do produto, as atividades de gestão e design, o desenvolvimento do software e a […]
Produtos Digitais
Inteligência Artificial: acelerando o design e gestão de produtos digitais
Como aproveitar o melhor da Inteligência Artificial Generativa para gerar mais valor? Essa tem sido uma pergunta recorrente no mercado conforme as empresas buscam entender e adotar a tecnologia. Embora existam muitas dúvidas e hipóteses não comprovadas, parece ser consenso que os avanços na Inteligência Artificial impactarão significativamente muitas profissões. No relatório The economic potencial […]
Produtos Digitais