Guia para a Formação de Analistas de Negócios
Transcrição
Guia para a Formação de Analistas de Negócios
1 Guia para a Formação de Analistas de Negócios Draft 0.9 (Release Candidate) Paulo F. Vasconcellos Jan-Fev/2009 2 Créditos & Débitos Este livro é liberado sob a licença Creative Commons :: Atribuição – Uso Não-Comercial –Compartilhamento pela mesma licença 2.5 (http://creativecommons.org/licenses/by-nc-sa/2.5/br/) Você pode: copiar, distribuir, exibir e executar a obra criar obras derivadas Sob as seguintes condições: Atribuição. Você deve dar crédito ao autor original, da forma especificada pelo autor ou licenciante. Uso Não-Comercial. Você não pode utilizar esta obra com finalidades comerciais. Compartilhamento pela mesma Licença. Se você alterar, transformar, ou criar outra obra com base nesta, você somente poderá distribuir a obra resultante sob uma licença idêntica a esta. • Para cada novo uso ou distribuição, você deve deixar claro para outros os termos da licença desta obra. • Qualquer uma destas condições podem ser renunciadas, desde que Você obtenha permissão do autor. • Nada nesta licença impacta ou restringe os direitos morais do autor. Qualquer direito de uso legítimo (ou "fair use") concedido por lei, ou qualquer outro direito protegido pela legislação local, não são em hipótese alguma afetados pelo disposto acima. Este é um sumário para leigos da Licença Jurídica (na íntegra). ( http://creativecommons.org/licenses/by-nc-sa/2.5/br/legalcode ) Créditos & Débitos Outras informações Legais e sobre a Editora 3 4 Prefácio Créditos & Débitos Índice 5 6 Introdução Capítulo 1 Introdução 7 8 Capítulo 1 9 Introdução Parte I O Analista de Negócios 10 Capítulo 1 O Analista de Negócios 11 Capítulo 2 O Analista de Negócios A função do analista de negócios (AN) existe há décadas. De maneira resumida, podemos dizer que é aquele profissional responsável por interagir com clientes e usuários para entender seus problemas e necessidades. Acontece que na maioria das vezes esse profissional acumula outra função. E esta é a sua principal responsabilidade: gerenciar o projeto, desenhar a solução, programar. Não raro, o processo de levantamento e entendimento dos requisitos de clientes e usuários é visto assim mesmo, como uma atividade secundária de um projeto. Porque o gerente, analista ou programador foi alocado ali para fazer outra coisa – para criar e entregar uma solução. Houve um tempo em que a formação de analistas de sistemas contemplava de maneira satisfatória o estudo de métodos e práticas que auxiliavam no entendimento de problemas de negócio. No entanto, tanto o mercado quanto a academia começaram a privilegiar o domínio da solução, formando e contratando analistas-programadores. Não é arriscado dizer que a crescente dinâmica do mundo dos negócios e um certo imediatismo criaram essa distorção pouco lógica: equipes de tecnologia da informação (TI) estão repletas de gente preparada para o domínio da solução – criar, modelar, programar, entregar – e carentes de profissionais que realmente entendam o problema que precisa ser resolvido. Não por acaso, o alinhamento estratégico de TI com o negócio figura há tempos em listas de prioridades de diretores de informática, CIO's (Chief Information Office) e afins. Também não é por acaso que problemas com requisitos, com a participação dos usuários e com mudanças aparecem em todas as listas de problemas recorrentes em projetos mal sucedidos. Calma: não estou afirmando que a presença de um AN por si só promove o tal alinhamento estratégico e faz dos projetos de TI uma sequência de casos de sucesso. Depois dos gerentes de projetos, arquitetos, desenvolvedores ágeis e afins, não pretendo nomear o próximo superherói da nossa área. Mas tentarei convencê-lo, neste capítulo e no restante deste livro, que o AN pode ser sim um profissional muito importante em todas as organizações. Comparada a outras áreas de conhecimento que tratam do desenvolvimento de sistemas, a análise de negócios é uma das mais novas. Tão nova que podemos dizer que é uma área ainda em fase de definição1. O que não nos impede de traçar algumas linhas básicas visando a formação de analistas de negócios. Antes, porém, precisamos entender quem é o analista de negócios. Quais devem ser suas atribuições e quais habilidades ele precisa desenvolver. Esses são os temas deste primeiro capítulo. 1 Com pouco mais de 50 anos de idade, é claro que toda a área de desenvolvimento de sistemas (ou Engenharia de Software) ainda está em fase de definição. Mas, de todas as suas disciplinas, a análise de negócios é realmente a mais nova. E, talvez, a mais imatura. 12 Capítulo 2 A Análise de Negócios A análise de negócios é uma macrodisciplina que tem como principal objetivo o entendimento do negócio - seus problemas e oportunidades - e das necessidades, restrições e desejos de todas as partes interessadas2. Ela ainda é mais conhecida através das duas disciplinas que lhe dão forma: a Modelagem de Negócios e a Engenharia de Requisitos. Apesar de nascer e se desenvolver como uma parte da engenharia de software, veremos adiante que a análise de negócios não se limita a projetos para o desenvolvimento ou implantação de sistemas de informação. No contexto de um ou mais projetos, lançamos mão dos métodos e práticas que formam a análise de negócios para dominarmos o problema. Ou seja, para efetivamente entendermos as necessidades do negócio e de seus participantes. A motivação pode ser um problema que requer alterações em processos, políticas e sistemas. Mas também pode ser uma oportunidade de negócio, algo que igualmente gera requisitos de mudanças em diversas partes de uma organização. De qualquer maneira estamos tratando aqui de mudanças que, a princípio, serão implementadas na forma de projetos. Que não são, necessariamente, projetos de sistemas. A solução para um problema de negócio ou para aproveitamento de uma oportunidade pode se limitar ao redesenho de um processo, reestruturação de recursos ou alteração de políticas que não geram impacto em sistemas existentes nem demandam novos sistemas de informação. No entanto, dado o nível de informatização de empresas dos mais diversos ramos de atividade e portes, é de se esperar que a grande maioria das soluções encontradas gere mudanças em sistemas existentes ou requisitos para novos sistemas. Os negócios e seus processos estão sendo digitalizados. Por isso é difícil separar o analista de negócios de um projeto de software. Por isso este livro trata quase que exclusivamente de projetos para desenvolvimento ou implantação de sistemas de informação. É comum a apresentação da análise de negócios como uma função estratégica3. Apesar do trabalho ser predominantemente operacional. Ao participar ativamente do gerenciamento do portfólio de projetos e do gerenciamento do relacionamento com as unidades de negócios4, o AN assume relevância estratégica para a organização de TI. Como veremos no decorrer do livro, mesmo em projetos isolados um bom AN não ignora a estratégia da empresa. Ele sabe que um projeto, por menor que seja, tem ou deveria ter uma motivação estratégica. Ao cuidar para que todos os requisitos contribuam para a realização daqueles objetivos maiores, ele está na prática realizando o alinhamento estratégico de TI com o negócio. 2 Partes interessadas: tradução do termo stakeholder. 3 Por exemplo, um exagerado artigo da CIO Magazine recebeu o título “Analistas de Negócios valem Ouro”: http://cio.uol.com.br/gestao/2008/05/19/analistas-de-negocio-valem-ouro/ 4 Posição defendida por Richard Wyatt-Haines em “Align IT” (Wiley, 2007). Ele chega a indicar o uso do termo Gerente de Relacionamentos ao invés de analista de negócios. O Analista de Negócios 13 Já existe uma proposta de estrutura para o corpo de conhecimentos da análise de negócios, o BABoK (Business Analysis Body of Knowledge), do IIBA (International Institute of Business Analysis). Por vários motivos, explicados no tópico “IIBA & BABoK” abaixo, este livro não obedece essa estrutura. Este guia apresenta a análise de negócios em três partes: • Entendendo o Negócio: título que visa dar sentido a modelagem de negócios. Aqui o AN conhecerá métodos e práticas para entender um negócio, suas motivações, estrutura, processos e regras. Não é possível um correto entendimento dos requisitos de usuários se não conhecemos seu negócio. E vice-versa. • Entendendo o Usuário: nome alternativo para engenharia de requisitos. O conjunto de métodos e práticas que o AN pode utilizar para desenvolver e gerenciar requisitos – as necessidades, desejos e restrições de usuários e do negócio. • Viabilizando o Projeto: o AN auxilia unidades de negócios e a área de TI na viabilização de projetos. Esta terceira parte apresenta o que o AN deve aprender para viabilizar, obter financiamento e vender um projeto. 14 Capítulo 2 IIBA & BABoK Em 2003 foi fundado o IIBA em Toronto, Canadá. Seguindo os moldes do PMI, Project Management Institute, promete fazer pela análise de negócios o que este fez pelo gerenciamento de projetos: buscar o reconhecimento e divulgação da profissão e desenvolver e manter padrões para a prática da análise de negócios e para a certificação de seus praticantes. No centro desses objetivos está o principal produto do instituto: o corpo de conhecimentos da análise de negócios, ou BABoK. Seu primeiro draft, estranhamente numerado como 1.4, foi publicado em outubro de 2005. A versão disponível para download gratuito no momento da publicação deste livro, ainda um draft, é a 1.65. Produto do trabalho de dezenas de colaboradores, dentre eles renomados metodologistas como Scott Ambler6, o BABoK é estruturado em 6 disciplinas, ou áreas de conhecimento (KA – Knowledge Areas). Abaixo uma breve apresentação de cada uma delas, de acordo com documento publicado pelo IIBA em 20077. Figura 1 - As 6 disciplinas do BABoK 5 http://www.theiiba.org/AM/Template.cfm?Section=Body_of_Knowledge 6 http://en.wikipedia.org/wiki/Scott_Ambler 7 “The Business Analysis Profession”, apresentação elaborada por Kevin Brennan, vice-presidente do IIBA, em setembro de 2007. 15 O Analista de Negócios Disciplina Propósito Planejamento da Análise de Negócios Determinar o que precisa ser feito. Análise da Organização Entender o problema de negócio e o escopo das possíveis soluções. Elicitação Encontrar as reais necessidades das partes interessadas. Análise de Requisitos Descrever características e qualidades da solução que deve satisfazer as necessidades das partes interessadas. Avaliação e Validação da Solução Determinar se a solução é correta para as partes interessadas. Gerenciamento e Garantir que as partes interessadas concordam com as necessidades Comunicação dos Requisitos que serão satisfeitas. A princípio não há nada de errado com a estrutura acima. O nome das disciplinas e respectivos propósitos parecem cobrir tudo o que é necessário para uma eficaz análise de negócios. Porém, uma análise mais detalhada do BABoK revela algumas surpresas. A principal delas: a modelagem de negócios é sumariamente ignorada! Revirei tanto a versão 1.6 quanto a versão 2.0, que foi temporariamente disponibilizada para revisão pública, e pouquíssimo encontrei sobre modelagem de negócios. Na versão 1.6 o termo aparece apenas como sendo uma das habilidades que um arquiteto de negócios deve desenvolver. Na versão 2.0 a modelagem de negócios surge durante a apresentação da técnica “modelagem de processos” (6.15). O problema começa com o número aí: a técnica faz parte da disciplina análise de requisitos!? O problema aumenta quando o BABoK registra que “BPMN é a notação mais amplamente aceita para a modelagem de negócios”8. BPMN, de Business Process Modeling Notation, atende, como o próprio nome indica, apenas a modelagem de processos de negócios. A modelagem de negócios, como veremos na segunda parte do livro, é muito mais que isso. Também é questionável a afirmação de que esta seria a notação “mais amplamente aceita”. É a notação da moda, sem dúvida, mas será realmente a mais aceita? Infelizmente o BABoK não indica fontes que sustentem a afirmação. Voltarei ao tema na segunda parte deste livro, que trata da modelagem de negócios. O que interessa aqui é notar que o BABoK parece cometer uma grave omissão. Por mais de um ano tentei contatá-los, sem sucesso. Minha pergunta: se não é o AN quem faz a modelagem de negócios, então quem é? É visível que boa parte do BABoK trata exclusivamente da engenharia de requisitos. De maneira adequada, diga-se de passagem. Mas é cambeta por desconsiderar técnicas e métodos que nos auxiliam no entendimento do negócio. Desconheço fato mais contundente que prove o quanto a disciplina modelagem de negócios é mal compreendida. Espero que a segunda parte deste livro comprove minhas considerações. Antes precisamos conhecer melhor o tal Analista de Negócios. 8 BABoK version 2.0 – Draft for Public Review. IIBA (2008). 16 Capítulo 2 Definindo o Analista de Negócios O AN é o profissional responsável pelo entendimento, avaliação e comunicação das necessidades de um negócio e suas partes interessadas. Desta forma ele colabora com a definição de uma solução para determinado problema de negócio. TI e as áreas de negócios vivem em um conflito que parece eterno e tem uma origem muito bem identificada: a dificuldade de comunicação. Seus vocabulários são muito diferentes. O cenário piora quando TI desconhece ou não mostra comprometimento com os reais objetivos do negócio. De uns tempos para cá, algumas empresas forçaram a aproximação de diretores e gerentes de TI com o negócio. Enquanto um relativo sucesso foi obtido no relacionamento entre membros do alto escalão, na parte operacional os sérios problemas de comunicação persistiram. Entra o analista de negócios. Este profissional deve atuar como uma ponte entre o negócio e TI. Dominando os dois vocabulários, deve eliminar, principalmente, os sérios problemas de comunicação. Mas esta definição parece fazer do AN um tradutor ou intérprete, o que não é verdade. Voltemos à definição do primeiro parágrafo acima. Temos três verbos ali: Entender, Avaliar e Comunicar. É hora de detalhar o significado de cada um deles: • Entender: o AN entende o negócio – seus problemas e oportunidades, e também as necessidades e restrições de todas as partes interessadas, o que inclui toda a equipe técnica, além de clientes, patrocinadores e usuários. Essa compreensão é ampla, o que confere ao AN uma perspectiva única. Enquanto áreas de negócios e TI observam e cuidam de seus respectivos lados e interesses, o AN vislumbra os dois lados da moeda – que é única. • Avaliar: sendo assim o AN tem condições de efetuar uma isenta e clara avaliação dos problemas e / ou oportunidades e das soluções apresentadas. Sua avaliação, que sempre é executada com representantes dos dois lados, deve guiar a seleção da melhor solução, ou da mais viável. • Comunicar: durante todo o processo de entendimento e avaliação que, diga-se de passagem, podem ter praticamente a mesma duração do projeto, o AN se comunica de forma constante com todas as partes interessadas. Em dado momento, questionando e estudando. Em outros, avaliando e negociando. O AN é uma espécie de hub, um concentrador de comunicações. O risco de virar um gargalo para os projetos é grande. Mas este é assunto para outro momento. O Analista de Negócios 17 Uma Profissão, Vários Nomes Por antiga que seja a demanda, a profissão AN é relativamente nova. Por isso ainda vemos vários nomes sendo utilizados para referenciar o mesmo profissional. O nome também pode indicar algum tipo de especialização. Mas, de maneira geral, todos podem ser chamados de Analistas de Negócios. A lista abaixo apresenta alguns dos termos mais comuns utilizados atualmente: • Analista de Requisitos: como o próprio nome indica, se limita ao levantamento, desenvolvimento e, em alguns casos, ao gerenciamento de requisitos. • Analista de Processos: função que pega carona na “onda” BPM (Business Process Management). Especializa-se na análise e desenho de processos de negócios. • Multiplicadores: termo que indica claramente a responsabilidade de aprender (sistemas, com TI) e repassar o conhecimento, multiplicá-lo entre as áreas usuárias. A via de retorno, do negócio para TI, existe mas parece ser secundária. • Product Owner: ou Dono do Produto, termo cunhado no método ágil para gerenciamento de projetos Scrum. É o profissional que define requisitos e prioridades e gerencia o Product Backlog, ou seja, a relação de tudo o que precisa ser entregue pelo projeto. Outros termos, relativamente estranhos, são utilizados em algumas empresas brasileiras para identificar o profissional AN ou seu departamento. “Ponto Focal” e “Departamento de Tecnologia do Negócio” são 2 deles. No primeiro caso vê-se nitidamente a tentativa de posicionar o AN como a ligação entre usuários e a área de TI. De certa forma aproxima-se com a sugestão de Richard Wyatt-Haines citada anteriormente: Gerentes de Relacionamento, ao invés de analistas de negócios. O RUP (Rational Unified Process), famoso por sugerir algumas dezenas de papéis em equipes de desenvolvimento, tem vários nomes para o AN: Business-Process Analyst, Business Designer e UseCase Specifier. Mas ele não lista o termo Analista de Negócios9. No entanto, com a mídia e principalmente o IIBA promovendo o nome “Analista de Negócios”, é fácil supor que este será o termo mais comumente aceito. Mesmo que suas responsabilidades e habilidades permaneçam nebulosas por um certo tempo. Independente do nome, afinal, como se dá a formação de analistas de negócios, ou de requisitos, processos ...? 9 “The Rational Unified Process – An Introduction” (Second Edition). Philippe Kruchten. Addison-Wesley (2000). 18 Capítulo 2 Formando Analistas de Negócios Ainda não existem cursos técnicos ou de graduação que tratem exclusivamente da formação de analistas de negócios. A exemplo do que ocorre com gerentes de projetos, talvez esses cursos nem venham a existir. Ou melhor, existirão na forma de cursos de extensão, pós-graduação ou especialização. Tendo em vista os cursos regulares oferecidos atualmente, aquele cujo currículo mais se aproxima da profissão é conhecido no Brasil como “Sistemas de Informação”. No entanto, como colocado anteriormente, os currículos vigentes dão enorme ênfase ao domínio da solução: estudantes aprendem lógica e programação, modelagem de sistemas e até noções de gerenciamento de projetos. Mas pouco ou nada veem sobre o entendimento do negócio, clientes e usuários – ou seja, o conhecimento de métodos e práticas que levam ao domínio do problema. Nem sempre foi assim. Cursos e publicações voltadas para os analistas de sistemas, em um passado não muito remoto, se preocupavam mais com a definição do problema a ser resolvido. Não parece ser coincidência que tais temas tenham evaporado tão logo o mercado sinalizou com forte demanda por “analistas-programadores”. Ao interpretar etapas da análise de sistemas como atividades que agregavam pouco ou nenhum valor aos projetos de desenvolvimento, a solução descoberta foi a simples eliminação dessas “fases”. Não são raros os depoimentos de analistas que, tão logo alocados em um projeto, devem “gerar código”. Por isso não me surpreendo quando pesquisas indicam que cerca de 70% de nossos projetos falham – atrasam, custam mais ou simplesmente são cancelados. Surpresa, dado o cenário atual, seriam 70% de projetos de sucesso. Mas... retornemos ao tema central deste tópico. Por sua atuação muito próxima ou mesmo subordinada a área de TI, espera-se que o AN tenha uma formação técnica. Noções básicas de lógica, modelagem de dados e sistemas e até mesmo de alguma linguagem de programação dão considerável estofo para um AN. Mas isso não deveria ser visto como um pré-requisito. E, felizmente, o mercado parece estar vendo desta maneira. Empresas estão empregando administradores de empresas, contadores e até publicitários como analistas de negócios. Se a ausência de um background técnico é sentida, por outro lado esses profissionais levam para as empresas pontos de vista e conhecimentos novos, diferentes daqueles que predominam em uma organização de TI. No final das contas, é tudo uma questão de equilíbrio. Aqueles com formação técnica deverão desenvolver conhecimentos sobre administração e contabilidade, por exemplo. Enquanto isso, os demais AN's deverão conhecer um pouco mais sobre sistemas, arquitetura de aplicações etc. Este livro recomenda que um AN nunca atue sozinho, em nenhuma situação. Ele sempre é acompanhado de outro analista. Sendo assim, é fácil compor uma dupla com um profissional com formação de TI e outro de outra área qualquer. Além da troca de conhecimentos, do aprendizado conjunto, a dupla oferece ao projeto perspectivas totalmente complementares. Mas, afinal, qual é a formação de um analista de negócios? Quais habilidades ele deve desenvolver? O Analista de Negócios 19 Habilidades Não está no escopo deste livro o estudo das habilidades sociais que devem ser desenvolvidas por um AN. Apesar de não fazer parte do time que acha que este tipo de habilidade é inata e ponto, devo confessar minha total incapacidade de repassar esse tipo de conhecimento. Claro, no decorrer do livro não hesitarei em apresentar alguma dica, quando considerá-la realmente válida. Mas, definitivamente, não sei falar muito sobre liderança, negociação, postura, meditação e levitação. Me limitarei a apresentar uma breve lista de habilidades sociais mais importantes que um AN deve demonstrar. Depois, de maneira menos escorregadia, tratarei das habilidades técnicas, estas sim o foco deste trabalho. Habilidades Sociais Em inglês elas são chamadas de soft skills. É reconhecido que sua transferência, na forma de cursos de treinamento e principalmente de livros, é um tanto mais complicada. Enquanto algumas pessoas apresentam grande facilidade para assimilá-las, outras simplesmente manifestam barreiras que parecem intransponíveis. Tomemos como exemplo o ato de falar em público. Todos conhecemos diversas pessoas que tem verdadeiro pavor de subir em um palco e se pronunciar para um grupo de pessoas. Se este é o seu caso, comece a ficar preocupado: um AN deve falar em público em diversas ocasiões, facilitando sessões de workshop ou apresentando alternativas de soluções. Já vimos, a comunicação é uma das principais responsabilidades de um AN. A facilidade de comunicação, em qualquer meio, é uma das principais habilidades soft que ele deve desenvolver. O que podemos afirmar é que, mais que treinamentos e miraculosas técnicas para “destravamento total”, é a prática constante que lapida nossas habilidades sociais. A menos que você tenha algum trauma (trava) realmente sério, considere a prática frequente e as críticas de seus colegas como suas principais fontes de aprendizado de habilidades soft. A lista abaixo destaca as principais habilidades sociais que um AN deve desenvolver: • Aprendizado: um bom AN aprende rápido. E aprende direito. Sabe identificar as fontes mais ricas e eficazes e extrair delas todo conhecimento necessário. O AN tem o hábito de ler e de estudar. Quando confrontado com um novo negócio ou cenário, não hesita em disparar um processo de pesquisa. Em tempos de Internet e principalmente de Google, o bom AN sabe que não existem muitos impedimentos ao seu estudo. O AN não tem medo de perguntar. E sabe que nada é óbvio quando se trata de negócios e sistemas de informação. Entende que pode ser confundido com um chato de vez em quando, mas que isso faz parte de seu trabalho. E faz perguntas e mais perguntas, como uma criança de 3 anos de idade. O AN também sabe que o conhecimento tácito, aquele que está na cabeça das pessoas, pode ser só uma parte do que ele precisa. Por isso ele também aprende ao ler documentos, diagramas, sistemas e outros diversos tipos de conhecimento explícito. • Comunicação: o AN é um exímio comunicador. Conversando, escrevendo, apresentando e facilitando eventos – não importa o meio ou o público. Se o principal problema que o AN veio resolver é de comunicação entre áreas de negócios e TI, é simplesmente o cúmulo do absurdo imaginar um AN que não saiba se comunicar 20 Capítulo 2 muito bem. O que não pode significar que aquele tímido ou aquele relaxado não podem se transformar em excelentes AN's. Todo mundo, em todas as profissões, um dia teve que começar. Quando bem guiados, tímidos, relaxados e afins saberão driblar suas limitações. Um aspecto particularmente importante é a comunicação do AN com a equipe técnica. Ele precisará ensinar alguns conceitos e termos de negócio para coordenadores e desenvolvedores. Saber ensinar também deve fazer parte do currículo do analista de negócios. • Negociação: não basta se comunicar bem, o AN deve negociar bem. Em diversos momentos de um projeto isso é quase tudo o que ele estará fazendo: negociando o escopo com usuários e desenvolvedores, combinando prazos, avaliando mudanças. Como bom negociador, o AN elimina ou reduz atritos e ruídos. Sua capacidade de negociação pode ser especialmente exigida quando a viabilização de um projeto estiver sob sua responsabilidade. A obtenção de apoio da alta direção, os acertos com o patrocinador, a revisão de prioridades com a organização de TI – tudo isso é negociação. • Pensamento Sistêmico: habilidade que em algumas rodas é chamada de “(ante)visão do jogador de xadrez” e em outras de “sexto sentido”. Falando sério, esta é a famosa “Quinta Disciplina” de Peter Senge10, que para o AN tem dois significados fundamentais: i) ver inter-relacionamentos, em vez de cadeias lineares de causa-efeito; e ii) ver os processos de mudança, em vez de simples fotos instantâneas. O AN entende que durante um projeto o negócio continua vivo e que, desta forma, segue sujeito e gerador dos mais diversos tipos de mudanças. E entende que o próprio projeto é uma mudança, o que o leva a desenvolver uma ampla visão de todos os impactos que podem ser gerados por ele. • Capacidade de Síntese: o AN deve ser capaz de, a partir de informações diferentes oriundas dos mais diversos lugares, gerar um todo que seja coerente. Ele sabe destacar aquilo que é realmente fundamental em determinado contexto e, o mais importante, compilar dados e informações de forma a gerar um conjunto íntegro, alinhado e factível. Quando falamos de modelagem de negócio estamos falando de simplificação. O bom AN sabe que um bom modelo de negócio se limita aquilo que é realmente necessário para um projeto. Já na engenharia de requisitos, no entendimento dos usuários, o AN busca a uniformização e organização de todos os dados e informações desenvolvidas. É assim que ele demonstra sua capacidade de síntese. • Visão Crítica e Criativa: o bom AN sabe que não pode se limitar aos requisitos apresentados pelos usuários. Isso porque ele entende que os requisitos, logo que surgem, carecem de desenvolvimento, de amadurecimento. Por isso apresenta críticas e novas sugestões, debatendo-as com usuários e desenvolvedores. 10 “A Quinta Disciplina”, Peter M. Senge. Editora Best Seller (2000). O Analista de Negócios 21 Habilidades Técnicas Também conhecidas como hard skills, em inglês. É o tipo de conhecimento mais fácil de ser transferido, tanto em processos de socialização (treinamento, por exemplo), quanto em processos de internalização (a partir de livros, apostilas e afins). No decorrer deste livro apresentarei diversas técnicas, ferramentas e métodos que devem formar a base de habilidades técnicas de um analista de negócios. Neste momento me limitarei a listar e descrever brevemente as principais habilidades hard que um AN deve desenvolver. Vamos a elas: • Modelagem: é a capacidade de gerar abstrações de algo que existe no mundo real. Uma habilidade que também pode ser apresentada como “Pensamento Visual11”. Do AN será cobrado, principalmente, a capacidade de gerar modelos de negócios. Mas é importante que ele também saiba gerar outros modelos. Abaixo uma lista com os mais importantes: • Modelagem de Negócios: representação dos aspectos mais importantes de um negócio em determinado contexto, determinado projeto. Aqui o AN entende que “menos é mais”. Negócios são complexos por natureza. Um modelo de negócio não tenta reproduzir todos os detalhes, pelo contrário. Ele se limita ao que é estritamente fundamental para entender o negócio e comunicar tal entendimento. Como a modelagem de negócios é muito mal compreendida (e mal falada), vale a pena adiantar aqui que Balanced Scorecards e Mapas Estratégicos, por exemplo, podem fazer parte de um modelo de negócio. • Modelagem de Dados: dados e informações são recursos de uma empresa. Consequentemente, podem fazer parte de um modelo de negócios. Mas aqui o AN entende que existem regras e padrões específicos para a modelagem de dados, baseados principalmente nas teorias da modelagem Entidade-Relacionamento e modelagem multidimensional. • Modelagem de Sistemas: claro, não é muito recomendado que um AN seja convocado para desenvolver um modelo de sistema. Mas saber ler um modelo de sistema pode ser necessário, particularmente nas interações com a equipe de desenvolvimento. Noções básicas de modelagem, particularmente aquela orientada a objetos, são necessárias. O conhecimento do padrão de facto para modelagem de sistemas, a UML (Unified Modeling Language), também. Cabe adiantar que sugiro a utilização desta mesma linguagem para a geração de vários diagramas que podem compor o modelo de negócios. • Prototipação: porque protótipos são modelos. O AN deve conseguir gerar desenhos que representem idéias. Protótipos de interfaces talvez sejam os mais exigidos, mas não são os únicos. O desenho de Storyboards que representem navegações entre telas ou a simulação de um trecho de um processo de negócio também é uma habilidade que o AN deve assimilar. 11 O termo Pensamento Visual é sugerido, por exemplo, por Dan Roam no livro “The Back of the Napkin – Solving Problems and Selling Ideas with Pictures”, Portfolio (2008). 22 Capítulo 2 • • Engenharia de Requisitos: tentei encontrar outro nome para esta habilidade mas não aparaceu nenhum melhor que este. Engenharia de Requisitos compreende um vasto conjunto de habilidades hard que um AN deve dominar. As principais são: • Técnicas para o Desenvolvimento de Requisitos: entrevistas, sessões JAD (Joint Application Development), workshops, engenharia reversa, observação ativa e passiva, pesquisas e outras. O AN tem a sua disposição um leque de alternativas para efetivamente entender o usuário, suas necessidades e restrições. Cada projeto ou usuário pode requerer o uso de uma ou outra técnica. É importante que o AN demonstre versatilidade e agilidade para escolher as técnicas mais apropriadas. • Especificação e Estruturação da “Voz do Usuário”12: o usuário fala muita coisa, pede outro tanto. Em conversas ou documentos ele mistura requisitos, regras de negócios, definições de dados, requisitos de interface e mais um sem número de informações. Ele não precisa saber distinguir uma regra de um requisito, por exemplo. Essa responsabilidade é exclusiva do AN. Saber organizar a “voz do usuário” é uma das habilidades mais caras que um analista deve apresentar. Diretamente relacionada com uma habilidade soft citada anteriormente, a capacidade de síntese. Aqui falamos exclusivamente da porção hard deste trabalho, que demanda o domínio de técnicas e ferramentas que viabilizam a especificação e estruturação de requisitos e demais informações aprendidas. • Redação de Casos de Uso: um documento criado especificamente para facilitar a descoberta e descrição dos requisitos funcionais de um sistema. Durante o desenvolvimento deste trabalho fui surpreendido com o tamanho da confusão que existe em torno desta técnica que, a princípio, deveria ser muito simples. Casos de uso foram inventados por Ivar Jacobson13 no final da década de 1960, para entender melhor os requisitos de um sistema de telecomunicações. A técnica ganhou público quando foi incorporada à linguagem de modelagem UML. Infelizmente, ganhou público e um show de desinformação. • Preparação e Execução de Testes: porque o AN é a última pessoa que testa uma aplicação antes do usuário final. A preparação acontece quase que simultaneamente ao registro dos requisitos, através da redação de casos de testes, por exemplo. Aqui o AN fixa todos os critérios de aceite, indicando para a equipe de desenvolvimento todos os testes que executará quando receber a aplicação. São testes do tipo “caixapreta”, ou seja, visam exclusivamente validar a conformidade da aplicação em relação aos requisitos apresentados. Viabilização da Solução: além das habilidades sociais necessárias para a viabilização de um projeto, como comunicação e negociação por exemplo, o AN também deve dominar habilidades técnicas com tal fim. Merecem destaque: redação de documentos de visão ou propostas técnicas; elaboração de apresentações; facilitação de workshops; matemática financeira; e gerenciamento de portfólios. 12 Termo utilizado originalmente por Karl Wiegers em “Software Requirements”, Microsoft Press (1999). 13 http://en.wikipedia.org/wiki/Ivar_Jacobson O Analista de Negócios 23 Especialização Ao dominar as habilidades sociais e técnicas listadas acima o AN está pronto para atuar em diversos tipos de projetos para negócios de qualquer porte ou natureza. Ele é um AN “genérico”. Ou “horizontal”, para usar um termo que pareça menos pejorativo. Se ele atua em uma empresa que presta serviços de desenvolvimento ou consultoria, atendendo diversos tipos de clientes, é exatamente isso que será esperado dele: que ele tenha condições de atuar em qualquer tipo de organização. No entanto, será exigido que ele seja ainda mais ágil no aprendizado, aquela primeira habilidade social apresentada. É recomendável que ele faça um tipo de imersão na história de um cliente e na situação do ecossistema ao qual ele pertence antes do primeiro contato. Cliente nenhum gosta de ensinar o “be-a-bá” sobre seu ramo de atividades quando tudo o que ele precisa é um novo sistema. E o tempo sempre é curto demais. Por isso é factível supor que, com o tempo, o AN “horizontal” vai se especializar em alguns tipos de negócios. Dois ou três projetos dentro de uma mesma área, não necessariamente para um mesmo cliente, podem ser suficientes para gerar um conhecimento muito bom sobre aquela atividade. Conhecimento que a empresa prestadora de serviços, se atenta, apresentará como um diferencial competitivo. Situação diferente é daquele AN que atua apenas em uma empresa. A necessidade de especialização naquele ramo de atividade é óbvia. Desta forma temos um analista mais “vertical”, especialista em determinado ecossistema de negócios14. Mais do que uma habilidade que se aprende na escola, a especialização em determinado ramo de atividades é fruto da experiência, de considerável tempo de estrada. Ela pode ser desenvolvida de maneira intencional, planejada. Pelo AN ou pela empresa para a qual trabalha. Mas também pode ser consequência de uma série não consecutiva de projetos. Esta foi a minha experiência e de alguns AN's que trabalharam comigo. Em determinado momento percebemos, por exemplo, que poderíamos explorar melhor a área de seguros porque o conhecimento acumulado em projetos anteriores se configurava uma interessante vantagem competitiva. Outro tipo de especialização possível é por tipo de solução. Podemos ter AN's especialistas em projetos de ERP (Enterprise Resource Planning), CRM (Customer Relationship Management), SCM (Supply-Chain Management), PLM (Product Life-Cycle Management), MEG (Me Engana que eu Gosto) e diversas outras STL's (siglas de 3 letras). No mundo SAP, por exemplo, os AN's são conhecidos como Consultores Funcionais. O mais importante para o AN é entender que antes de qualquer tipo de especialização ele deve buscar o domínio do básico, daquela lista de habilidades sociais e técnicas apresentada acima. 14 Ecossistema significa tudo e todos que giram em torno e dentro de um negócio, seus clientes, fornecedores, parceiros comerciais, concorrentes, legislação e marcos regulatórios, produtos e serviços, além dos sistemas. 24 Capítulo 2 Analistas de Negócios – Por que agora? A questão acima é mais fácil de responder do que “por que só agora?”. Guardiães de um estranho status quo gostam de dizer que a crescente demanda por analistas de negócios é só uma moda. Talvez seja mesmo. Talvez, a exemplo de várias outras modas que caracterizam o mundo de TI e dos negócios, esse movimento todo não dure mais do que 3 ou 4 anos. Mas surgirá então outro termo – arquiteto de negócios, projetista de negócios, analista de organização & métodos (ops15) – e essa “nova” profissão deverá dominar praticamente tudo o que um AN aprende hoje. Em nossa área é assim mesmo: vão-se os nomes, ficam os conceitos e, principalmente, as necessidades. Vamos aos fatos: 1. Negócio e TI nunca tiveram um relacionamento muito amistoso. Não por acaso o tal “alinhamento estratégico” vive no topo da lista de prioridades de 9 entre 10 gestores de TI. 2. Cerca de 70% dos nossos projetos atrasam e / ou estouram orçamentos e / ou são cancelados. Dentre as causas mais comuns sempre aparecem: i) problemas com o entendimento dos requisitos; ii) a participação dos usuários; e iii) mudanças de escopo. 3. Desenvolvedores e coordenadores de projetos não estão sendo treinados para entender o negócio e os usuários. 4. O mundo dos negócios nunca foi tão volátil e dinâmico, o que aumenta consideravelmente os riscos de TI e particularmente de seus projetos. Alinhar, acompanhar o ritmo do negócio, muitas vezes parece ser o mesmo que pedir para que você, com um velocípede, tente acompanhar Massa em sua Ferrari. 5. O conhecimento sobre o negócio está espalhado entre diversas pessoas, lugares e sistemas. Dependendo da empresa, simplesmente ninguém tem uma visão do todo. A concorrência entre silos pelos caros recursos apenas complica ainda mais o panorama. Por tudo isso e mais um pouco, a figura do AN surgiu e vem ganhando relevância. É claro que o analista de negócios não é o único recurso à disposição das organizações de TI para a busca do alinhamento estratégico. Mas é, sem sombra de dúvidas, um dos mais importantes. É aquele que pode demonstrar no dia-a-dia o comprometimento com essa busca, através do relacionamento com as áreas de negócios e da entrega de bons projetos. Ou seja, ninguém deveria ter dificuldades para justificar a contratação ou alocação de AN's em uma equipe. Então, a pergunta que fica é: por que só agora? Sinceramente, não sei dizer. 15 Gosto de dizer que os analistas de O&M são, de certa maneira, os bisavós dos analistas de negócios. Falo um pouco mais sobre isso no quadro “Darwin e os Analistas”. O Analista de Negócios 25 Darwin e os Analistas Darwin ficou famoso por descobrir e dizer que as espécies, todas as espécies vivas da face da terra, evoluem. Ele contou que não são os mais fortes, os mais inteligentes ou aqueles que gritam mais alto que sobrevivem – são aqueles que melhor se adaptam às mudanças. Todo mundo já gastou essa teoria fazendo analogias com o universo dos negócios e de TI. Tirarei minha casquinha. Era uma vez... uma empresa, lá nos anos 50, animadíssima com as possibilidades oferecidas por um novíssimo fruto da genialidade humana, o tal cérebro eletrônico. Contabilidade, folha de pagamentos, cálculos e mais cálculos. As possibilidades eram lindas e maravilhosas. Mas, “êita engenhoca difícil de operar!”. Uma rebelião de empresas usuárias quase decretou a morte da informática ainda em seus primeiros anos de vida. Quase, porque um sábio vendedor da IBM debelou o conflito e salvou nossa área16. Coincidência ou não, nasciam ali também os primeiros analistas. As áreas de negócios, guiadas por manuais tayloristas17, também criaram seus analistas: os Analistas de Organização & Métodos. Assim mesmo, com um “e” comercial. Mas os analistas de TI e de O&M só se encontravam por acidente. Ou naquelas raras vezes em que o cara de O&M tentava organizar aquela bagunça então conhecida por CPD (Centro de Processamento de Dados). Aliás, TI não se chamava TI ainda. Era só um CPD. Uma caixa preta com um monte de gente esquisita falando línguas esquisitas. COBOL? Fortran? O tempo passou, Jobs e Gates inventaram a microinformática e alguns anônimos (intencionais ou não) inventaram os Analistas de Sistemas. Gente que tinha que estudar o problema de negócio e solucioná-lo através de sistemas de informação. Novo conflito. Por um breve período os analistas de O&M foram renomeados. Viraram Analistas de Organização, Métodos & Sistemas. Não adiantou. Eles seguiram chatos, imutáveis e com um “e” comercial no nome. Não se adaptaram. Não estudaram sistemas. Não entenderam o Visicalc. Foram extintos. Vitoriosos, os Analistas de Sistemas começaram sua saga. Dramática saga. Breve saga. Negócios começaram a entender que os computadores podiam sim fazer a diferença. O impacto da Internet então, nem me diga. E tudo é para ontem, anteontem... Buscando adaptação, os analistas ganharam um sobrenome: programadores. Daí para o mal interpretado mundo Agile, onde muita gente prega zero-documentação, zero-modelo, foi um pulinho. Alinhamento? Coloca o usuário sentado ao lado do programador que a coisa sai! Programador? Sim, o Analista de Sistemas se foi. Aconteceu tão rápido que nem enterro teve. Eis que surge, sem convite, o tal analista de negócios. Incorrigível, o mundo de TI já trata de fazer suas adaptações: já tem gente contratando AN com experiência em Java! 16 Está aqui um trecho que não é só ficção e palpite não. Esta história deliciosa está muito bem documentada em “From Airline Reservations to Sonic the Hedgehog – A History of the Software Industry”, livro de Martin Campbell-Kelly. MIT Press (2003). 17 De Taylor, ou Frederick Winslow Taylor ( http://en.wikipedia.org/wiki/Frederick_Winslow_Taylor ). 26 Capítulo 2 É do Negócio ou de TI? 27 Capítulo 3 É do Negócio ou de TI? Que dilema! Se o analista de negócios atua como um tipo de ponte entre as áreas de negócio e de tecnologia, a quem ele deve ser subordinado? Este capítulo não estava previsto no plano original do livro. Mas se tornou necessário depois de minhas andanças e conversas. Não há uma resposta clara para a questão e, provavelmente, nunca haverá um padrão. Originalmente o AN brotou nas dependências de TI. Na maioria das vezes é um profissional formado em algum curso de tecnologia. Tanto que há quem defenda, por exemplo, que ele seja um gerente de relacionamentos da organização de TI com as áreas de negócios. Por outro lado, existem empresas que veem o AN como um SME (Subject Matter Expert), um especialista em determinado tema do negócio. E que, como tal, deve responder diretamente para a respectiva área de negócio. Há também a terceira via, que cria um departamento exclusivo para a análise de negócios. Um departamento totalmente independente de TI e das áreas usuárias. Em algumas empresas os AN's estão sendo alocados no departamento de marketing! Neste capítulo serão apresentadas as três alternativas, os prós e contras de cada uma delas. Parece haver um desenho mais adequado para cada tipo de negócio. Mas, ao invés de apresentar conclusões, me limito a oferecer subsídios para que você decida qual o modelo mais adequado para sua situação. Claro que essa discussão não faz muito sentido se sua empresa presta serviços de consultoria e / ou desenvolvimento. Mesmo assim, evite a tentação de pular diretamente para o próximo capítulo. Explico: saber como seus clientes podem estruturar essa função pode ser muito importante. Você vai se relacionar com os AN's de seus clientes. Além disso, atenção para o parágrafo abaixo. Outro tópico abordado aqui é a formação de equipes de projetos. Independente de qual seja seu departamento, o AN deve ser alocado em projetos. Qual a melhor estrutura para acomodálo? Como minimizar as possibilidades de conflito entre ele e a equipe técnica? Afinal, como se dá o relacionamento entre desenvolvedores, arquitetos, coordenadores e o analista de negócios? No decorrer desse papo apresentarei algumas estruturas alternativas, que visam principalmente ao aprendizado, a troca de experiências entre os analistas. Comunidades de prática, centros de excelência e escritórios de análise de negócios serão apresentados e avaliados. Pois é: como este capítulo poderia não existir? Tsc, tsc... 28 Capítulo 3 O Analista de Negócios é de TI A princípio este parece ser o desenho mais natural. O AN, assim como analistas de sistemas, desenvolvedores, administradores de redes e o pessoal de suporte, é subordinado ao departamento de tecnologia da informação. É provável que ele não seja especializado em nenhuma área de negócio específica, como vendas, produção ou finanças. Pelo contrário, a organização de TI deve apresentar uma pequena equipe de AN's1 capaz de navegar por todas as áreas da empresa. Será exigido, isso sim, que ele conheça muito bem o negócio da empresa. Este desenho apresenta as seguintes vantagens: • Menor probabilidade de conflitos com desenvolvedores e demais integrantes da equipe técnica. Isso porque há uma convivência frequente e todos trabalham de acordo com uma mesma filosofia – compartilham valores, padrões, métodos e práticas. • Por ser um desenho centralizador, TI tem mais poder de decisão sobre prioridades de alocação dos AN's. • É mais fácil garantir que a metodologia ou processo de desenvolvimento está sendo obedecido. E desvantagens: • A centralização também pode ser uma desvantagem. Dependendo da proporção entre o número de solicitações e a quantidade de AN's disponíveis, podemos ter aqui um belíssimo gargalo. Além disso, oportunidades de negócio podem ser negligenciadas, as prioridades podem estar equivocadas. • Isso também pode gerar um volume maior de atritos com as áreas de negócio. Conflitos que, não raro, devem ser intermediados por alguém que está acima na hierarquia da empresa. • Como o AN de uma estrutura centralizada é naturalmente “genérico”, há uma certa lentidão quando ele tem que aprender uma atividade ou situação de negócio inédita. Este problema é consideravelmente reduzido quando a rotatividade de profissionais é baixa. Uma grande empresa nacional de telecomunicações utiliza este desenho. E chama a equipe de AN's de “Ponto Focal”. Dado o porte da empresa, os analistas são divididos por áreas de negócio ou tipos de processos: Produtos, Atendimento e Processos de Apoio são alguns exemplos. O quadro “No Meio do Tiroteio” detalha um pouco mais esse caso. Quando o analista de negócios está subordinado à área de TI o processo de trabalho ocorre mais ou menos assim: um departamento ou seção manifesta a necessidade de uma nova aplicação. Esta solicitação entra na lista de pendências (backlog) da área de TI. O quanto antes um AN deve ser destacado para entender um pouco mais o problema em questão. Só assim a solicitação pode ser priorizada – posicionada no backlog. A priorização é negociada com a área 1 No final deste capítulo falo sobre “O Tamanho da Equipe”. É do Negócio ou de TI? 29 solicitante. Todo mundo quer tudo para ontem, e TI deve ter uma boa justificativa caso aquele pedido não mereça estar no topo de sua lista de afazeres. A sequência acima é ridiculamente simplista e esconde uma série de variáveis. Exploremos um pouco mais o tema. Quando chega uma nova solicitação, nem sempre é possível dizer se se trata de uma nova aplicação ou de uma alteração em um sistema existente. O porte da alteração também pode ser uma incógnita. Como o usuário nem sempre tem essa informação, é de se esperar que solicitações assim apareçam em outro canal: no help-desk, por exemplo. Quem gosta de dizer que “atendimento nível 1 é coisa de analista de suporte júnior” deveria parar e pensar um pouquinho. Aqui nascem alguns sérios conflitos entre áreas de negócio e TI. Como o “analista de suporte júnior” pode ter condições de dizer se aquela solicitação é pequena ou grande, se gerará demanda por manutenção em um sistema legado ou um novo projeto? Confrontadas com a situação descrita acima, algumas empresas tomaram uma decisão bastante perdulária: alocam AN's para cuidar até de pequenas demandas. Justificam o desenho apresentando uma solução para outro problema: a padronização das solicitações. A coisa é tão maluca em algumas empresas, que o mesmo padrão utilizado para novos sistemas deve ser obedecido em pequenas solicitações de manutenção. Imagine o processo: um AN tentando escrever casos de uso, protótipos e uma detalhada especificação, repleta de justificativas, só porque o usuário pediu o acréscimo de um novo campo numa tela qualquer. Pode parecer absurdo, mas acontece. A demanda por manutenção e correções de sistemas legados é imensa em um grande número de empresas, dos mais diversos portes. É, no popular, um indigesto abacaxi que as organizações de TI engolem diariamente. Longe de mim apresentar alguma sugestão para adoçar um pouquinho o abacaxi2. Me preocupa aqui que o AN, uma posição cara e rara, seja desperdiçado. Usuários e analistas de suporte deveriam ser orientados para qualificar minimamente as demandas. O AN deveria ser acionado apenas quando a demanda realmente exigir um melhor entendimento do negócio e dos usuários. Enfim, quando a demanda realmente tiver uma maior importância para o negócio. 2 Hmm.. não me segurei. Então vão não uma, mas duas sugestões: i) SOA (Arquitetura Orientada a Serviços); e / ou, ii) uma velha dica do Gartner: aposente 2 ou 3 sistemas legados por ano, começando por aqueles que não passam em qualquer avaliação básica de custos x benefícios. 30 Capítulo 3 No Meio do Tiroteio A empresa, fruto de algumas fusões, tem um péssimo histórico de relacionamento entre áreas de negócio e o departamento de TI. Em determinado momento a coisa ficou tão feia que usuários passaram a estudar sistemas. Não as funcionalidades oferecidas, mas o interior das aplicações. Tanto que alguns aprenderam a linguagem SQL! Não sei dizer se alguns se arriscaram a colocar a mão na massa, mas o fato é que algumas de suas solicitações já apresentavam a solução pronta – o código que deveria ser implementado. Em outras situações eles descreviam campos e tabelas que deveriam ser alterados. A empresa mudou, e duas áreas foram criadas para receber e filtrar todas as solicitações recebidas. A primeira cuida do entendimento do problema e da especificação deste de forma padronizada. A segunda, um centro de soluções, cuida do relacionamento com os fornecedores. Sim, praticamente todas as atividades de manutenção e desenvolvimento de sistemas foram terceirizadas. O problema é que os traumas dos usuários permanecem. E os maus costumes idem. O departamento que foi criado para o entendimento do problema é visto como um empecilho. As atividades desta área são consideradas supérfluas por muitos usuários. Sendo assim, alguns deles simplesmente passam por cima dos AN's, negociando suas solicitações diretamente com o centro de soluções. A primeira área só é avisada quando sua assinatura é necessária. Ou seja, pura burocracia. Sob o ponto de vista de alguns usuários, tudo é pequeno, tudo é “facinho facinho”. A coisa piora muito quando o usuário se esquece que a empresa não se limita ao seu departamento, que podem existir outras prioridades. Então ele “fura a fila”, sem noção das consequências. É curiosa a grande criatividade dos usuários. A empresa estipulou que existem dois tipos de solicitações: as pequenas e as grandes. Estas devem ser tratadas como projetos. Os usuários sabem que projetos seguem um ritual diferente, mais demorado. Então eles fatiam suas solicitações e as apresentam “pequenas demandas” em intervalos regulares de tempo. Demora até o departamento de TI perceber que está sendo ludibriado. Talvez o problema não fosse crítico se a qualidade dos serviços prestados pelas fábricas não fosse tão ruim. Mas o fato é que muitas aplicações e até pequenas alterações são entregues com muitos erros. Não é necessária muita esperteza para perceber que muitos desses bugs são frutos exclusivos dos atalhos que foram tomados. Mas, como eu disse, o serviço das fábricas de software é ruim. Então mesmo aquelas solicitações que seguem sem desvios o manual, sofrem com erros e funcionalidades diferentes daquelas esperadas pelos usuários. O estranho é que as empresas, esta em particular, acreditam que a culpa é delas – que o problema está na qualidade da especificação que é entregue para as fábricas. E passam a exigir especificações ainda mais detalhadas, e colocam mais e mais pontos de checagem. Consequência: o processo se torna ainda mais lento, os usuários mais insatisfeitos, os AN's mais criticados... nessa bagunça toda, nesse ciclo vicioso, só um lado sai ganhando: as fábricas de software. É do Negócio ou de TI? 31 O AN é do Negócio E cada área usuária possui o seu. É indiscutível que este desenho confere um pouco mais de agilidade ao processo. O AN é exclusivo de um departamento. Ou seja, ele deve saber tudo sobre ele, a localização exata de cada clipe de papel. Mas essa alternativa é, de certa forma, um luxo. Afinal, departamento algum tem demanda suficiente para ocupar um AN o tempo todo. Sendo assim, é de se esperar que este profissional tenha alguma outra atribuição. O que percebi em algumas empresas é que usuários com mais tempo de casa desempenham a função de AN's em projetos. São temporariamente alocados para representar o departamento em um empreendimento. Seus afazeres cotidianos são assumidos por outro colaborador até o término do projeto. Vantagens deste modelo: • O domínio do negócio, do problema, é total. Ou, colocando de outra forma, o aprendizado se dá de maneira muito mais rápida. • Como o AN é também um usuário direto ou indireto da solução em questão, seu ponto de vista tende a ser muito mais respeitado pela equipe técnica. • A possibilidade de enganos e mal entendidos é minimizada. De certa forma, há um nó a menos na rede de comunicações do projeto. A contrapartida, ou os riscos inerentes a este modelo: • Este AN não tem uma formação técnica. Se não dominar as disciplinas que formam a análise de negócios, será apenas um usuário. (Entendam, não estou menosprezando os usuários. Apenas estou dizendo que não podemos confundir usuários com AN's). • O AN pode não respeitar integralmente os padrões e o processo de desenvolvimento estipulados pelo departamento de TI. O problema é minimizado ou eliminado se ficar clara a subordinação do AN ao gerente do projeto. • Se um projeto atende, por exemplo, três departamentos, teremos então três AN's. Cada um defendendo seu lado. Incorpora-se assim, à equipe de projeto, os conflitos que normalmente existem entre departamentos. • Pode faltar uma visão do todo. Talvez este seja o risco mais sério. Se cada AN olha exclusivamente o seu departamento, quem se preocupa com o negócio ou processo como um todo? Lá no início do capítulo eu prometi uma certa isenção, mas preciso dizer que este desenho parece mais moderno, mais ágil. Ele parece fazer muito sentido em médias e grandes empresas, particularmente naquelas que renovam sua carteira de produtos e serviços com bastante frequência, como bancos, seguradoras e empresas de telecomunicações. Esta renovação sempre significa novos projetos ou grandes alterações em aplicações existentes. Áreas de apoio, como contabilidade, RH e o departamento financeiro, não precisam de AN's 32 Capítulo 3 exclusivos. Podem compartilhar um pequeno pool. Mas as áreas “nervosas” dessas empresas, como marketing, produtos e vendas, podem se beneficiar muito com esta interface chamada AN. Como já foi colocado, o único grande risco deste modelo pode ser a falta de uma visão mais ampla do negócio e seus processos. Um risco que pode ser mitigado com a instituição de uma comunidade de prática, sugestão que será apresentada posteriormente neste capítulo. Podemos transformar um usuário-chave em um analista de negócios? Sim, por que não? Mesmo que no início existam algumas deficiências no conhecimento de arquitetura de aplicações, isso é compensado pelo grande domínio de negócio apresentado. Mas, vale repetir que é fundamental que o usuário-chave seja de fato treinado para dominar as habilidades técnicas que caracterizam um AN. É isso que vai garantir uma boa comunicação com a equipe técnica. Em um grande banco nacional, cujo modelo será apresentado no tópico seguinte, tem advogados, administradores e gente formada em letras em sua equipe de AN's. O treinamento dos usuários-chave deve ser patrocinado e ministrado pela área de TI. Assim, além das habilidades técnicas, o novo AN também é apresentado ao processo de desenvolvimento utilizado pela empresa, aos seus padrões, ferramentas e tecnologias. Em outro cenário, ainda neste modelo, as áreas de negócio contratam AN's já formados. Neste caso será preciso um período de imersão. Mesmo que conheça o ramo de atividade em questão, o AN precisará estudar a empresa e o departamento que o está contratando. Falo mais sobre a seleção e contratação de AN's abaixo, ainda neste capítulo. É do Negócio ou de TI? 33 O AN não é de Ninguém Ou seja, existe um departamento autônomo de análise de negócios que não é subordinado nem a TI nem a nenhuma área de negócio específica. Tamanha independência realmente deve significar uma privilegiada posição em todas as negociações e situações de conflito. Ou, por outro lado, mais um chefe a ser chamado para acalmar ânimos e encontrar uma solução que agrade a todos. Trata-se de um desenho curioso que vi em um dos maiores bancos nacionais. Esta área fora subordinada à TI. Problemas que não conheço levaram a declaração de independência desta área que agora é conhecida como Departamento de Tecnologia do Negócio. Estrutura estranha, nome mais ainda. Vantagens superficialmente percebidas ou chutadas: • A independência dos AN's possibilita a atuação destes como juízes realmente isentos. Nos conflitos entre áreas usuárias e TI, tão comuns, os AN's podem ter a última palavra. Ou guiar o consenso. • Ao contrário do modelo anterior, aqui a visão do todo é mais fácil de ser obtida. Como precisa atender todas as áreas de negócio, é mandatório que o conjunto de AN's conheça todo o negócio, sua estrutura, processos, motivações e regras. Além, é claro, da arquitetura de informações e de aplicações. O preço pago, igualmente suposto: • Trata-se de um canal a mais de comunicação, um departamento a mais, uma estrutura gerencial a mais. Além do custo, maior que dos dois modelos anteriores, há o risco de conflitos ainda mais difíceis de serem sanados por envolverem agora um mínimo de três e não duas partes interessadas. • A consolidação dos protocolos de comunicação entre as áreas, particularmente entre o departamento de AN's e a área de TI, é mais lenta. Os processos de desenvolvimento e gerenciamento foram divididos. As partes do processo que envolverem as duas áreas não podem ser alteradas sem o consentimento de ambas. Devo confessar uma certa antipatia por este modelo. Em tempos de questionamento e enxugamento das estruturas e dos processos de gestão3, é difícil justificar a criação de um novo departamento em uma empresa. Parece, eu disse parece, que “tiraram o bode da sala”. Havia um sério problema de relacionamento entre usuários e técnicos? Ao invés de tratar o problema plantaram um departamento entre eles. De qualquer maneira, se o problema foi remediado, quem sou eu para questionar. Só acho a solução cara demais. 3 Aqui confesso extrema simpatia e forte influência de “O Futuro da Administração”, livro de Gary Hamel e Bill Green. Elsevier-Campus (2008). 34 Capítulo 3 Mas vamos trabalhar em outro cenário. Imaginem uma empresa que trabalha apenas com um tipo de produto ou serviço. Um produto ou serviço baseado em software. Neste caso faz sentido que a equipe de AN's fique concentrada em um único departamento, que não é TI. Há pelo menos um caso no Brasil em que os AN's pertencem ao departamento de marketing. Aqui sim o desenho faz sentido porque todo o trabalho dos analistas gira em torno dos produtos e serviços oferecidos. A subordinação ao dono do produto, marketing, garante agilidade e alinhamento. Mas reparem que não se trata de um departamento de AN's, e sim de uma variação do segundo modelo: uma área de negócio é “dona” dos AN's. Escritórios de Análise de Negócios E por falar em antipatia e azedume... Queria muito 5 minutos cara-a-cara com o infeliz que inventou os escritórios de projetos4. Este novo silo retrata duas coisas: o corporativismo e o medo. Criaram um muro em torno dos gerentes de projetos, exatamente quem deveria derrubar muros e mostrar para as empresas como é o trabalho em equipes multidisciplinares. Um contrasenso total. Mas nossa área adora propagar péssimas idéias. Eis então que pipocam sugestões de escritórios de processos e escritórios de análise de negócios. Céus! Puxo o tema aqui exatamente porque esses escritórios se assemelham ao modelo em que há um departamento exclusivo para AN's. A diferença é que os escritórios de AN's, pelo visto, serão subordinados a TI. Mas, a exemplo dos PMO's (Project Management Offices), terão sua estrutura gerencial e sua própria burocracia. Há justificativa? Em todos os casos as desculpas são as mesmas: i) promover o gerenciamento de projetos (ou a análise de negócios); ii) treinar novatos; e, iii) garantir o respeito aos padrões. Primeiro: profissão nenhuma carece de promoção no interior de uma empresa. Se ela é instituída é porque reconhecem seu valor e utilidade. Segundo: existem alternativas mais baratas para treinamento e difusão de boas práticas. Terceiro: um escritório por si só não garante nada. Vai punir? Acabei de me lembrar que naquele caso que contei lá em cima, “No Meio do Tiroteio”, a empresa retratada também tem um PMO. Olha só: AN's, um centro de soluções, fábricas terceirizadas e, como cereja do bolo, um escritório de projetos. É ou não é uma beleza? Quatro áreas só para brigar com os usuários! Quanta covardia... Peço desculpas pelo desabafo. Mas ele foi necessário para que a alternativa apresentada abaixo seja melhor avaliada. 4 E 10 minutos com o “gênio” que inventou as fábricas de software. É do Negócio ou de TI? 35 Comunidades de Prática5 Em organizações dos mais diversos portes e naturezas existem grupos informais que compartilham informações e conhecimentos. Esses grupos ou redes de contatos normalmente giram em torno de um interesse comum. É natural que tais redes extrapolem as fronteiras da organização, na forma de grupos de estudos e comunidades virtuais. Esses grupos nascem de forma espontânea e seu crescimento é orgânico. Não há colaboração que não seja voluntária. As organizações podem tirar proveito dessas redes informais de contato para aumentar e melhorar a qualidade de seu capital intelectual. Esses grupos podem ser convertidos em Comunidades de Prática que são reconhecidas e apoiadas pela organização. É importante saber respeitar o aspecto espontâneo e voluntário dessas comunidades, cujas características são bastante distintas daquelas que caracterizam uma equipe de projeto, um departamento e arranjos como os PMO's e escritórios de análise de negócios. Equipes, departamentos e escritórios são estruturas formais. Seguem uma hierarquia e obedecem procedimentos e padrões. Enquanto as equipes são temporárias, os dois últimos são permanentes. Colocando de outra forma, eles são centros de custos. Comunidades de prática, por outro lado, são estruturas informais. Elas se autodefinem e autogerenciam, alheias à hierarquia e aos processos vigentes. Preste um pouco de atenção: sua empresa pode ter algumas dezenas de comunidades de prática. Grupos que gostam de se reunir com certa frequência, durante o almoço, nos cafezinhos ou até mesmo em happy hours. Muitos gostam de “falar sobre o serviço”, já reparou? Pois bem, eles são embriões de ou comunidades de prática já constituídas. No popular, de forma pejorativa, gostamos de tratar esses grupos como “panelinhas”. Mas as trocas de conhecimento e experiências que eles estão efetuando já devem gerar algum valor para a empresa. A proposta aqui é que a empresa reconheça e apoie esses grupos informais, as Comunidades de Prática. Antes de definirmos como uma empresa pode apoiar uma comunidade, vamos detalhar um pouco mais as suas características fundamentais. Uma comunidade de prática é: • Motivada pelo Bate-papo: ela visa desenvolver as competências dos participantes através da geração e troca de conhecimentos. Ocasionalmente o grupo pode tentar descobrir uma solução para um problema específico, mas isso é uma exceção. Não há uma pauta pré-definida para seus encontros. • Guiada pelo Valor: seus membros compartilham interesses ou práticas. O valor está no processo de aprendizado. • Definidas pelo Conhecimento: que é interdependente. Suas fronteiras são permeáveis, ao contrário de equipes de projetos, departamentos e escritórios que apresentam rígidas estruturas. • Duração Indeterminada: uma comunidade dura enquanto houver interesse. 5 Contém trechos do artigo “Aprendizado Interprojetos”, de minha autoria, publicado nos anais da 6a. edição do seminário “Gestão de Projetos de TI” promovido pela SUCESU-SP (2004). A versão integral do artigo, em 36 Capítulo 3 • Formação Aleatória: a participação é voluntária. E os participantes se autoselecionam. Daí o apelido “panelinha”. São esses aspectos simples e naturais que fazem das comunidades de prática uma alternativa muito moderna. A ausência de mecanismos de controle formais pode assustar um pouco. Mas é exatamente essa liberdade que gera o potencial de aprendizado. E de inovação, uma palavra que está na boca de todo mundo mas distante demais das estruturas e processos das empresas. Uma empresa não precisa fazer muito para apoiar a formação e manutenção das comunidades de prática. Quatro passos bem básicos são necessários: • Identificar os grupos informais criados em torno de temas (conhecimentos) que sejam relevantes para a organização; • Indicar um ou mais membros do grupo para intermediar o relacionamento do grupo com a organização; • Oferecer uma infraestrutura básica para o grupo, como espaços reservados para seus encontros; • Reservar um período de tempo, da jornada normal de trabalho, para que tais encontros ocorram. A interferência da organização no funcionamento da comunidade de prática deve ser a menor possível. O sentimento de confiança mútua e de abertura para exposição de pontos de vista são essenciais para a longevidade da comunidade. Porém, é claro, as organizações precisam perceber que seu investimento, por menor que seja, está dando algum tipo de retorno. Indicadores tradicionais de ganho de produtividade não servem neste caso. Os principais ganhos serão percebidos na performance dos colaboradores e, consequentemente, na qualidade dos projetos. Uma empresa pode ter comunidades com os mais diversos temas. Nossa preocupação aqui é com os analistas de negócios. Por se tratar de uma função ainda em fase de definição, uma comunidade de prática específica para AN's faz muito sentido. Por fim, é importante destacar também as extensões das comunidades de prática. Normalmente elas extrapolam as fronteiras de uma organização. Grupos de discussão, fóruns e outras ferramentas oferecidas na Internet permitem a colaboração e a troca de experiências com profissionais do mundo todo. Uma empresa tem muito a ganhar quando seus colaboradores são incentivados a participar desse tipo de associação. Mas, por incrível que pareça, muitas ainda censuram o uso da Internet por trabalhadores do conhecimento. Se há o temor de que informações sensíveis ou sigilosas sejam acidentalmente liberadas, a empresa deveria apenas publicar um guia de uso desse tipo de ferramenta. Impedir seu uso, além de antipático e desmotivador, também fecha as portas da empresa para conhecimentos que existem além de seus muros. Na era da Economia da Informação, essa não parece ser uma coisa muito inteligente. É do Negócio ou de TI? 37 Contratando Analistas de Negócios Se esta é uma função / profissão relativamente nova e mal definida, como uma empresa pode contratá-la? O que ela deve buscar nos currículos? Quais tipos de testes podem ser aplicados? Enfim, como devem ser os processos de seleção e contratação de AN's? É importantíssimo começar bem. Nossa área, particularmente aqui no Brasil, é conhecida por publicar anúncios de vagas exagerados, mal definidos e pouco eficazes. São exagerados porque frequentemente buscam super-heróis. Por exemplo: Coordenador de projeto com 10 anos de experiência e certificação PMP. Formação superior em engenharia, administração, sistemas de informação ou equivalentes. Experiência comprovada no gerenciamento de projetos de sistemas de informação para varejo, atacado ou indústria. Será considerado um diferencial conhecimentos do SAP/R3 e da arquitetura Java (JEE). Noções de alguma metodologia de desenvolvimento, particularmente O RUP, é desejável. Esse tipo de coisa ficou tão comum que nem percebemos o absurdo, né? Como é possível que alguém realmente domine temas tão díspares como o gerenciamento de projetos – cujo corpo de conhecimentos é formado por 9 disciplinas, SAP R/3 – um sistema monstruoso (em todos os sentidos), Java/JEE – uma plataforma tecnológica complexa e o RUP (Rational Unified Process), igualmente gigantesco? Mas o fato de gente se candidatar para vagas desse tipo assusta mais que o anúncio. Será que os candidatos usam capas, máscaras e vão para as entrevistas voando? Resta a torcida para que o mesmo não ocorra com os AN's. Apesar de uma certa indefinição, aquela lista básica de habilidades sociais e técnicas que ele deve apresentar parece bastante razoável, não? Se você concorda, então talvez goste da sugestão de anúncio abaixo: Analista de negócios com X anos de experiência. Formação superior em sistemas de informação, administração ou equivalente é desejável. Deve comprovar experiência no ramo de [nomedoramode atividades]. A certificação CBPA (Certified Business Analysis Professional) será considerada um diferencial. Deve dominar a modelagem de negócios, preferencialmente utilizando o padrão de notação [UML|EPBE|BPMN|EPC|IDEF*]. Deve saber guiar eventos para desenvolvimento de requisitos e ter boa comunicação. É imprescindível o conhecimento de técnicas para registro, estruturação e testes de requisitos. Não estou pedindo que você copie e cole o exemplo acima. Minha preocupação é que você não exija do AN mais do que ele pode dar. Um anúncio bem específico e detalhado tem maiores chances de atrair melhores candidatos. As retrições devem espantar a maioria dos aventureiros. Normalmente, quando citamos as habilidades técnicas de forma detalhada, o candidato desconfia que algum tipo de teste será aplicado. Será! 38 Capítulo 3 Se você pediu conhecimento de UML, por exemplo, como avaliá-lo se não com uma provinha? O mesmo vale para todas as habilidades técnicas. Eu aplicaria, no mínimo, um teste com as seguintes situações: • Peça que o candidato desenvolva um modelo de alto nível que destaque os principais elementos que caracterizam aquele ramo de atividades específico. Se há uma linguagem de modelagem em questão, peça que o modelo seja desenvolvido neste padrão. • Apresente um modelo de um processo de negócio relevante (para seu negócio) e comum, mas incompleto. Peça que o candidato complete o desenho e justifique cada elemento acrescentado. • Apresente um problema de negócio e se ofereça para ser entrevistado pelo candidato. Ele deve elaborar uma especificação de caso de uso completa, inclusive com os casos de testes. • Por fim, peça que o candidato escreva na hora, na forma de um documento de visão, as razões porque a empresa deve contratá-lo. Que o candidato se venda como venderia um projeto. Em um documento de uma página apenas. Cada questão acima vale 25 pontos. Todo candidato que não obtiver 75 pontos deveria ser eliminado. Ok, soou duro e deveras restritivo. Mas deve ser assim mesmo. Claro, nunca se esquecendo que estamos tratando de pessoas. O cara só tirou 50 mas mostrou qualidades e habilidades que podem ser muito úteis para a empresa? Caramba, tente aproveitá-lo. Tente, antes, entender porque ele foi mal em algumas questões. É horrível quando sinto que gasto o seu e o meu tempo com questões que dependem exclusivamente de bom senso. Perdão. Mas o processo não se encerra aqui. Por enquanto você apenas garantiu que o candidato possui as habilidades técnicas mínimas. O que fazer para avaliar as habilidades sociais? Aqui, mais do que provinhas, são as conversas que comprovarão a adequação do candidato. E essas conversas não podem ocorrer apenas entre o selecionador e o candidato. É responsabilidade demais para o selecionador. Se você é da área de TI, convide profissionais de áreas de negócio para conhecer o candidato e bater papo com ele. Se você é de uma área de negócio, chame alguém de TI para o bate-papo. Este profissional será uma ligação entre diversas áreas. É fundamental que a avaliação do candidato seja compartilhada pelo maior número de departamentos envolvidos. A área contratante tem a palavra final, claro. Mas ela deve conhecer opiniões e eventuais vetos de outras áreas. Questão de prevenção, de gerenciamento de riscos. Ah, faltou dizer que o RH pode participar do processo. Se ele não for um departamento exclusivamente burocrático e divulgador de regras, então ele deve participar do processo. É do Negócio ou de TI? 39 Sendo Contratado Este livro foi escrito para você, meu caro (candidato a) Analista de Negócios. Mas eu não poderia ignorar demandas como a que tratei no tópico anterior. Apenas espero que aquelas sugestões ali também sejam úteis para ti. Já pensou se uma empresa maluca resolve adotar minhas sugestões para anúncio de vagas e testes? Já pensou se você dá uma sorte danada e se candidata a uma vaga nesta empresa? Só isso já paga o investimento no livro, certo? Mas, falando sério, tratemos agora do lado dos candidatos. O que eles podem fazer para serem selecionados para entrevistas e contratados? Do lado de lá o processo começa na identificação da necessidade e na correta redação de um anúncio. Do lado de cá começa na elaboração do currículo. Não, não vou te dar um template de currículo. AN de verdade sabe que templates são um perigo! Profissionais do século XXI acham que templates são coisas de gente preguiçosa e pouco criativa. Te darei apenas algumas dicas: • Comece escrevendo com todas as letras qual vaga você almeja: AN. • Valorize sua experiência começando o currículo por ela. Indique as últimas empresas e suas principais realizações, de forma sucinta. Lembre-se, a capacidade de síntese é uma habilidade social esperada pelo contratante. • Na sequência mostre sua formação, inclusive extensões e cursos. Como esta área não tem um curso de graduação específico, esses complementos são de suma importância. Mas limite-se àqueles que realmente comprovem seu interesse pela análise de negócios. Simples assim, objetivo desse tanto. Uma versão mais detalhada, com referências e indicações, pode ser mantida em um site de relacionamentos profissionais como o LinkedIn6. Se for o caso, então informe o endereço de seu perfil público no currículo impresso. E prepare-se para a entrevista. Lembre-se que toda empresa minimamente séria vai aplicar testes. Então estude e revise seus conhecimentos com uma certa antecedência. Faça uma breve pesquisa sobre a empresa e seu ramo de atividades. É legal conhecer tanto o histórico quanto as perspectivas de todo aquele mercado. Saber quais são os clientes, fornecedores e concorrentes devem fazer parte do estudo. Se a Internet (melhor dizendo, o Google) não ajudar muito, o que é difícil hoje em dia, busque publicações da área. Ou seja, demonstre interesse. Afinal, você está se oferecendo para trabalhar naquela empresa. Você não quer saber onde está amarrando seu burrinho? 6 http://www.linkedin.com 40 Capítulo 3 Formando Equipes Este tema merece um livro só para ele. Quem sabe um dia crio coragem. Por enquanto ele será só isso, um sub-capítulo. Com uma justificativa: preciso mostrar como podemos posicionar os AN's em uma equipe de projeto para desenvolvimento de sistemas. Não consigo falar sobre isso sem falar um pouco sobre a equipe toda. Apresento abaixo o que costumo chamar de modelo para um Dream Team, ou time dos sonhos. Defendo a especialização, mas não numa filosofia taylorista ou fordista, por favor. É Drucker7 quem me inspira8: “Conhecimento, por definição, é especializado. Com efeito, as pessoas realmente detentoras de conhecimentos tendem ao excesso de especialização, qualquer que seja seu campo de atuação, exatamente porque sempre se deparam com muito mais a aprender.” Nos tempos do COBOL e similares, era fácil imaginar uma equipe formada em torno de um superprogramador, como sugerido por Fred Brooks9. Depois que inventamos o mundo Cliente / Servidor e decidimos usar a Internet como plataforma para nossas aplicações, tudo mudou. Tecnologias se tornaram mais complexas – cresceram para os lados e para cima. Antes um mesmo módulo escrito em COBOL definia dados, interfaces e lógica de negócio. Era natural que um programador escrevesse tudo. Depois ganhamos bancos de dados, servidores de aplicações, servidores Web e mais um imenso conjunto de elementos. Mesmo que alguns gênios insistam que podem dominar tudo, uma organização séria deve se preocupar com a formação de equipes que valorize especializações. Da mesma forma que técnicos de futebol não montam times com 11 generalistas em campo. Em cada posição há muito a ser estudado. Com um agravante quando falamos de desenvolvimento de sistemas: novidades aparecem quase todo dia, o que torna o domínio relativamente efêmero. Como dizia Drucker, todos sempre irão se deparar com muito mais a aprender. Por isso é bom desconfiar de todo mundo que domina muita coisa em nossa área. Ou confiar desconfiando. Goleiros artilheiros são exceção, não a regra. Mas é importante saber quais especializações valorizar. Um time de futebol sempre terá 11 posições a ser ocupadas. Não podemos ter um número variável de especializações. Uma estrutura básica, um modelo para a formação de equipes é necessário. Abaixo apresento um desenho e uma breve explicação sobre cada especialista sugerido. De novo: esse breve desvio é necessário para que você entenda a relevância e o posicionamento do analista de negócios em uma equipe de projeto. 7 http://en.wikipedia.org/wiki/Peter_Drucker 8 “O Advento da Nova Organização”, artigo de Peter F. Drucker publicado em “Gestão do Conhecimento – Harvard Business Review”, Editora Campus (2001). 9 “The Mythical Man-Month – Anniversary Edition”, Frederick P. Brooks Jr, Addison-Wesley (1995). O texto a que me refiro, “The Surgical Team”, consta da edição original do livro, de 1975. É do Negócio ou de TI? 41 Figura 2: Modelo para a Formação de Equipes. Em Infraestrutura residem todos os profissionais responsáveis pelo dimensionamento, montagem (setup) e manutenção dos ambientes de desenvolvimento, homologação e produção. Cada projeto pode exigir uma composição um pouco diferente desta célula. Lidaremos com transações financeiras ou outros dados que requerem muito cuidado, então precisaremos de um especialista em segurança, firewalls, encriptação e assim por diante. Infelizmente, é relativamente comum que estes profissionais só sejam alocados em um projeto quando a fase de entrega está prestes a ser iniciada. Essa prática resulta nos tradicionais embates entre desenvolvedores e “a turma de infra”. Eles deveriam se envolver com o projeto desde os primeiros dias, entendendo os requisitos e se mobilizando para realizar o dimensionamento, configuração e testes de todos os elementos de infraestrutura envolvidos na solução. Aqueles que o mercado convencionou chamar de “analistas-programadores” aparecem em três células: Dados, Serviços e Interfaces. Talvez a distinção entre analistas de sistemas e programadores realmente seja uma coisa do passado. Mas ignorar a diferença entre as três camadas não é uma boa idéia. Cada uma dessas áreas evoluiu muito nos últimos tempos. E, consequentemente, se tornaram mais exigentes em termos de conhecimentos e especialização. Vamos dar uma olhada em cada uma delas. O DBA (DataBase Administrator) morreu. Viva o novo especialista na camada de Dados, o profissional que sabe que o mundo não gira em torno de bases relacionais. O cara que, conhecendo os requisitos dos usuários, saberá lançar mão de bases multidimensionais e gerenciadores de conteúdo não-estruturado, além dos tradicionais bancos transacionais. 42 Capítulo 3 O programador clássico, aquele que se destaca por seu domínio de lógica e coisas como orientação a objetos, componentização, orientação a serviços, design patterns e outros papos afins, é aquele que ocupa a célula chamada Serviços. As fronteiras com as duas células vizinhas devem ser bem delimitadas. Acontece que, não raro, os ocupantes desta casa gostam de falar que “banco de dados é coisa do passado”. Isso sem falar que suas telas são terríveis, uns rascunhos medonhos: eles valorizam demais a parte invisível do iceberg, se esquecendo que tudo o que o usuário vê, toca e avalia são as interfaces. Ou seja, as Interfaces merecem uma célula só sua. É uma das áreas que mais se desenvolveu nos últimos tempos, principalmente depois do advento da Web. HTML, CSS, Javascript, Ajax, Flash e mais tecnologias para celulares e outros dispositivos móveis... Não é preciso ir muito longe para mostrar que especialistas são necessários aqui também. E que, além das tecnologias, eles devem dominar conceitos de ergonomia de software e usabilidade. Esses quatro profissionais ou grupos de profissionais, infraestrutura, dados, serviços e interfaces, têm pelo menos uma coisa em comum: normalmente eles são desastrados (e desastrosos) no trato com clientes e usuários. Porque eles não são treinados para entender o negócio e os usuários. Como já foi dito anteriormente, eles estão ansiosos para desempenhar sua função principal, seja ela modelar, programar ou configurar servidores. Para eles, o desenvolvimento de requisitos é um tipo de empecilho, uma “chateação” que deve ser resolvida antes que eles possam se debruçar naquilo que realmente gostam de fazer. Por isso, não raro, eles são negligentes – querem remover aquela barreira o mais rapidamente possível. Entra o Analista de Negócios. O cara que foi treinado para entender o negócio e os usuários. O profissional cuja principal atribuição é a comunicação desse entendimento para toda a equipe de projeto. Veja novamente a figura 2 acima. Clientes e usuários ficam do lado esquerdo daquele diagrama. Isso significa que o AN, o Coordenador e o Arquiteto são os principais pontos de contato com as partes interessadas que ficam fora da equipe. Mas é importante frisar que o AN não é um tipo de parede, um impedimento para o contato dos usuários com o restante do time. Pelo contrário, ele deve facilitar esses contatos. E organizá-los. É sabido que o contato não planejado compromete a performance de uma equipe. O AN, em conjunto com o Coordenador e o Arquiteto, faz com que cada contato da equipe com o mundo exterior seja estruturado. Por que três pontos de contato? Acontece que cada um deve cuidar de seu assunto: • O AN cuida do problema, ou seja, do entendimento do negócio e dos usuários; • O Arquiteto cuida da solução, de seu desenho, qualidade e implementação; enquanto o • Coordenador cuida do projeto, prazos, custos, suprimentos, e todas as demais questões administrativas. Mas é preciso explicar um pouco melhor as atribuições do Coordenador e do Arquiteto. É do Negócio ou de TI? 43 Dois Líderes Vou justificar minha sugestão apelando novamente para Fred Brooks10, que no mesmo livro já referenciado acima falou mais ou menos assim: “Pensadores são raros. Executores são raros. Pensadores-Executores são mais raros ainda.” Uma empresa não pode ter um modelo para a formação de equipes que se baseie na sorte. Na sorte de encontrar um gênio “pensador-executor” que lidere seus projetos. Por isso a distinção entre o Arquiteto (Pensador) e o Coordenador (Executor) é tão importante. O Arquiteto, também conhecido como Líder Técnico, é o dono da solução. Trabalhando com os representantes das células Interfaces, Serviços, Dados e Infraestrutura, ele cuida do desenho e da implementação de um sistema. Uma de suas principais atribuições é a manutenção da integridade arquitetônica da solução. Em conjunto com o AN, ele garante que a aplicação realmente satisfaz todos os requisitos apresentados. Ele lidera a equipe, cuidando exclusivamente de questões técnicas. E deve ter a palavra final sobre o escopo da solução. É interessante notar que não se trata de uma função burocrática. O arquiteto também coloca a mão na massa, implementando as partes mais críticas de uma solução ou criando guias e modelos para os demais membros. Já o Coordenador se concentra em todas as questões gerenciais e administrativas de um projeto. O gerenciamento de prazos, custos, suprimentos, comunicação, pessoal e riscos, não necessariamente nesta ordem, são suas principais atribuições. Ele entende que é ele quem trabalha para o time, e não o contrário. Como foi colocado por Tom DeMarco11 e Timothy Lister há muito tempo12: “A função do gerente não é fazer as pessoas trabalharem e sim tornar possível que elas trabalhem.” Definitivamente, não se aplica a máxima que diz que “cachorro com dois donos morre de fome”. É só uma divisão de responsabilidades: enquanto o coordenador se ocupa da aquisição da ração – no tempo correto e sem estourar o orçamento, o arquiteto monta o cardápio e serve nosso querido melhor amigo. A liderança técnica do arquiteto deve ser respeitada pelo coordenador. Eles debaterão suas respectivas restrições, sobre prazos por exemplo. Mas a palavra final sobre o desenho da solução deve ser do arquiteto. Da mesma forma, o arquiteto deve saber respeitar as deliberações do coordenador. Um bom arquiteto sabe que sempre existirão restrições de prazos e custos, por exemplo. E que essas restrições serão apresentadas e defendidas pelo coordenador, principalmente. 10 http://en.wikipedia.org/wiki/Fred_Brooks 11 http://en.wikipedia.org/wiki/Tom_DeMarco 12 No livro “Peopleware: Productive Projects and Teams”, Dorset House (1987). http://en.wikipedia.org/wiki/Peopleware:_Productive_Projects_and_Teams 44 Capítulo 3 Este tipo de divisão existe há tempos em outras áreas do conhecimento humano. Um dos melhores exemplos vem do cinema. O diretor de um filme é seu arquiteto, o pensador. Ele cria e controla os outros criadores, os atores, o diretor de fotografia, os especialistas em efeitos especiais e compositores da trilha sonora, entre outros. Essas especializações demandadas para a construção de um filme se equivalem às nossas especializações técnicas (Interfaces, Dados...). Mas, quando um filme recebe um prêmio, é o produtor (seu executor) quem sobe no palco. No processo mais comum é o produtor quem contrata (ou aloca) o diretor. O produtor se ocupa de todas as funções administrativas relativas ao projeto do filme, contratações, financiamento, controle do cronograma etc. O pensador tem sua própria categoria de prêmios, de Melhor Diretor. Por históricas que sejam as desavenças entre produtores e diretores, a indústria do cinema sabe que precisa desses dois tipos de cérebros para realizar seus projetos. São raros os gênios, como Spielberg e Lucas, que conseguem assumir qualquer das duas funções. Mais raros ainda são aqueles que conseguem acumular as duas funções em um mesmo projeto. O método para gerenciamento de projetos Ágeis chamado Scrum13 tem uma proposta que, em conceito, se assemelha com este desenho. Ele sugere a existência de dois perfis: o Scrummaster e o Product Owner (Dono do Produto). O primeiro se aproxima daquele que chamo de coordenador, enquanto o Product Owner se aproxima um pouco do arquiteto. Um dos criadores do método, Jeff Sutherland, criou uma bela analogia para explicar a importância dos dois papéis14: comparando com uma equipe de rally, o Scrummaster é o piloto e o Product Owner é o navegador. A similaridade com minha proposta só não é total porque muitos defendem que o Product Owner trate exclusivamente do domínio do problema. Eu acho que, com tal finalidade, até o nome – Dono do Produto – é infeliz. O dono do produto, em minha leitura, fala sobre a solução e não sobre o problema que pretende resolver. Falo mais sobre o Scrum e outros processos de desenvolvimento e gerenciamento de projetos no último capítulo. 13 http://en.wikipedia.org/wiki/Scrum_(development) 14 http://jeffsutherland.com/scrum/ É do Negócio ou de TI? 45 O Tamanho do Time O modelo sugerido acima deve ser adaptado para cada empresa ou tipo de projeto. Mas sua estrutura básica deveria ser respeitada. Uma empresa bem pequena, por exemplo, pode não ter 7 funcionários. Ou 7 especialistas. Não é por isso que o modelo não lhe atenderá. Empresas de software, com irritante frequência, incham mas não crescem. Acumulam funções similares, talvez aproveitando a ampla oferta de generalistas. Isso é inchaço. Ao usar o modelo como um guia elas podem, a cada contratação, preencher as células de especialização onde há maior carência. Assim seu processo de seleção se torna mais objetivo. Mas, tratemos de algumas questões mais práticas. Se um determinado projeto demandar apenas 4 pessoas, por exemplo, como fica o desenho da equipe? Algumas recomendações: • Que o coordenador e o arquiteto sejam realmente pessoas diferentes. O projeto ganha com tal distinção, com esse confronto. • O coordenador pode acumular a função do AN. Suas habilidades técnicas e sociais são, de certa forma, equivalentes, o que deve facilitar a junção de responsabilidades. • E o arquiteto, como já foi dito anteriormente, realmente coloca a mão na massa. Então ele pode acumular qualquer outra atribuição técnica (interfaces, serviços e dados). Devemos notar que o arquiteto sairá mesmo de uma dessas células. E como saber qual o número ideal de AN's para um empresa? Ainda é muito difícil cravar um número, uma fórmula. Uma grande empresa nacional, com cerca de 60 mil funcionários, tem cerca de 150 AN's. Isso daria algo em torno de 1 analista para cada 400 funcionários. Definitivamente, dada a ordem de grandeza, não serve muito como referência. Prefiro uma fórmula que leve em conta o número de projetos correntes. Quantos projetos sua empresa desenvolve de forma simultânea? O número ideal de AN's é igual ao número de projetos simultâneos vezes 2. Eu disse número ideal. Porque o ideal é que os AN's atuem em duplas. No decorrer do livro justifico minha sugestão. Por enquanto vale dizer que se o número ideal não for possível, por alguma restrição qualquer, mesmo assim considere a possibilidade do trabalho de análise de negócios ser executado por duas pessoas: o AN e mais um integrante da equipe, de preferência o coordenador. Faltou explicar a formulazinha acima: por que o número de projetos simultâneos vezes 2? Porque é enfaticamente defendido neste livro que seja adotado um processo de desenvolvimento iterativo e incremental15. Sendo assim, os AN's terão trabalho durante todo o projeto. É o oposto do modelo cascata (ou Waterfall16), onde o AN desenvolve seu trabalho nas fases iniciais de um projeto e depois pula para outro. Falo mais sobre isso no decorrer do livro e de maneira mais específica no último capítulo. 15 http://en.wikipedia.org/wiki/Iterative_and_incremental_development 16 http://en.wikipedia.org/wiki/Waterfall_model 46 Capítulo 3 47 É do Negócio ou de TI? Parte II Entendendo o Negócio 48 Capítulo 3 Modelagem de Negócios 49 Capítulo 4 Modelagem de Negócios De todas as disciplinas que formam a engenharia de software, nenhuma é mais mal compreendida e mal falada do que a Modelagem de Negócios. Muitos a veem como pura burocracia – geradora de um tipo de documentação que nunca mais é utilizada e muito menos atualizada. Outros tantos acham que se trata de tentar representar em modelos todo um negócio, nos mínimos detalhes, o que é impossível. Tanta má compreensão resultou em um incômodo fato: quase ninguém pratica a modelagem de negócios em seus projetos. Existe até quem sugira que a modelagem seja tratada como um projeto a parte, separado daquele que deve gerar a solução. Quanta desinformação! Que faz com que os projetos já comecem no levantamento de requisitos, com corajosos analistas tentando compreender as necessidades dos usuários. Não raro esse entendimento é falho porque o analista não conhece o negócio. Sua comunicação com clientes e usuários é prejudicada porque ele simplesmente ignora os conceitos básicos que caracterizam aquela organização e seu mercado. Como esperar boas respostas se o analista não sabe o que perguntar? Engraçado é que não é raro ouvirmos que “o usuário nunca sabe o que quer”. Como o título desta segunda parte do livro antecipa, a modelagem de negócios serve para que possamos Entender o Negócio. As técnicas e métodos que formam esta disciplina nos ajudam a compreender todos os aspectos de uma empresa, suas motivações, estruturas, processos e regras. A modelagem de negócios é o oposto da modelagem de sistemas. Nesta sempre objetivamos o mínimo detalhe, os modelos evoluem até seu estágio final, o código. Na modelagem de negócios nos contentamos com o mínimo, só modelamos o essencial. Essencial para quê? Oras, para uma boa compreensão do negócio. Pensamos assim: se uma parte do negócio é bem compreendida por todas as partes interessadas, então para que gastar tempo tentando modelála? Hora do alerta para todos que gostam de receitinhas de bolo, checklists e afins: todas as técnicas e métodos sugeridos nesta parte do livro são opcionais. Você só lançará mão deles em um projeto quando de fato precisar daquele entendimento. E, por favor, pense 10 vezes antes de utilizar qualquer diagrama aqui sugerido como documentação de sistema. A explicação é simples: todo negócio é volátil e dinâmico demais. Sua documentação ficaria obsoleta em uma velocidade impressionante. E a manutenção desses documentos pode ser cara demais. Alertas colocados, mergulhemos então nesta bela e mal compreendida matéria. Neste capítulo veremos o básico da disciplina, opções de linguagens para modelagem e uma introdução às 3 visões que compõem um modelo de negócios. Visões que serão detalhadas nos capítulos seguintes. 50 Capítulo 4 Por que modelamos? Ok, você já sabe, modelamos para entender. Em nosso caso específico, para entender um negócio. Mas essa afirmação, de certa forma simplista, talvez não seja suficiente para que você justifique a aplicação desta disciplina em seu próximo projeto. Vamos detalhar melhor as motivações para a execução da modelagem de negócios: • Uma imagem explica mais e melhor do que mil palavras: este velho dito popular, levemente adaptado, é verdadeiro mas ao mesmo tempo perigoso. Não é qualquer imagem que substitui milhares de palavras. Há uma imagem certa para cada situação. E isso significa mais agilidade nos processos de entendimento, avaliação e comunicação com as partes interessadas. • Precisamos saber onde vamos pisar: nosso projeto vai mexer no negócio, alterando processos e embutindo sistemas. Precisamos ter uma clara noção de todos os impactos que vamos gerar. Afinal, quem é louco de fazer de um negócio um laboratório de experiências1? Um bom modelo serve como base para essa avaliação e para a realização de todas as experiências que se fizerem necessárias. O modelo é o nosso mapa e laboratório. O modelo também é, por que não, o nosso tabuleiro. Se ainda assim estiver difícil para você justificar o esforço de modelagem, então apele para autores de fora, como a dupla escandinava Hans-Erik Ericksson e Magnus Penker2, por exemplo. Segundo eles: “Se os requisitos estão baseados em um bom modelo de negócios, há uma chance muito maior do sistema de informação suportar o negócio de maneira adequada”. Além disso, Eriksson e Penker listam outras vantagens que podemos obter de um bom modelo de negócios: • • • • Maior e melhor aderência do sistema ao negócio; Facilidade na integração de sistemas; Redução no custo de propriedade (manutenção) de sistemas; e Reutilização da lógica do negócio em outros sistemas. Claro, não é o modelo por si só que realiza tantas mágicas. Dependemos de bons processos de desenvolvimento, boa arquitetura de aplicações e um zilhão de outras coisinhas mais. Aqui é importante notar que um bom modelo de negócios pode representar mesmo várias vantagens. Mas do que é feito um bom modelo? 1 Pensei um pouco sobre a frase e quase a eliminei. Resolvi deixá-la na companhia deste breve comentário: cientes ou não, existem vários loucos por aí que fazem isso: do negócio uma experiência. 2 Autores de “Business Modeling with UML”, Wiley (2000), que aparece na Bibliografia Comentada, no final deste livro. 51 Modelagem de Negócios O que Modelamos? Negócios de qualquer segmento ou porte são sistemas muito complexos, compostos dos mais diversos elementos. Temos pessoas, funções e departamentos; instalações, máquinas e equipamentos; processos, procedimentos e regras; produtos, serviços e clientes; mercado, concorrentes e parceiros; planos, objetivos e metas. Essa listinha é genérica e nem de longe tenta encerrar o assunto. Um modelo deve conseguir representar todos os componentes e aspectos de um negócio relevantes em determinada situação. Mas deve fazê-lo de forma organizada, senão não terá valor algum. Todo negócio é complexo. Nossos modelos devem representar essa complexidade de forma elaborada3, de maneira que facilite o entendimento e comunicação. Tão antiga quanto andar para a frente é a noção de que facilitamos a resolução de um problema grande e complicado quebrando-o em diversos pedacinhos. Um modelo de negócios é formado por um determinado número de visões – os nossos pedacinhos. Cada visão indica uma forma diferente de enxergar o negócio, uma perspectiva diferente4. Este livro apresentará apenas as visões mais comuns, existentes em negócios de qualquer natureza. Mas é importante frisar que, além de não serem obrigatórias (na composição de um modelo de negócios), elas não são as únicas visões possíveis. Estudaremos aqui e nos próximos capítulos 3 visões: • Visão do Negócio: que também pode ser chamada de Visão da Motivação (do Negócio). Ela nos ajuda a entender o negócio e seu ecossistema, detalhando principalmente as suas motivações, seus objetivos e metas. • Visão da Estrutura: que nos ajuda a analisar todos os recursos utilizados, consumidos ou produzidos por uma empresa. • Visão dos Processos: que cuida de toda a parte “viva” de uma organização, toda a sua dinâmica. Optei por essas três visões, e só por elas, por acreditar que este conjunto representa um modelo mínimo – útil e necessário na grande maioria dos projetos de sistemas. De forma resumida: a visão do negócio nos mostra o cenário e os objetivos; em estrutura vemos todos os recursos que estarão envolvidos nesta busca pelos objetivos; e a visão dos processos mostra como faremos essa busca. Figura 3: As 3 visões de um modelo de negócios 3 Combinemos o seguinte: aqui o oposto de complexo não é simples e sim elaborado. Entendemos que não é possível simplificar um negócio (através de um modelo), e sim torná-lo melhor elaborado. Esse conceito foi surrupiado de “The Back of the Napkin”, livro de Dan Roam, Portfolio (2008). Como veremos no restante deste capítulo, não foi só nisso que este livro me inspirou. 4 Esta frase, se fora do contexto, compromete um tanto, não? 52 Capítulo 4 Existem relativamente poucos trabalhos sobre a modelagem de negócios. E não há um padrão consolidado acerca das visões, nem mesmo das básicas ou mais comuns. No livro de Eriksson e Penker citado anteriormente, “Business Modeling with UML”, além das três visões acima existe a Visão do Comportamento. Ela é utilizada particularmente para a análise de recursos complexos. Aqui vou considerá-la como um subconjunto da visão de processos. Justificarei minha escolha no capítulo 7. Outro trabalho sério sobre modelagem de negócios, “Business Modeling: A Practical Guide to Realizing Business Value5”, não fala de visões mas de disciplinas de modelagem de negócios. Segundo os autores existiriam 4: Modelagem de Processos, da Motivação, da Organização e das Regras. Apesar de considerar várias sugestões deste trabalho, optei pelo termo Visões em detrimento de Disciplinas. E considero a modelagem da motivação como um subconjunto da visão do negócio. Assim como a modelagem de regras é um subconjunto de todas as três visões que apresento. Espero que tudo isso fique um pouco mais claro na medida em que as visões forem apresentadas com mais detalhes. Agora preciso explicar o adjetivo “sério” utilizado no início do parágrafo anterior. Talvez o termo seja exagerado, mas serve para distinguir os dois trabalhos supracitados de outros, particularmente da forma como a modelagem de negócios é apresentada no RUP e no livro “Modelagem Ágil” de Scott Ambler6. Das 351 páginas de seu trabalho, Ambler dedica apenas 7 ao tema modelagem de negócios. E, como o RUP, baseia suas sugestões exclusivamente em casos de uso de negócio (BUC – Business Use Case) e modelos de objetos de negócio. Fica claro que ambos trabalhos nasceram de “gente de sistema” e não de negócio. Os modelos sugeridos são muito fracos na representação de um negócio real. Não distinguem nem elementos básicos como recursos, processos, objetivos e regras. A especificação de casos de uso é uma das ferramentas mais importantes de um AN. Mas neste trabalho é sugerido que ela seja utilizada exclusivamente para descobrir e descrever requisitos funcionais de um sistema. Aliás, foi só para isso que ela foi inventada. Qualquer outro uso é “forçar de barra”, algo como usar um serrote para colocar um prego na parede. Pois é, já reparou como tomei uma série de decisões por você? Mas eu não espero que você confie em mim. Não assim, de imediato. O que eu espero mesmo é que você, como eu, sinta na pele o que é usar uma sugestão ou outra. Tente, por exemplo, modelar um negócio da forma como é sugerido por Scott Ambler e no RUP. E tire suas próprias conclusões. Eu cometeria um grave engano se ficasse “em cima do muro” neste livro. Minhas experiências não serviriam para nada. Mas, por favor, isso aqui não é um atalho. Na menor desconfiança acerca de alguma das minhas indicações, tente o outro lado. O que eu prometo é isso: sempre mostrar qual é o outro lado. Portanto, para ficar bem claro: a modelagem de negócios sugerida neste livro não tem nada a ver com aquela que aparece no RUP e derivados7. Ponto. Vamos para a próxima questão. 5 De David M. Bridgeland e Ron Zahavi. Morgan Kauffman / OMG Press (2008). 6 “Modelagem Ágil – Práticas Eficazes para a Programação eXtrema e o Processo Unificado”, Scott W. Ambler. Bookman / Artmed Editora (2004). 7 Faltou citar outro livro relativamente famoso que caiu na “armadilha” do RUP: “UML for the IT Business Analyst”, de Howard Podeswa. Thomson (2005). Modelagem de Negócios 53 Quanto Modelamos? Uma das maiores falácias sobre a modelagem de negócios é que ela é burocrática. Não raro utilizam o seguinte termo para condená-la: BDUF8, sigla que em inglês significa “Big Design Up Front”. Numa tradução livre, “um montão de diagramas antes de qualquer coisa”. O termo não foi criado exclusivamente para a modelagem de negócios. Mas pegou. E não de forma gratuita. Realmente há muita gente que acha que deve modelar todo um negócio, ou boa parte dele, antes de fazer qualquer outra coisa em um projeto. Não é por acaso que há muita gente também que sugere que a modelagem de negócios seja tratada como um projeto a parte, bem separado daquele que deve gerar software. Duas coisas ficam implícitas aqui: • Uma visão muito “cascata” do ciclo de vida de desenvolvimento; e • A ilusão de que este modelo estará imune as mudanças que afetam diariamente um negócio. A modelagem de negócios no contexto de um projeto de software é diferente. Não queremos documentar o negócio, apenas entendê-lo. Por isso e pelos equívocos listados acima a questão aqui colocada é muito importante: quanto modelamos? Quantos diagramas são necessários ao entendimento, avaliação e comunicação de um determinado negócio? Chegamos naquela questão que interessa a maioria: quanto tempo isso leva? Resposta default em nossa área: depende. Alguns projetos mais simples podem demandar apenas um ou dois diagramas que não consomem nem um dia de trabalho. No outro extremo podemos ter empreendimentos que exigem a elaboração de dezenas ou até mesmo centenas de artefatos. O mais importante aqui é um teste muito simples: cada diagrama deve explicar de forma completa e inequívoca algum aspecto do negócio. Esse diagrama só foi gerado porque não havia outro meio de buscar tal entendimento. Mas, mesmo em um cenário em que muito trabalho de modelagem é exigido, não há justificativas para que esse trabalho seja feito “antes de qualquer coisa”. O tal BDUF é nocivo sim e deve ser evitado pelo AN e por toda a equipe de projeto. Na sequência deste trabalho tentarei ilustrar este trabalho em um processo iterativo e incremental. Mesmo que o AN seja obrigado a gerar um grande número de diagramas, ele o faz de forma gradual e durante praticamente todo o decorrer de um projeto. O que nos traz de volta a questão: quanto modelamos? Apenas o suficiente para o correto entendimento do negócio. Podemos pular para a próxima questão? 8 http://en.wikipedia.org/wiki/Big_Design_Up_Front 54 Capítulo 4 Onde Modelamos? Estranhou a pergunta? Você verá que a resposta não é tão complicada. Refazendo a questão: Onde baseamos nossos modelos? Um monte de diagramas como fluxogramas e organogramas não representam necessariamente um modelo de negócio. Ok, um modelo é um conjunto de diagramas. Mas esse conjunto deve fazer sentido, deve ser íntegro e coerente. Uma das principais características de um bom modelo de negócio é sua Integridade Conceitual. Para que tal integridade seja obtida todos os diagramas devem compartilhar uma mesma base, uma mesma origem. Chamaremos esta base de Metamodelo, um modelo que explica os outros modelos e diagramas. Pense nele como um mapa ou, melhor ainda, como um grande tabuleiro. Cada diagrama que gerarmos será como uma peça neste tabuleiro. Sendo assim, cada diagrama deve respeitar as regras de uso do tabuleiro. Existe um número razoável de alternativas de padrões de notação ou linguagens para a modelagem de negócios, mas são poucas as que oferecem um metamodelo completo. Agora, antes de entregar de mão beijada minha opção (acho que já o fiz), apresentarei as 4 principais alternativas de linguagens para a modelagem de negócios, suas vantagens e desvantagens: Linguagem de Modelagem Descrição, prós e contras IDEF9 (Integration DEFinition) Uma família inteira de linguagens de modelagem criada entre os anos 1970 e 1980. Oferece variações (representadas por números na frente do nome) para os mais diversos tipos de uso. Por exemplo: • IDEF0 – Modelagem de Funções • IDEF1 – Modelagem de Informações • IDEF1X – Modelagem de Dados • IDEF4 – Projeto Orientado a Objetos • IDEF8 – Modelagem de Interfaces com usuários Pró: Tem muito tempo de estrada. Contras: Tem muito tempo de estrada e envelheceu. Apesar do aspecto “família”, carece de um metamodelo. É provável que esta linguagem seja mais conhecida através do EPC10 (Event-driven Process Chain) modelo de trabalho que a tem como núcleo, o ARIS (Architecture of Integrated Information Systems)11. Criada no início dos anos 1990, a EPC é uma linguagem para modelagem de processos de negócio. Como o próprio nome indica, tem os eventos de negócio como ponto de partida. Prós: Difusão e bom número de ferramentas que a suportam. Contra: Incompleta e não-extensível. 9 http://en.wikipedia.org/wiki/IDEF 10 http://en.wikipedia.org/wiki/Event-driven_process_chain 11 http://en.wikipedia.org/wiki/Architecture_of_Integrated_Information_Systems 55 Modelagem de Negócios Linguagem de Modelagem Descrição, prós e contras BPMN12 (Business Process Modeling Notation) Padrão criado pelo BPMI (Business Process Management Initiative) que em 2005 foi incorporado pelo OMG (Object Management Group). Como o próprio nome indica, é um padrão de notação para processos de negócio. Ou seja, não contempla outros elementos, como estruturas e dados, que formam um modelo de negócios completo. Na realidade a aplicação de BPMN parece fazer mais sentido no desenho de uma solução, na modelagem de como um processo deve ficar (to be). É provável que sua utilização se limite a projetos que envolvam a implementação de um produto BPMS (Business Process Management System)13. Pró: É um moderno fluxograma, passível de transformação direta para execução14. Contras: É só um moderno fluxograma. E carece de um metamodelo15. A UML é uma linguagem de modelagem mantida pelo OMG. Sua UML16 (Unified Modeling Language) versão 1.1 foi lançada em novembro de 1997, marcando o fim de um embate que era conhecido como a “Guerra dos Métodos”. Grady Booch, James Rumbaugh e Ivar Jacobson, os “Três Amigos”, encabeçaram a criação desta linguagem que reunia as melhores ideias de cada metodologista. A UML nasceu para modelar sistemas, não negócios. Ainda assim algumas alternativas foram sugeridas, particularmente no RUP e nos trabalhos de Scott Ambler e Howard Podeswa (criticados anteriormente neste capítulo). Mas a UML é extensível, ela pode ser adaptada praticamente para qualquer tipo de necessidade. Em 2000 Hans-Erik Ericksson e Magnus Penker apresentaram a EPBE (Eriksson-Penker Business Extensions) no livro “Business Modeling with UML”. Estas extensões possibilitam a geração de um completo modelo de negócios. Prós: É a alternativa mais completa para modelagem de negócios. Com amplo suporte de ferramentas. Contra: A UML é relativamente complexa. Pode não ser muito intuitiva para pessoas não técnicas. 12 http://en.wikipedia.org/wiki/BPMN 13 http://en.wikipedia.org/wiki/BPMS 14 Mas nem aqui a coisa ainda funciona direito. A transição de modelos BPMN para BPEL (Business Process Execution Language) (http://en.wikipedia.org/wiki/BPEL) ainda é problemática. 15 Apesar dos esforços do OMG e alguns de seus integrantes no sentido de dar 'estofo' para a BPMN, especificamente através do BPDM (Business Process Definition Metamodel) (http://en.wikipedia.org/wiki/BPDM), até a data de publicação deste livro não havia nenhuma definição. Oracle, SAP e IBM, por motivos não muito claros, não querem que esta evolução apareça na versão 2.0 da BPMN. 16 http://en.wikipedia.org/wiki/Unified_Modeling_Language 56 Capítulo 4 UML & EPBE Se o quadro anterior não foi suficiente para tornar isso claro, então reafirmo aqui uma outra escolha que fiz por você: quase todas as propostas de diagramas para a modelagem de negócios apresentadas neste livro se baseiam na UML e em sua extensão EPBE. Preciso justificar minha escolha: • A UML já tem muitos quilômetros e projetos rodados. É uma linguagem madura, ao contrário da BPMN por exemplo, que carente de um metamodelo não é muito mais do que uma moderna régua de gabarito. • Como a UML é um padrão de facto para a modelagem de sistemas, sua adoção para a modelagem de negócios reduz traduções e consequentes problemas. A comunicação entre a turma de negócios e a turma de sistemas se torna mais natural e intuitiva. • Reduzimos gastos com ferramentas e treinamento ao adotar um mesmo padrão para a modelagem de negócios e de sistemas. • A EPBE expande os velhos padrões de modelagem de negócios (organogramas e fluxogramas), oferecendo novas maneiras de se ver um negócio. • A EPBE está disponível em diversas ferramentas, tanto comerciais quanto aquelas gratuitas e / ou de código aberto. • UML e EPBE são extensíveis. Podemos adaptar os padrões para acomodar aspectos que sejam exclusivos de determinado domínio. Além disso, podemos incorporar novas ferramentas, como Balanced Scorecards, Mapas Estratégicos e outras que não fazem parte do desenho original destes padrões mas se configuram importantes elementos de um negócio. • Casos de uso, uma das principais ferramentas utilizadas por um AN para a descoberta e descrição de requisitos, é também uma das 5 visões oferecidas pela UML. Configuram a visão central, aquela que permite rastreabilidade entre as demais visões (Lógica, Processo, Implementação e Distribuição), ou seja, a ligação entre os requisitos e todos os artefatos gerados em um projeto. Está aqui a ligação entre modelos de negócios e modelos de sistemas. Se a lista acima não foi sufiente para convencê-lo do uso da UML para a modelagem de negócios, então talvez você queira interromper a leitura por aqui mesmo... Peraí! Brincadeirinha. Mesmo que por algum motivo qualquer você não queira ou não possa utilizar a UML, o mais importante neste e nos próximos capítulos desta parte são os conceitos. De certa maneira, todos os diagramas aqui sugeridos podem ser feitos em outra linguagem. Até numa linguagem inventada por ti. Então, por favor, siga adiante. 57 Modelagem de Negócios Quando Modelamos? Parece consenso, pelo menos teórico17, que todo projeto começa pelo entendimento do negócio, ou seja, pela modelagem do negócio. Se nenhum estudo é necessário, se toda a compreensão sobre o negócio é compartilhada por todas as partes interessadas, então não há o que modelar. Não se deixe enganar, essa situação é raríssima. Quase sempre precisaremos, no mínimo, de um ou outro modelo. Quando eles devem ser gerados? Quando a necessidade de entendimento de determinado aspecto do negócio for percebida. Em um processo iterativo e incremental, a modelagem de negócios pode ocorrer durante praticamente todo o projeto. Na medida em que novos processos ou atividades de negócio virarem escopo de uma iteração, a necessidade de gerar modelos – de entender aquela parte do negócio, pode aparecer. O modelo de ciclo de vida “iterativo e incremental” aparece em diversos momentos deste texto. Chegou a hora de entender seus conceitos básicos. Logo no início de um projeto precisamos ter uma visão do todo, algo que em inglês chamam de “big picture”. É como se fosse uma fotografia instantânea com uma característica muito peculiar: ela tem 2 quilômetros de extensão e apenas 2 centímetros de profundidade. Normalmente ela será um elemento da Visão do Negócio. Esta grande fotografia será o mapa que norteará todos os trabalhos da equipe. O AN, ao entender o problema de negócio e os requisitos do usuário, ajudará a equipe a definir as prioridades – a sequência de trabalho. De todos os elementos retratados nesta figura, onde está aquele que é mais crucial para a solução do problema? O trabalho deve começar por ele. O AN vai detalhá-lo, saindo dos 2cm iniciais para 4, 8, ou 16 centímetros, dependendo da complexidade do problema em questão e das necessidades de entendimento das partes interessadas. Após entregar este estudo para a equipe de construção, o AN parte para o segundo elemento mais importante. Não sem antes avaliar os resultados da iteração anterior. E assim sucessivamente. Vejamos o ciclo de vida de um projeto de uma forma “insanamente simples”, como sugerida por Scott Berkun18: Todo e qualquer projeto tem 3 fases bem delimitadas: i) aquela onde definimos o que precisa ser feito; ii) depois o momento em que selecionamos e desenhamos a melhor solução; e finalmente, iii) a fase em que a gente constrói a solução. O desenho ao lado, intencionalmente, nos lembra uma cascata. Figura 4: As 3 Fases de todos os projetos. 17 Porque na prática pouca gente modela. 18 No obrigatório “A Arte do Gerenciamento de Projetos”, de Scott Berkun. Artmed Editora (2008). Este trabalho reaparece na Bibliografia Comentada e em diversos pontos deste livro. 58 Capítulo 4 Quando um projeto utiliza o modelo de ciclo de vida “cascata”, cada uma das três fases acima ocorrem apenas uma vez. Quando falamos sobre um modelo iterativo e incremental, a primeira impressão que fica é a de que este modelo nada mais é que do que “um monte de cascatinhas”. É uma forma simples de entender, mas ela esconde alguns perigos. A principal justificativa para a adoção de um ciclo iterativo e incremental é a aproximação com os usuários e clientes. Incentivamos assim que eles avaliem e nos deem retorno sobre nosso trabalho o quanto antes, e diversas vezes no decorrer do projeto. Ao ver o processo iterativo e incremental como “um monte de cascatinhas” ignoramos esse retorno, o que não é correto. O feedback de usuários e clientes define ou altera o plano de trabalho das iterações futuras. O que em outros modelos de ciclos de vida é tratado como mudança, em um processo iterativo é visto como evolução, como o amadurecimento da solução. O princípio é muito lógico: somos humanos, vamos errar. Ao adotar um processo iterativo e incremental assumimos nossa falibilidade, nossa humanidade. Voltemos ao gráfico acima. O trabalho do AN se limita a primeira caixinha, na definição do que precisa ser feito. Então, se em determinado projeto está prevista a realização de 10 iterações, entendemos que o trabalho do AN, a modelagem do negócio e o desenvolvimento dos requisitos, ocorrerá 11 vezes. Onze? Sim, porque consideramos que a construção daquele instantâneo de “2km X 2cm” é uma iteração em si – que podemos chamar de “Iteração 0 (zero)”. Como eu prometi o básico sobre o modelo iterativo e incremental, aproveitemos o momento para aprender outras coisinhas básicas: • Iterar vem do latim itetare, que significa repetir. Estamos dizendo que repetimos determinadas atividades n vezes no decorrer de um projeto. • O modelo também é incremental porque cada iteração, cada repetição deve significar o acréscimo de funcionalidades a solução. • A duração das iterações é fixa. O escopo pode alterar, mas o prazo não. Quanto maior a insegurança e / ou a volatilidade dos requisitos, menor deve ser a duração de uma iteração. Para não complicar as organizações podem adotar 2 padrões: 30 dias para projetos “calmos” e 15 dias para projetos “nervosos”. • O término de cada iteração, com exceção da iteração zero, significa a entrega de software rodando. Isso é mandatório. Só assim usuários e clientes podem avaliar a evolução e a qualidade do trabalho. Não há nem nunca existirão modelos ou documentos que substituam o software. O que não significa que este release esteja pronto para ser colocado em ambiente de produção, por favor. Na maioria das situações as entregas intermediárias serão avaliadas em um ambiente de homologação ou testes. • Na indisponiblidade do usuário, é o AN quem deve receber e avaliar o software. Mas este, definitivamente, não é o cenário ideal. A avaliação de usuários e clientes não pode ser terceirizada. Uma boa alternativa é a liberação quinzenal para AN's e mensal para os usuários. Modelagem de Negócios 59 Como Modelamos? Você reparou a sequência de tópicos deste capítulo? Ela apresenta uma parte muito importante do “know-how”, do “saber como” modelar. Espere, não precisa voltar lá no início. Vou repetir a sequência abaixo: • • • • • • Por que modelamos? O Que modelamos? Quanto modelamos? Onde modelamos? Quando modelamos? Como modelamos? Esta sequência de perguntas é um dos três principais componentes de uma metodologia proposta por Dan Roam no livro “The Back of the Napkin – Solving Problems and Selling Ideas with Pictures19”. Chamada de 6 W's20, essas questões representam 6 maneiras de ver as coisas. A ordem das perguntas é importante. Sua lógica tem justificativas até no ramo da neurobiologia. Claro que não vou me aprofundar tanto aqui. Se você ficou curioso, leia o livro do Dan21. Nos interessa aqui saber como modelar. E nosso processo de modelagem, de entendimento do negócio, fica mais fácil se tentar responder essas 6 perguntas em sequência22: 1. 2. 3. 4. 5. 6. Por quê? Quem ou O Quê? Quanto? Onde? Quando? Como? Mas preciso avisar que, apesar da lógica (e da neurobiologia), tomei a liberdade de alterar a sequência original de perguntas proposta por Dan. O “por que” é sua última pergunta. Para nós será a primeira. E a explicação é simples: o AN começa o trabalho tentando entender porque foi colocado no projeto... Ok, é mais importante que isso. A primeira pergunta é: por que o projeto é necessário? Por que a empresa precisa do produto deste projeto? Este é o ponto de partida da análise de negócios. É aqui que aprendemos os Requisitos de Negócio. 19 Portfolio (2008). 20 6 W's porque no inglês as perguntas são: Why, Who/What, How Much / How Many, Where, When e How. Ok, o cara forçou a barra. Tem dois H's ali no meio. Mas as palavras também possuem um W. Então, tá valendo. Você entendeu. 21 E veja mais detalhes sobre ele na Bibliografia Comentada, no final deste livro. 22 Pois é, para os caras é fácil decorar “6 W's”. Mas podemos tentar. Que tal? PQQOQC? Tente em voz alta: PôQêQêOQéCê? Se ainda não decorou, fique calmo. Logo será tão natural quanto contar de 1 a 6. 60 Capítulo 4 A pergunta seguinte nos ajuda a descobrir quem ou o que está envolvido no problema / oportunidade em questão: Quem é o nosso cliente? Qual é o nosso produto? O que que tá pegando? Depois nos preocupamos com o quanto: Quanto a empresa espera ganhar? Quanto ela vai economizar? Quantos irão para o olho da rua? Na quarta questão avaliamos o onde: Onde a coisa vai acontecer? O objetivo aqui é localização mesmo: mercado, região, departamento. Qual é o local? Só então mergulhamos no quando, nos aspectos temporais do problema em questão: Quando esse problema ocorre? Qual deve ser a sequência de eventos ou atividades? E, finalmente, chegamos no como: Como a empresa atende seus clientes? Como ela executa determinado processo? Como ela fabrica? E assim por diante. Precisa dizer que o “como” é a pergunta mais difícil de ser respondida? Que é a mais complexa? Que é aquela que tomará a maior parte de nosso tempo? O “como” é a cola das 5 questões anteriores. Livros sobre modelagem costumam ser muito generosos na definição do que devemos desenhar, mas excessivamente econômicos na descrição do processo de modelagem. Eriksson e Penker, por exemplo, já abrem seu livro avisando que não se trata de uma “metodologia de modelagem”. Apesar de não se tratar de um livro sobre modelagem de negócios, o trabalho de Dan Roan cobre esta lacuna de uma maneira muito prática e didática. Seu método é indicado para qualquer pessoa, para a solução de qualquer tipo de problema. Meu trabalho aqui foi remixar o melhor dos dois mundos em uma proposta específica para analistas de negócios. No próximo capítulo estudaremos este remix e os conceitos básicos da modelagem de negócios.