Archive for the ‘Linguagens de programação’ Category

Testes de aceitação automáticos para Flash com T-Plan Robot (VNCRobot)

Wednesday, October 28th, 2009

Finalmente, conseguiremos resolver um problema que há quase 2 anos assombra alguns desenvolvedores da globo.com, incluindo eu mesmo. Encontramos uma ferramenta de testes de aceitação automático flexível, open source, gratuita, black box e bem documentada, para testar SWF.

O T-Plan Robot é um VNC client, e pode se conectar a um computador remoto através da rede, controlando os inputs de mouse e teclado programaticamente, e implementa testes baseados em imagens, o que o torna flexível o suficiente para testar não apenas SWFs, mas qualquer outro tipo de aplicação com interface gráfica.

A ferramenta grava scripts, a partir da navegação do usuário pela interface no sistema operacional (bem parecido com que o Selenium faz, por exemplo, usando um plugin Firefox), em seu script próprio ou em Java, como o que eu fiz abaixo:


/**
 * Generated on Tue Oct 27 21:39:52 BRST 2009
 * T-Plan Robot v2.0.Beta (Build No. 2.0.Beta-20091014.1)
 * Default Java Converter version 2.0.0
 */
package teste;

import com.tplan.robot.ApplicationSupport;
import com.tplan.robot.AutomatedRunnable;
import com.tplan.robot.scripting.
	DefaultJavaTestScript;
import com.tplan.robot.scripting.JavaTestScript;
import java.awt.Point;
import java.io.File;
import java.io.IOException;

public class MyTest extends DefaultJavaTestScript
	implements JavaTestScript {

	public void test() {
		try {
			// Mouse move to=x:43,y:30 wait=200
			mouseMove(new Point(43, 30), "200");
			// Mouse click to=x:43,y:30 wait=1100
			mouseClick(new Point(43, 30), "1100");
			// Compareto "tela.bmp"
			compareTo(new File[] {
					new File("tela.bmp") });
			// Mouse click to=x:190,y:116
			mouseClick(new Point(190, 116));
		} catch (IOException ex) {
			ex.printStackTrace();
		}

	}

	public static void main(String args[]) {
		MyTest test = new MyTest();
		ApplicationSupport robot =
			new ApplicationSupport();
		AutomatedRunnable t = robot.
			createAutomatedRunnable(test, "javatest",
				new String[] { "–connect",
					"10.2.66.72:5902", "–password",
						"globocom" }, System.out,
						false);
		new Thread(t).start();
	}
}

Com isso, é possível integrá-lo à sua suite de testes automatizados!

Ainda levaremos um certo tempo para estudar a extensa documentação e aprender a tirar o máximo do T-Plan Robot. A partir de agora, iniciaremos o esforço de rodar testes do nosso player em vários sistemas operacionais virtualizados, com várias versões de Flash Player. Isso sem dúvida resultará em um aumento substancial da quantidade de entregas relacionadas ao player, já que eliminará o enorme tempo gasto atualmente com testes manuais e nos dará confiança.

Agradeço em nome de todos nós especialmente ao Carlo “zED” Caputo por ter perseguido junto conosco a solução desse problema e ter sugerido experimentarmos essa ferramenta para implementação dos testes no nosso player de vídeo Flash, e também ao Tiago Motta, por ter sido bem insistente em me passar os testes preliminares do T-Plan Robot, que eu finalmente pude terminar hoje. O próprio zED, em 2007, em apenas um dia, implementou uma ferramenta com o mesmo propósito e princípio. Infelizmente, apesar da excelente iniciativa, não recebeu apoio para amadurecê-la e interrompeu o projeto. Na época, ele já conhecia o T-Plan Robot, mas ainda não atendia a nossa necessidade.

Instalando Haskell (GHC 6.10) no Slackware 12.1

Wednesday, February 11th, 2009

Após instalar o GHC 6.10 tive o seguinte problema ao tentar rodar tanto o compilador Haskell ghc quanto o ambiente interativo ghci:

/opt/ghc/ghc: error while loading shared libraries: libedit.so.0: cannot open shared object file: No such file or directory

Essa library não é instalada por padrão no Slackware. Então, resolvi esse problema baixando-a e procedendo da seguinte maneira:

$ ./configure --prefix=/usr; make; make install

Se tudo der certo, temos então o arquivo libedit.so no diretório /usr/lib. Mas o ghc procura pela library pelo nome libedit.so.0. Então, crie um link simbólico para o arquivo e tente rodar o ghc novamente.

$ ln -s /usr/lib/libedit.so /usr/lib/libedit.so.0

Sun Tech Days 2008 in Sampa

Sunday, September 28th, 2008

Nos dias 29 e 30 de setembro de 2008 terei a oportunidade de estar no Sun Tech Days 2008 em São Paulo, junto com o pessoal da globo.com. Acredito que será uma ótima oportunidade de rever alguns amigos de lá e de conhecer novos colegas além de, é claro, aprender coisas novas durante o evento.

Globo Vídeos para iPhone/iPod touch

Friday, September 26th, 2008

Globo Vídeos iPhoneÉ com orgulho que anuncio, no dia do lançamento do iPhone no Brasil, o lançamento da versão iPhone/iPod touch do Globo Vídeos.

A infraestrutura e o site estavam prontos desde maio e o seu desenvolvimento se deu em aproximadamente 1 mês pela nossa equipe agile de Tecnologia WebMedia. Além de oferecer vídeos no formato H.264 para o QuickTime, o site apresenta uma interface otimizada para o Safari Mobile, aproveitando vários recursos legais desses dispositivos.

Além disso, possibilitamos que iPhones/iPods toquem vídeos nas versões clássicas dos sites que possuem o nosso player embed, incluindo o Globo Vídeos. Como o Safari Mobile não suporta Flash, quando acessado a partir de um desses dispositivos, o nosso player agora é exibido em uma versão não-Flash, servindo formato de vídeo H.264 em vez do flv normalmente oferecido.

Globo Vídeos

Aplicações web nativas - por que não?

Friday, June 6th, 2008

Recentes discussões sobre desempenho e escalabilidade de sistemas me levaram a seguinte questão: por que não se fala em frameworks e sistemas web server-side compilados diretamente para assembly nativo?

Este é um fenômeno curioso para mim, já que aplicações interpretadas (e até as compiladas para uma virtual machine), são menos performáticas. Quero que fique claro que não acredito que o uso de aplicações compiladas seja a solução para problemas de performance. Estas questões precisam ser primariamente endereçadas a melhorias arquiteturais e infraestruturais desenhadas para cada aplicação particular. Apenas questiono o fato de nós desenvolvedores, na grande maioria dos casos, não considerarmos essa hipótese ao desenvolver uma aplicação web, ou mesmo como meio de otimizar sistemas específicos cuja performance é crítica.

Por exemplo, ainda que soluções Java tenham desempenho excelente em muitos casos, seria muito interessante e perfeitamente justificável, do meu ponto de vista, o desenvolvimento de um framework para C++ que suportasse um esquema semelhante à tecnologia Servlet do Java - sem as limitações de performance de programas CGI - entre outras soluções web consagradas, além de bibliotecas que facilitassem o desenvolvimento de aplicações C++ para web.

É claro que não podemos negar que existem vantagens interessantes oferecidas pelas linguagens interpretadas neste campo. Mas, honestamente, não entendo porque o simples ganho de performance oferecido por aplicações nativas ainda não resultou no surgimento de pelo menos um framework desse gênero consolidado e de uma comunidade de desenvolvedores que, assim como eu, são aficionados por desempenho. :)

Selenium IDE && ( XPather || Firebug )

Wednesday, May 7th, 2008

Neste post inaugural, vamos demonstrar uma maneira de facilitar o trabalho de implementar testes de aceitação automatizados usando a extension Firefox Selenium IDE. Para ilustrar, tente fazer com o Selenium algum tipo de ação ou asserção sobre algum dos links da parte inferior do site www.google.com, por exemplo. Basicamente, há duas opções neste caso: ou clicar no link (com o botão direito ou esquerdo do mouse) para registrar uma ação/asserção, o que faz com que o Selenium automaticamente escreva um trecho de script, ou você pode escrever o script na mão. A primeira opção tem uma desvantagem: o Selenium poderá gravar como identificador do link o texto do link. Se o texto deste link mudar freqüentemente no site, você não vai querer identificá-lo desta maneira. A segunda opção sempre permite que você faça essa identificação pelo posicionamento desse elemento na árvore DOM do documento, por XPath.

No screencast abaixo, vamos demonstrar como o uso de duas outras extensions Firefox, o XPather e o Firebug, ajudam a descobrir rapidamente os XPaths dos elementos ao escrever os scripts.

Obs.: É necessário acrescentar uma barra (/) no início do XPath gerado para que o Selenium entenda.

P.S.: o Firebug é indispensável para uma infinidade de outras coisas. Portanto, se você gostar do XPather, mantenha as duas extensions instaladas. ;)