Automação de Testes de Front-End com o Selenium
O desenvolvimento de softwares de qualidade depende da existência de testes para garantir a consistência do que foi programado. A automação de testes é um grande aliado nesse processo. Deste modo, com o crescimento do sistema e com a implementação de novas funcionalidades, tem-se a garantia de que aquilo que existia anteriormente não foi impactado.
A existência de testes que garantem a estabilidade do código é bastante comum no back-end das aplicações. Desta forma, muitos desenvolvedores já adotaram esta prática por compreender sua importância. Apesar disto, os testes na camada superior, o front-end, acabam sendo deixados de lado e não recebem a devida importância.
Sendo assim, quando é necessário modificar uma tela que possua um grande formulário, muito tempo é gasto para conferir se a funcionalidade original não foi impactada além do que se gasta testando se as mudanças foram executadas com sucesso.
Uma solução para este problema é a automação de testes para testar o front das aplicações. Neste cenário, surge o Selenium. Ele apresenta um conjunto de ferramentas que nos ajudam a melhorar o desempenho durante o desenvolvimento. Podemos destacar duas ferramentas principais deste conjunto: o Selenium WebDriver e o Selenium IDE.
Sumário
Automação de testes com selenium
Selenium IDE
O Selenium IDE é uma extensão presente no Chrome e Firefox que permite a criação de testes rápidos. Ele apresenta uma interface gráfica, não sendo necessário digitar nenhuma linha de código para a criação dos testes. Além disso, também permite gravar interações com a tela que podem ser reproduzidas posteriormente como testes.
Ele também possui opções para depuração que auxiliam na execução dos testes. Com isso, se apresenta uma ferramenta simples e prática, que permite o acompanhamento visual das interações com a tela, além da possibilidade de utilização de “asserts”.
No Chrome Web Store, esta ferramenta pode ser instalada clicando aqui.
Na imagem abaixo está apresentado um exemplo de teste do Selenium IDE. Neste teste, a partir do google, acessa-se a página da DTI e posteriormente a página de vagas.
Selenium WebDriver
O Selenium WebDriver é uma API (Application Programming Interface) que está disponível para várias linguagens de programação, tais como Java, C#, Ruby, Python e JavaScript. Ele permite que sejam criados testes automatizados para o front-end da mesma forma como são desenvolvidos os do back-end.
Uma característica muito interessante da ferramenta é a possibilidade de se criar testes contemplando vários navegadores diferentes, garantindo a funcionalidade do sistema em diversos ambientes. Com isso, é possível melhorar ainda mais a qualidade do que é desenvolvido e a portabilidade do código.
O programa de teste desenvolvido tem a capacidade de controlar um navegador, como o Chrome ou Firefox, e simular todas as interações do usuário com a tela. Para identificar algum dos elementos exibidos, por exemplo, pode-se passar o id, nome, classe css ou xpath do campo. Deste modo, quanto melhor o código do sistema testado, mais fácil será criar um teste. Um problema recorrente destes testes é a existência de ids repetidos numa mesma página, o que não só dificulta a execução como também é uma má prática. Outro ponto importante a ser ressaltado é que o WebDriver permite que o programador assista a simulação que está sendo executada, ou seja, uma janela do navegador escolhido é aberta, e permite que haja uma análise visual do que está sendo feito.
Mais informações sobre esta ferramenta e como incluí-la no projeto podem ser obtidos na página oficial do Selenium.
O Selenium além da automação de testes
Além de ser utilizado para testes de tela, o Selenium pode ser muito útil quando se deseja testar o funcionamento de todo o sistema. Um exemplo prático na tribo Triforce é a existência de um formulário que possui mais de 40 campos em um dos sistemas do nosso Squad Empresarial. A cada nova implementação era necessário preencher manualmente este formulário, tomando cerca de 5 a 10 minutos para os casos mais complexos. Com a automação gerada, após a criação do roteiro de preenchimento do formulário, está sendo possível preenchê-lo em menos de 1 minuto. Esta automação de testes proporcionou um ganho significativo para a produtividade da equipe.
Esta ferramenta possui, ainda, diversas aplicações práticas que podem acelerar o dia-a-dia do desenvolvedor, como, por exemplo, em um apontamento automático de horas.
Ao passo que apresenta uma enorme gama de possibilidades, a utilização do Selenium é extremamente simples. Com apenas alguns minutos, é possível criar pequenas POCs de aprendizado para, posteriormente, passar a utilizar a ferramenta em sistemas reais, alcançando ganhos palpáveis em um pequeno espaço de tempo.
Desenvolvimento de Software
Confira outros artigos
Testes end-to-end: sucesso na implementação da automação
Hoje, como você garante a entrega de valor, a confiabilidade e a eficiência do seu projeto? Com o intuito de responder a essa questão crucial, uma das melhores respostas é a automação de testes end-to-end. Muitas pessoas, principalmente nossos clientes, tendem a imaginar que automação de testes é apenas mais um tipo de teste de […]
Desenvolvimento de Software
Mecanismos de Acompanhamento no Desenvolvimento de Software
O uso de mecanismos de acompanhamento é imprescindível no mundo do desenvolvimento de software e pode potencializar a eficiência digital. O acompanhamento efetivo das operações é fundamental para garantir a entrega de soluções digitais de sucesso. Na nossa empresa, utilizamos uma metodologia única, o dti evolve, que incorpora inteligência artificial (IA) para acelerar nosso processo de […]
Desenvolvimento de Software
Eficiência digital com copilot: um caso de uso do GitHub
Em um mundo em constante evolução tecnológica, otimizar o tempo e potencializar a eficiência digital se torna cada vez mais crucial. Portanto, vamos apresentar alguns experimentos que estão sendo implementados com o Git Hub Copilot em busca de maior eficiência digital. Certamente quem nos acompanha sabe que estamos experimentando e introduzindo as melhores ferramentas de […]
Desenvolvimento de Software