SlideShare una empresa de Scribd logo
1 de 4
Caso 1 – Bom dia por quê?

Vocês são funcionários de uma empresa de desenvolvimento de software, alocados em diferentes
projetos nos diversos clientes. Um belo dia cada um de vocês foi convidado para participar de
uma reunião emergencial após o expediente, convocada pelo diretor de desenvolvimento a pedido
de uma de suas equipes.

A equipe do projeto estava desenvolvendo um software e algumas funcionalidades já estavam em
uso em ambiente de produção. Tratava-se de uma aplicação para um famoso teatro que tinha
como objetivo automatizar os pontos de venda de ingressos e gerenciamento das apresentações.

Sempre que havia uma atração famosa o sistema de vendas aleatoriamente travava. Era preciso
reiniciar o servidor para que tudo voltasse ao normal. O servidor estava hospedado em outra
empresa, o que dificultava o restabelecimento do serviço. O teatro não tinha interesse nenhum em
trazer os servidores para dentro de casa, até mesmo porque todos indícios apontavam a aplicação
– e não a infraestrutura – como o bicho-papão causador de problemas.

Na reunião, a equipe de desenvolvimento afirmou que a aplicação estava utilizando a arquitetura
clássica de 3 camadas (apresentação, negócio e persistência), sendo que havia duas
apresentações: uma web, para as atividades administrativas; e uma outra que provia serviços
remotos acessados pelos pontos de venda para sincronização dos mapas das poltronas do teatro.

Segundo a equipe, o travamento só ocorre com as funcionalidades referentes à sincronização dos
mapas. O sistema não possuía casos de testes automatizados, a validação do sistema foi feita
pelo próprio usuário. Como o usuário não consegue simular os momentos de pico, esta falha do
sistema não foi detectada e nem consegue ser reproduzida em ambiente de homologação.

Um pequeno detalhe, o prazo para entrega do sistema já era piada de mal gosto, o projeto já
estava dando prejuízo, o cliente estava puto da vida com aquela novela e o presidente da
empresa decepcionado com a equipe do projeto. A equipe já tinha tentado de tudo, mas de nada
adiantou. Só resta agora passar a batata quente.

Para isso uma nova equipe foi criada, e vocês – participantes desta reunião – faziam parte dela.
Vocês não tiveram escolha, já era! E agora Josés, como arquitetos do BOPE, quais medidas
vocês tomariam para resolver esse perrengue?
Caso 2 – Isso é um Single Sign-On?

Um dia as coisas mudaram, a diretoria de sua empresa mudou. O mais novo diretor recebeu a
incumbência de reativar a Fábrica de Software da empresa e contratou vocês como equipe
especializada de arquitetos para resolver um problema recorrente em toda organização: o controle
de acesso das aplicações.

Todas as aplicações produzidas pela Fábrica de Software necessitavam de um módulo de
segurança, responsável por garantir a autenticação e o acesso seguro às funcionalidades de cada
sistema. Na antiga fábrica, este módulo era reconstruído para cada aplicação. Mas se tinha uma
coisa que o novo diretor não queria era retrabalho desnecessário.

A antiga fábrica teve sérios problemas com descumprimento de prazos e de altos custos com
retrabalho. Para o presidente da empresa a impressão que ficou foi: vender software é prejuízo
certo. Graças a novas oportunidades de negócios no mercado local, surgiu a oportunidade de
tentar de novamente. O novo diretor foi contrato para fazer dar certo desta vez e não podia
decepcionar.

Após diversas reuniões entre vocês e o novo diretor, foi identificado que o problema do controle de
acesso não era exclusividade da Fábrica de Software. Estava aí uma oportunidade de matar dois
coelhos com uma cajadada só: reduzir o custo da fábrica e também dos sistemas internos da
empresa. Isso sim seria um ótimo cartão de visitas.

Percebeu-se que cada sistema da empresa – construídos com as mais diversas tecnologias –
possuía uma base de segurança diferente. Olha só que coincidência, todos os sistemas foram
feitos pela antiga fábrica. Se tem algo de bom nisso é que vocês possuem acesso ao código-fonte
e podem modificar o que quiserem. Com base em levantamentos, vocês identificaram que a base
de dados da empresa era LDAP, mas cada cliente da fábrica poderia ter outra, desde banco de
dados até simples arquivos de texto.

Sob a perspectiva de arquitetura de software, como vocês resolveriam este desafio?
Caso 3 – Couve-flor não, é Workflow!

Almoço no shopping, equipe reunida. De repente um dos diretores da empresa, por coincidência,
encontra todo mundo reunido e fala: “surgiu um projeto novo que é a cara de vocês”. A primeira
coisa que vocês pensaram, mas ninguém pronunciou, foi: “lá vem bomba”. Era um sistema para
controle de fluxos de trabalho, utilizando uma tecnologia específica que demandava bastante
dedicação em pesquisas. Como era desafiador, vocês toparam!

Basicamente o objetivo do projeto era construir uma aplicação Web que reunisse a administração
dos fluxos de trabalho gerenciados por um motor de Workflow, mas não era só isso. A primeira
atividade que vocês se dedicaram foi meter a cara nos livros para descobrir que diabo faz tal
motor. E descobriram! Aprenderam que um motor de Workflow processa fluxos cadastrados e que
em determinados momentos delegam atividades para programas externos. O início de um fluxo
também pode ser disparado por um programa externo.

Se o motor já faz tudo, para que serve este projeto? Por dois motivos básicos. O primeiro é que as
telas Web providas pelo fabricante do motor para interagir com os fluxos é bizarra, altamente
toscas, complicadas de usar e completamente inviáveis para o usuário final. O segundo é que o
motor precisa delegar atividades que ele não sabe fazer, tais como: acessar sistemas da empresa,
buscar documentos na intranet e enviar mensagens para celular. Toda interação com o motor se
ocorre via WebServices, seja ela de entrada (motivo 1) ou de saída (motivo 2).

Como vocês – arquitetos de renome – projetariam esta aplicação que interage com o motor do
Workflow, com o usuário final e com os dados da organização? Como dizia Edson Gomes: “este
sistema é um vampiro, ô ô ôô”.
Caso 4 – Era uma vez uma aplicação que nunca ficava pronta...

Era uma vez um projeto que nunca ficava pronto. Por ironia do destino (ou não), apelaram para a
equipe de arquitetos da empresa e vocês foram escolhidos para para descascar o abacaxi. O
turnover do projeto estava alto, a equipe era composta por novatos e apenas um remanescente
dos primórdios do projeto.

Tratava-se de um sistema para apoiar atividades de fiscalização de estabelecimentos comerciais.
Os agentes levariam consigo um tablet que rodaria a dita cuja aplicação que nunca ficava pronta.
O gerente do projeto estava desesperado e relatou que cada tentativa de corrigir um problema,
outro pior aparecia. Sabe quando você puxa o lençol curto para cobrir a cabeça e descobre os pés
e vice-versa? Era isso que acontecia.

Vocês iniciaram os trabalhos fazendo a verificação da arquitetura e inspeção do código-fonte.
Segundo o antigo membro da equipe, a aplicação seguia o modelo de 3 camadas, onde a
apresentação utilizava a biblioteca de telas padrão do tablet e a camada de persistência utilizava
uma tecnologia simples de armazenamento.

Após muito penar, vocês descobriram que as camadas não seguiam as regras básicas. A camada
de negócio fazia referência às telas e aos objetos de acesso aos dados, as telas acessavam a
camada de persistência diretamente, pulando a camada de negócio. Ou seja, tava uma tremenda
tosqueira, pouca coisa estava como manda o figurino.

Vocês propuseram refazer a aplicação por completo, mas o gerente do projeto disse: “nem
pensar”. O prazo do projeto já havia estourado e o cliente deu o ultimato. Se falhar desta vez, o
projeto será cancelado com aplicação de multas exorbitantes.

A aplicação além de apresentar crash difíceis de rastrear, o processo de sincronização entre o
tablet e o servidor (na Internet) estava mais perdido do que cachorro que cai de caminhão de
mudança. A sincronização simplesmente não funcionava e essa era a principal preocupação do
cliente.

A solução era corrigir o que estava errado, que era praticamente tudo. Mas como fazer isso sem
assumir que iria jogar a aplicação fora e fazer outra? Use a criatividade pois o cliente colocou um
arquiteto da equipe dele para acompanhar o trabalho. Boa sorte!

Más contenido relacionado

Más de Cleverson Sacramento

Más de Cleverson Sacramento (20)

Demoiselle Avançado para Colaboradores – Maio/2012
Demoiselle Avançado para Colaboradores – Maio/2012Demoiselle Avançado para Colaboradores – Maio/2012
Demoiselle Avançado para Colaboradores – Maio/2012
 
Apresentação Demoiselle2 para novos concursados
Apresentação Demoiselle2 para novos concursadosApresentação Demoiselle2 para novos concursados
Apresentação Demoiselle2 para novos concursados
 
Configurações do domínio cleversonsacramento.com
Configurações do domínio cleversonsacramento.comConfigurações do domínio cleversonsacramento.com
Configurações do domínio cleversonsacramento.com
 
Lembretes Arrais Amador
Lembretes Arrais AmadorLembretes Arrais Amador
Lembretes Arrais Amador
 
Curso Arrais Amador - Balizamento
Curso Arrais Amador - BalizamentoCurso Arrais Amador - Balizamento
Curso Arrais Amador - Balizamento
 
Demoiselle Paraguay Dojo 18/01/2012
Demoiselle Paraguay Dojo 18/01/2012Demoiselle Paraguay Dojo 18/01/2012
Demoiselle Paraguay Dojo 18/01/2012
 
Demoiselle Paraguay Teoria 18/01/2012
Demoiselle Paraguay Teoria 18/01/2012Demoiselle Paraguay Teoria 18/01/2012
Demoiselle Paraguay Teoria 18/01/2012
 
Demoiselle Paraguay Abertura 18/01/2012
Demoiselle Paraguay Abertura 18/01/2012Demoiselle Paraguay Abertura 18/01/2012
Demoiselle Paraguay Abertura 18/01/2012
 
Eclipse Web: 10 anos de amor e ódio
Eclipse Web: 10 anos de amor e ódioEclipse Web: 10 anos de amor e ódio
Eclipse Web: 10 anos de amor e ódio
 
Minicurso Objective-C LinguÁgil 2011 (parte1)
Minicurso Objective-C LinguÁgil 2011 (parte1)Minicurso Objective-C LinguÁgil 2011 (parte1)
Minicurso Objective-C LinguÁgil 2011 (parte1)
 
Minicurso Objective-C LinguÁgil 2011 (parte2)
Minicurso Objective-C LinguÁgil 2011 (parte2)Minicurso Objective-C LinguÁgil 2011 (parte2)
Minicurso Objective-C LinguÁgil 2011 (parte2)
 
Dojo Objective-C e Xcode no Sepro
Dojo Objective-C e Xcode no SeproDojo Objective-C e Xcode no Sepro
Dojo Objective-C e Xcode no Sepro
 
Retrospectiva do Dojo do Demoiselle 2 no Consegi 2011
Retrospectiva do Dojo do Demoiselle 2 no Consegi 2011Retrospectiva do Dojo do Demoiselle 2 no Consegi 2011
Retrospectiva do Dojo do Demoiselle 2 no Consegi 2011
 
Palestra Demoiselle2 no Consegi 2011
Palestra Demoiselle2 no Consegi 2011Palestra Demoiselle2 no Consegi 2011
Palestra Demoiselle2 no Consegi 2011
 
Oficina Demoiselle2 no Consegi 2011
Oficina Demoiselle2 no Consegi 2011Oficina Demoiselle2 no Consegi 2011
Oficina Demoiselle2 no Consegi 2011
 
Pós Ruy - Resultado da avaliação
Pós Ruy - Resultado da avaliaçãoPós Ruy - Resultado da avaliação
Pós Ruy - Resultado da avaliação
 
Pós Ruy - 2 e 3 Camadas - Coding Dojo
Pós Ruy - 2 e 3 Camadas - Coding DojoPós Ruy - 2 e 3 Camadas - Coding Dojo
Pós Ruy - 2 e 3 Camadas - Coding Dojo
 
Pós Ruy - 2 e 3 Camadas - Web com JSF2
Pós Ruy - 2 e 3 Camadas - Web com JSF2Pós Ruy - 2 e 3 Camadas - Web com JSF2
Pós Ruy - 2 e 3 Camadas - Web com JSF2
 
Pós Ruy - 2 e 3 Camadas - Teste de componentes
Pós Ruy - 2 e 3 Camadas - Teste de componentesPós Ruy - 2 e 3 Camadas - Teste de componentes
Pós Ruy - 2 e 3 Camadas - Teste de componentes
 
Pós Ruy - 2 e 3 Camadas - Build de Componentes
Pós Ruy - 2 e 3 Camadas - Build de ComponentesPós Ruy - 2 e 3 Camadas - Build de Componentes
Pós Ruy - 2 e 3 Camadas - Build de Componentes
 

Último

ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdfENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
LeloIurk1
 
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
LeloIurk1
 
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdfReta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
WagnerCamposCEA
 
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptxResponde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
AntonioVieira539017
 
apostila projeto de vida 2 ano ensino médio
apostila projeto de vida 2 ano ensino médioapostila projeto de vida 2 ano ensino médio
apostila projeto de vida 2 ano ensino médio
rosenilrucks
 
Slide - EBD ADEB 2024 Licao 02 2Trim.pptx
Slide - EBD ADEB 2024 Licao 02 2Trim.pptxSlide - EBD ADEB 2024 Licao 02 2Trim.pptx
Slide - EBD ADEB 2024 Licao 02 2Trim.pptx
edelon1
 
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
LeloIurk1
 

Último (20)

ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdfENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
ENSINO RELIGIOSO 7º ANO INOVE NA ESCOLA.pdf
 
Modelo de Plano Plano semanal Educação Infantil 5 anossemanal Educação Infant...
Modelo de Plano Plano semanal Educação Infantil 5 anossemanal Educação Infant...Modelo de Plano Plano semanal Educação Infantil 5 anossemanal Educação Infant...
Modelo de Plano Plano semanal Educação Infantil 5 anossemanal Educação Infant...
 
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
5 bloco 7 ano - Ensino Relogioso- Lideres Religiosos _ Passei Direto.pdf
 
PROJETO DE EXTENSÃO I - AGRONOMIA.pdf AGRONOMIAAGRONOMIA
PROJETO DE EXTENSÃO I - AGRONOMIA.pdf AGRONOMIAAGRONOMIAPROJETO DE EXTENSÃO I - AGRONOMIA.pdf AGRONOMIAAGRONOMIA
PROJETO DE EXTENSÃO I - AGRONOMIA.pdf AGRONOMIAAGRONOMIA
 
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdfReta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
Reta Final - CNU - Gestão Governamental - Prof. Stefan Fantini.pdf
 
Currículo - Ícaro Kleisson - Tutor acadêmico.pdf
Currículo - Ícaro Kleisson - Tutor acadêmico.pdfCurrículo - Ícaro Kleisson - Tutor acadêmico.pdf
Currículo - Ícaro Kleisson - Tutor acadêmico.pdf
 
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptxResponde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
Responde ou passa na HISTÓRIA - REVOLUÇÃO INDUSTRIAL - 8º ANO.pptx
 
Rota das Ribeiras Camp, Projeto Nós Propomos!
Rota das Ribeiras Camp, Projeto Nós Propomos!Rota das Ribeiras Camp, Projeto Nós Propomos!
Rota das Ribeiras Camp, Projeto Nós Propomos!
 
apostila projeto de vida 2 ano ensino médio
apostila projeto de vida 2 ano ensino médioapostila projeto de vida 2 ano ensino médio
apostila projeto de vida 2 ano ensino médio
 
Seminário Biologia e desenvolvimento da matrinxa.pptx
Seminário Biologia e desenvolvimento da matrinxa.pptxSeminário Biologia e desenvolvimento da matrinxa.pptx
Seminário Biologia e desenvolvimento da matrinxa.pptx
 
LISTA DE EXERCICIOS envolveto grandezas e medidas e notação cientifica 1 ANO ...
LISTA DE EXERCICIOS envolveto grandezas e medidas e notação cientifica 1 ANO ...LISTA DE EXERCICIOS envolveto grandezas e medidas e notação cientifica 1 ANO ...
LISTA DE EXERCICIOS envolveto grandezas e medidas e notação cientifica 1 ANO ...
 
migração e trabalho 2º ano.pptx fenomenos
migração e trabalho 2º ano.pptx fenomenosmigração e trabalho 2º ano.pptx fenomenos
migração e trabalho 2º ano.pptx fenomenos
 
Slide - EBD ADEB 2024 Licao 02 2Trim.pptx
Slide - EBD ADEB 2024 Licao 02 2Trim.pptxSlide - EBD ADEB 2024 Licao 02 2Trim.pptx
Slide - EBD ADEB 2024 Licao 02 2Trim.pptx
 
DeClara n.º 75 Abril 2024 - O Jornal digital do Agrupamento de Escolas Clara ...
DeClara n.º 75 Abril 2024 - O Jornal digital do Agrupamento de Escolas Clara ...DeClara n.º 75 Abril 2024 - O Jornal digital do Agrupamento de Escolas Clara ...
DeClara n.º 75 Abril 2024 - O Jornal digital do Agrupamento de Escolas Clara ...
 
Antero de Quental, sua vida e sua escrita
Antero de Quental, sua vida e sua escritaAntero de Quental, sua vida e sua escrita
Antero de Quental, sua vida e sua escrita
 
Camadas da terra -Litosfera conteúdo 6º ano
Camadas da terra -Litosfera  conteúdo 6º anoCamadas da terra -Litosfera  conteúdo 6º ano
Camadas da terra -Litosfera conteúdo 6º ano
 
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
2° ANO - ENSINO FUNDAMENTAL ENSINO RELIGIOSO
 
Recomposiçao em matematica 1 ano 2024 - ESTUDANTE 1ª série.pdf
Recomposiçao em matematica 1 ano 2024 - ESTUDANTE 1ª série.pdfRecomposiçao em matematica 1 ano 2024 - ESTUDANTE 1ª série.pdf
Recomposiçao em matematica 1 ano 2024 - ESTUDANTE 1ª série.pdf
 
praticas experimentais 1 ano ensino médio
praticas experimentais 1 ano ensino médiopraticas experimentais 1 ano ensino médio
praticas experimentais 1 ano ensino médio
 
PROJETO DE EXTENSÃO I - Radiologia Tecnologia
PROJETO DE EXTENSÃO I - Radiologia TecnologiaPROJETO DE EXTENSÃO I - Radiologia Tecnologia
PROJETO DE EXTENSÃO I - Radiologia Tecnologia
 

Pós Ruy - Dinâmica dos Casos Reais

  • 1. Caso 1 – Bom dia por quê? Vocês são funcionários de uma empresa de desenvolvimento de software, alocados em diferentes projetos nos diversos clientes. Um belo dia cada um de vocês foi convidado para participar de uma reunião emergencial após o expediente, convocada pelo diretor de desenvolvimento a pedido de uma de suas equipes. A equipe do projeto estava desenvolvendo um software e algumas funcionalidades já estavam em uso em ambiente de produção. Tratava-se de uma aplicação para um famoso teatro que tinha como objetivo automatizar os pontos de venda de ingressos e gerenciamento das apresentações. Sempre que havia uma atração famosa o sistema de vendas aleatoriamente travava. Era preciso reiniciar o servidor para que tudo voltasse ao normal. O servidor estava hospedado em outra empresa, o que dificultava o restabelecimento do serviço. O teatro não tinha interesse nenhum em trazer os servidores para dentro de casa, até mesmo porque todos indícios apontavam a aplicação – e não a infraestrutura – como o bicho-papão causador de problemas. Na reunião, a equipe de desenvolvimento afirmou que a aplicação estava utilizando a arquitetura clássica de 3 camadas (apresentação, negócio e persistência), sendo que havia duas apresentações: uma web, para as atividades administrativas; e uma outra que provia serviços remotos acessados pelos pontos de venda para sincronização dos mapas das poltronas do teatro. Segundo a equipe, o travamento só ocorre com as funcionalidades referentes à sincronização dos mapas. O sistema não possuía casos de testes automatizados, a validação do sistema foi feita pelo próprio usuário. Como o usuário não consegue simular os momentos de pico, esta falha do sistema não foi detectada e nem consegue ser reproduzida em ambiente de homologação. Um pequeno detalhe, o prazo para entrega do sistema já era piada de mal gosto, o projeto já estava dando prejuízo, o cliente estava puto da vida com aquela novela e o presidente da empresa decepcionado com a equipe do projeto. A equipe já tinha tentado de tudo, mas de nada adiantou. Só resta agora passar a batata quente. Para isso uma nova equipe foi criada, e vocês – participantes desta reunião – faziam parte dela. Vocês não tiveram escolha, já era! E agora Josés, como arquitetos do BOPE, quais medidas vocês tomariam para resolver esse perrengue?
  • 2. Caso 2 – Isso é um Single Sign-On? Um dia as coisas mudaram, a diretoria de sua empresa mudou. O mais novo diretor recebeu a incumbência de reativar a Fábrica de Software da empresa e contratou vocês como equipe especializada de arquitetos para resolver um problema recorrente em toda organização: o controle de acesso das aplicações. Todas as aplicações produzidas pela Fábrica de Software necessitavam de um módulo de segurança, responsável por garantir a autenticação e o acesso seguro às funcionalidades de cada sistema. Na antiga fábrica, este módulo era reconstruído para cada aplicação. Mas se tinha uma coisa que o novo diretor não queria era retrabalho desnecessário. A antiga fábrica teve sérios problemas com descumprimento de prazos e de altos custos com retrabalho. Para o presidente da empresa a impressão que ficou foi: vender software é prejuízo certo. Graças a novas oportunidades de negócios no mercado local, surgiu a oportunidade de tentar de novamente. O novo diretor foi contrato para fazer dar certo desta vez e não podia decepcionar. Após diversas reuniões entre vocês e o novo diretor, foi identificado que o problema do controle de acesso não era exclusividade da Fábrica de Software. Estava aí uma oportunidade de matar dois coelhos com uma cajadada só: reduzir o custo da fábrica e também dos sistemas internos da empresa. Isso sim seria um ótimo cartão de visitas. Percebeu-se que cada sistema da empresa – construídos com as mais diversas tecnologias – possuía uma base de segurança diferente. Olha só que coincidência, todos os sistemas foram feitos pela antiga fábrica. Se tem algo de bom nisso é que vocês possuem acesso ao código-fonte e podem modificar o que quiserem. Com base em levantamentos, vocês identificaram que a base de dados da empresa era LDAP, mas cada cliente da fábrica poderia ter outra, desde banco de dados até simples arquivos de texto. Sob a perspectiva de arquitetura de software, como vocês resolveriam este desafio?
  • 3. Caso 3 – Couve-flor não, é Workflow! Almoço no shopping, equipe reunida. De repente um dos diretores da empresa, por coincidência, encontra todo mundo reunido e fala: “surgiu um projeto novo que é a cara de vocês”. A primeira coisa que vocês pensaram, mas ninguém pronunciou, foi: “lá vem bomba”. Era um sistema para controle de fluxos de trabalho, utilizando uma tecnologia específica que demandava bastante dedicação em pesquisas. Como era desafiador, vocês toparam! Basicamente o objetivo do projeto era construir uma aplicação Web que reunisse a administração dos fluxos de trabalho gerenciados por um motor de Workflow, mas não era só isso. A primeira atividade que vocês se dedicaram foi meter a cara nos livros para descobrir que diabo faz tal motor. E descobriram! Aprenderam que um motor de Workflow processa fluxos cadastrados e que em determinados momentos delegam atividades para programas externos. O início de um fluxo também pode ser disparado por um programa externo. Se o motor já faz tudo, para que serve este projeto? Por dois motivos básicos. O primeiro é que as telas Web providas pelo fabricante do motor para interagir com os fluxos é bizarra, altamente toscas, complicadas de usar e completamente inviáveis para o usuário final. O segundo é que o motor precisa delegar atividades que ele não sabe fazer, tais como: acessar sistemas da empresa, buscar documentos na intranet e enviar mensagens para celular. Toda interação com o motor se ocorre via WebServices, seja ela de entrada (motivo 1) ou de saída (motivo 2). Como vocês – arquitetos de renome – projetariam esta aplicação que interage com o motor do Workflow, com o usuário final e com os dados da organização? Como dizia Edson Gomes: “este sistema é um vampiro, ô ô ôô”.
  • 4. Caso 4 – Era uma vez uma aplicação que nunca ficava pronta... Era uma vez um projeto que nunca ficava pronto. Por ironia do destino (ou não), apelaram para a equipe de arquitetos da empresa e vocês foram escolhidos para para descascar o abacaxi. O turnover do projeto estava alto, a equipe era composta por novatos e apenas um remanescente dos primórdios do projeto. Tratava-se de um sistema para apoiar atividades de fiscalização de estabelecimentos comerciais. Os agentes levariam consigo um tablet que rodaria a dita cuja aplicação que nunca ficava pronta. O gerente do projeto estava desesperado e relatou que cada tentativa de corrigir um problema, outro pior aparecia. Sabe quando você puxa o lençol curto para cobrir a cabeça e descobre os pés e vice-versa? Era isso que acontecia. Vocês iniciaram os trabalhos fazendo a verificação da arquitetura e inspeção do código-fonte. Segundo o antigo membro da equipe, a aplicação seguia o modelo de 3 camadas, onde a apresentação utilizava a biblioteca de telas padrão do tablet e a camada de persistência utilizava uma tecnologia simples de armazenamento. Após muito penar, vocês descobriram que as camadas não seguiam as regras básicas. A camada de negócio fazia referência às telas e aos objetos de acesso aos dados, as telas acessavam a camada de persistência diretamente, pulando a camada de negócio. Ou seja, tava uma tremenda tosqueira, pouca coisa estava como manda o figurino. Vocês propuseram refazer a aplicação por completo, mas o gerente do projeto disse: “nem pensar”. O prazo do projeto já havia estourado e o cliente deu o ultimato. Se falhar desta vez, o projeto será cancelado com aplicação de multas exorbitantes. A aplicação além de apresentar crash difíceis de rastrear, o processo de sincronização entre o tablet e o servidor (na Internet) estava mais perdido do que cachorro que cai de caminhão de mudança. A sincronização simplesmente não funcionava e essa era a principal preocupação do cliente. A solução era corrigir o que estava errado, que era praticamente tudo. Mas como fazer isso sem assumir que iria jogar a aplicação fora e fazer outra? Use a criatividade pois o cliente colocou um arquiteto da equipe dele para acompanhar o trabalho. Boa sorte!