Analysis of Open-Source CASE Tools For Supporting Software Modeling Process With UML
Analysis of Open-Source CASE Tools For Supporting Software Modeling Process With UML
Analysis of Open-Source CASE Tools For Supporting Software Modeling Process With UML
net/publication/328470591
CITATIONS READS
4 381
3 authors, including:
Sávio Freire
Federal Institute of Ceará
47 PUBLICATIONS 163 CITATIONS
SEE PROFILE
All content following this page was uploaded by Sávio Freire on 09 May 2019.
Logo, a identificação das boas práticas de modelagem seguidas • Diagrama de estado: Apresenta os diversos estados que um
por cada ferramenta torna-se um importante critério para auxiliar objeto pode assumir durante o seu ciclo de vida;
no processo de escolha de ferramentas para modelagem de • Diagrama de sequência: Descreve a interação entre os
sistemas. Além disso, por se tratar de ferramentas de código livre, objetos e atores por meio da sequência de mensagens
pode-se evoluir as ferramentas melhor avaliadas com o intuito de trocadas;
aumentar a quantidade de diretrizes atendidas, e, • Diagrama de atividade: Apresenta o fluxo de controle de
consequentemente, maximizar a possibilidade de confecção de uma atividade para outra.
modelos cada vez mais corretos. Em outras palavras, modelos que
seguem as especificações da UML. Vale ressaltar que os diagramas supracitados apresentam a
Este artigo está organizado como segue. A seção 2 apresenta estrutura do sistema por meio do diagrama de classes e as
os conceitos relacionados com a modelagem de sistemas, as interações entre as entidades internas e externas por meio dos
ferramentas CASE e a diretrizes para a modelagem de software. A outros diagramas. Com isso, tem-se diferentes perspectivas
discussão acerca dos trabalhos relacionados é apresentada na complementares do sistema que irão auxiliar na fase de
seção 3. A seção 4 detalha a análise das ferramentas open-source. desenvolvimento de sistemas.
Finalmente, as considerações finais são apresentadas na seção 5.
2.2 Ferramentas CASE
O termo Computer-Aided Software Engineering (CASE) se refere
2 Fundamentação Teórica às ferramentas que auxiliam o PDS por meio da automatização
Esta seção apresenta os conceitos relacionados à modelagem de das suas atividades [1]. Essas ferramentas possuem um conjunto
sistemas, às ferramentas CASE e às diretrizes para modelagem de de funcionalidades relacionado às atividades ou ao estágio do
software utilizando os diagramas da UML. processo. Além disso, essas ferramentas podem ser integradas
formando um CASE workbench, possibilitando o apoio aos
2.1 Modelagem de Sistemas diversos estágios que compõem uma atividade do PDS.
Um Processo de Desenvolvimento de Software (PDS) é um Segundo Bezerra [12], as principais funcionalidades
conjunto de atividades que produz um produto de software [1]. disponibilizadas pelas ferramentas CASE são:
Além disso, esse processo é composto pelas seguintes atividades
básicas: especificação, desenvolvimento, validação e evolução [1]. • A criação e manutenção da consistência de diagramas UML;
Mais especificamente, a atividade de desenvolvimento é formada • A exportação do diagrama no formato XMI (XML Metadata
pelos estágios de projeto e implementação. Interchange), possibilitando a interoperabilidade entre
O estágio de projeto está relacionado com a modelagem de diferentes ferramentas CASE;
sistemas, que se caracteriza pela utilização de modelos para • Manutenção da consistência entre os modelos gerados;
representar uma visão ou perspectiva diferente do sistema a ser • Engenharia Round-Trip, que permite a interação entre a
ferramenta CASE e o código-fonte. Assim, é possível gerar
desenvolvido [1]. Segundo Bezerra [12], a modelagem auxilia a
código a partir dos modelos e vice-versa;
gerenciar a complexidade intrínseca ao desenvolvimento de
• Rastreamento de requisitos, que possibilita localizar os
sistemas de software, facilita a comunicação entre as pessoas artefatos gerados relacionados a um requisito de software.
envolvidas, reduz os custos de desenvolvimento e suporta a
previsão do comportamento futuro do sistema.
Adicionalmente, essas ferramentas podem possibilitar que o
Neste contexto, a Unified Modeling Language (UML) [2] tem
designer utilize um conjunto de símbolos equivalentes aos
sido a linguagem padrão para a modelagem de sistemas. Na sua
definidos na UML para a criação visual dos seus diagramas.
versão atual (2.5.1), a UML possui sete diagramas estruturais
Entretanto, outras ferramentas, como PlantUML e UMLet,
(classe, pacote, componente, perfil, estrutura composta, objeto e
utilizam notação textual para a definição dos diagramas UML.
implantação) e sete diagramas comportamentais (casos de uso,
Vale ressaltar que essas ferramentas podem ser proprietárias ou
atividade, estados e interação (sequência, comunicação, visão
open-source [3]. Uma ferramenta proprietária não permite o
geral de interação, temporização)). Por meio deles, é possível
acesso gratuito ao código, diferentemente das ferramentas open-
modelar as diferentes visões complementares de um sistema.
source. Conforme Garcia et al. [4], as ferramentas open-source
Dentre os diagramas que compõem a UML, os diagramas de
apresentam as seguintes vantagens: (i) são gratuitas para ser
casos de uso, de classe, de estado, de sequência e de atividade são
utilizadas, (ii) são flexíveis, (iii) proporcionam vantagens
os mais utilizados pelos engenheiros de software para representar
econômicas, (iv) permitem a liberdade de executar o programa e
um sistema [1]. A seguir, cada um desses diagramas é definido [2]:
analisar o seu funcionamento, (v) podem ser aprimoradas e
customizadas, (vi) permitem o acesso ao código-fonte, e (vii)
• Diagrama de casos de uso: Apresenta a interação entre os possuem pouca vulnerabilidade à invasão de vírus.
atores do sistema e suas funcionalidades (casos de uso); Dentre as ferramentas open-source para a modelagem de
• Diagrama de classes: Descreve a estrutura de classes que sistemas, pode-se citar: ArgoUML, StarUML, UMLet, DiaUML,
compõem o sistema;
BOUML, Violet, UML Designer, Modelio, NClass, Plantuml,
Umbrello, Open ModelSphere e Papyrus. As ferramentas
Analysis of Open-Source CASE Tools for Supporting Software
SBQS, October 17-19, 2018, Curitiba, Brazil
Modeling Process with UML
Enterprise Architect, Gliffy, Vision e Rational Rose são exemplos oito categorias, a saber: (i) baseados na norma ISO/IEC 9126
de CASE proprietárias. (NBR 13596), (ii) baseados em características de hardware e
software, (iii) baseados no repositório de dados, (iv) baseados na
2.3 Diretrizes para a Modelagem de Software documentação, (v) baseados no uso da ferramenta com relação ao
As diretrizes de modelagem de software auxiliam na boa computador utilizado, (vi) baseados na UML, (vii) baseado no
formação dos modelos utilizando a UML [11]. Assim, as fornecedor, e (viii) baseados nas necessidades identificadas com a
ferramentas CASE que apoiam a fase de modelagem deveriam utilização das ferramentas. Com o intuito de validar as diretrizes,
considerar essas diretrizes para interferir positivamente na as autoras elaboraram um estudo de caso contendo os diagramas
qualidade dos diagramas confeccionados [10]. de casos de uso, de classes, de sequência, de estado e de
Neste sentido, Ambler [11] definiu um conjunto de 308 atividades. Para tanto, foram consideradas as seguintes
diretrizes divididas em: (i) propósito geral, que podem ser ferramentas: Rational Rose C++ Demo, PowerDesigner 9.0,
aplicadas para a maioria dos diagramas UML, e (ii) um Together ControlCenter 6.1, AllFusion Component Modeler 4.1,
subconjunto para cada um dos treze diagramas da versão 2.0 da Enterprise Architect 3.51, Poseidon for UML Community Edition
linguagem. Como exemplo dessas diretrizes, pode-se citar: para o 1.6 e ArgoUML 0.14. Como resultados, foram apresentadas a
diagrama de classes, “deve-se sempre indicar a multiplicidade comparação entre as ferramentas e a validação das diretrizes
entre as classes”. propostas.
Além disso, Bezerra [12] também cita boas práticas de O trabalho de Oliveira, Souza e Figueiredo [6] analisou as
construção de diagrama UML à medida que explica sobre os ferramentas ArgoUML e Gliffy que possibilitam a modelagem
diagramas da versão 2.5. Para o diagrama de casos de uso, o autor UML via desktop e online, respectivamente. Para tanto, foi
define os relacionamentos possíveis entre as entidades que elaborado um experimento para analisar essas ferramentas em
compõem esse diagrama (veja a Tabela 1). Além disso, outras relação à usabilidade do ponto de vista dos alunos de graduação e
diretrizes são definidas para os demais diagramas da UML. pós-graduação da disciplina de Engenharia de Software
Experimental da Universidade Federal de Minas Gerais (UFMG).
Assim, foram considerados o tempo gasto para elaborar os
Tabela 1: Relacionamentos possíveis no diagrama de casos de diagramas, a quantidade de erros cometidos, o número de
uso [12] diagramas incompletos e a quantidade de vezes que os
pesquisadores foram consultados pelos participantes do
Caso de Uso e Ator e Ator Caso de Uso experimento. Como conclusões, a ferramenta Gliffy apresentou
Caso de Uso e Ator maior facilidade de uso, logo, possui melhor usabilidade que a
Comunicação X ferramenta ArgoUML.
Extensão X A pesquisa realizada por Costa, Werneck e Campos [7]
Inclusão X utilizou a norma brasileira NBR 13596 para avaliar as ferramentas
Generalização X X gratuitas Dia, ArgoUML, Umbrello e Jude. Assim, os critérios
utilizados seguiram as características da referida norma, a saber:
Vale ressaltar que a verificação das diretrizes pode ser feita
(i) funcionalidade, (ii) confiabilidade, (iii) usabilidade, (iv)
por meio de uma funcionalidade explícita na ferramenta e/ou por
eficiência, (v) manutenibilidade, e (vi) portabilidade. Como
meio de prevenção de erros. Por um lado, a primeira abordagem
resultados, os autores encontraram que a ferramenta Jude
possibilita que o usuário possa executar a verificação de modelos
apresentou melhor pontuação em relação à comparação com as
a qualquer momento. Por outro lado, a segunda abordagem não
outras ferramentas participantes da pesquisa.
permite que o erro de modelagem aconteça. Por exemplo, segundo
Os autores Silva, Alturas e Carneiro [3] analisaram as
a Tabela 1, um usuário não deveria conseguir vincular um ator a
ferramentas open-source ArgoUML e DiaUML e a ferramenta
outro ator por meio do relacionamento de inclusão em uma
proprietária Visio em relação aos aspectos de usabilidade. Para
ferramenta que utilizasse a segunda abordagem. tanto, os alunos do curso de pós-graduação em Informática
Aplicada à Organizações foram os sujeitos da pesquisa e
preencheram o questionário proposto pelos autores após a
3 Trabalhos Relacionados
utilização de um modelo elaborado para o estudo. Os resultados
Esta seção apresenta a análise dos trabalhos relacionados com a obtidos demonstraram que a ferramenta Visio apresentou
presente pesquisa. Para tanto, os trabalhos de Foresti e de Bortoli melhores resultados, pois os sujeitos da pesquisa tiveram maior
[5], Oliveira, Souza e Figueiredo [6], Costa, Werneck e Campos facilidade de aprendizado e maior produtividade.
[7], Silva, Alturas e Carneiro [3], Chupac, Mudron e Kana [8], Chupac, Mudron e Kana [8] analisaram quatorze ferramentas
Khaled [9] e Cunha, Costa e Parreira Junior [10] foram que suportam a modelagem dos diagramas UML e verificaram se
considerados por abordar a análise de ferramentas CASE para elas possuíam possibilidade de simulação de modelos, quais as
apoio às atividades da Engenharia de Software. versões da UML suportadas, quais os formatos para a exportação do
Foresti e de Bortoli [5] propuseram 57 diretrizes para analisar projeto e dos diagramas, dentre outros critérios. A ferramentas
ferramentas de apoio à UML. Essas diretrizes foram divididas em
SBQS, October 17-19, 2018, Curitiba, Brazil E. S. S. Freire et al.
analisadas foram: Visual Paradigm 8.3 (Enterprise Edition), utilizadas pelo presente trabalho também são as propostas por [11]
MagicDraw 17.0.1 (Enterprise Edition), StarUML 5.0, UModel em conjunto com as propostas por Bezerra [12].
2012 (Enterprise Edition), CaseComplete 2012, EnterpriseArchitect
9.2 (Corporate Edition), SketchUML, Bridgepoint 3.4.6,
PowerDesigner 16.1, Artisan Studio 7.3, Objecteering 6.1 4 Análise das Ferramentas Open-Source
(Enterprise Edition), Rational Software Architect 8.0, Blueprint Nesta seção, são detalhadas as diretrizes escolhidas para a análise
Software Modeler (Community Edition), e Innovator 11 for das ferramentas CASE open-source e a visão geral delas em
software architects. Considerando a pontuação atribuída a cada relação as suas funcionalidades. Adicionalmente, o resultado da
ferramenta, foi concluído que as ferramentas Enterprise Architect e análise dessas ferramentas é apresentado juntamente com as
Visual Paradigm contemplavam a maioria dos critérios utilizados. ameaças à validade desse estudo.
Dentre eles, pode-se citar o suporte (i) ao MDA (Model-driven
Architecture), (ii) à exportação de documentos, (iii) à engenharia 4.1 Escolha das Diretrizes e das Ferramentas
reversa e (iv) à geração de código-fonte. Inicialmente, foram escolhidas as diretrizes para a análise das
A pesquisa de Khaled [9] comparou as ferramentas Rational ferramentas considerando as utilizadas por Cunha, Costa e
Rose, ArgoUML, MagicDraw e Enterprise Architect considerando Parreira Junior [10]. Vale ressaltar que esses autores selecionaram
os seguintes critérios: (i) geração de documentação HTML, (ii) e utilizaram um subconjunto das diretrizes propostas por Ambler
suporte a todos os diagramas previstos nas versões 1.5 e 2.0 da [11]. Portanto, foram analisadas todas as diretrizes de [11] com o
UML, (iii) engenharia reversa, ou seja, transformação de modelos intuito de verificar quais as novas diretrizes poderiam ser
em código e vice-versa, (iv) integração com ferramentas de utilizadas no presente trabalho que não foram utilizadas por [10].
modelagem de dados, (v) exportação do diagrama para outros Consequentemente, algumas diretrizes foram incluídas e outras
formatos, e (vi) robustez, ou seja, prevenir que os usuários percam removidas. Essa análise foi realizada em conjunto pelos três
seu trabalho devido a um erro na ferramenta. Como resultados, os autores e o intuito foi identificar as diretrizes passíveis de
autores indicaram os pontos fortes de cada ferramenta. Por exemplo, verificação automática (independentes do designer).
a Rational Rose fornece suporte a todos os diagramas da UML. Um ponto importante a ser discutido é que as diretrizes de
Os autores Cunha, Costa e Parreira Junior [10] realizaram uma Ambler [11] definem boas práticas relacionadas em sua maioria
comparação entre as ferramentas Rational Software, MagicDraw, ao estilo de modelagem utilizando UML. Por exemplo, a
UModel, Visual Paradigma e Enterprise Architect em relação às superclasse deve ficar acima das subclasses no diagrama de
boas práticas de modelagem de software. Os critérios de classes. Assim, aspectos relacionados às normas de modelagem
comparação utilizados foram as diretrizes definidas por Ambler UML não são completamente contempladas. Por outro lado, as
[11]. Dessa análise, as ferramentas Rational Software e diretrizes de modelagem evidenciadas por Bezerra [12] se tornam
MagicDraw contemplaram a maior e a menor quantidade de complementares a de [11], pois retratam regras de relacionamento
diretrizes, respectivamente. Assim, os autores realizaram um entre os elementos dos diagramas e as informações mínimas para
estudo experimental considerando essas duas ferramentas e tendo representá-los.
como participantes, dez alunos do curso de Ciências da Neste sentido, o presente trabalho utilizou um subconjunto das
Computação da Universidade Federal de Goiás (UFG). Com isso, diretrizes de Ambler [11] e de Bezerra [12]. Essas diretrizes foram
foi atestado que a ferramenta pode interferir na qualidade dos escolhidas em conjunto pelos autores do presente trabalho e as
diagramas confeccionados, pois os alunos que utilizaram a divergências encontradas durante o processo de escolha foram
ferramenta Rational Software obtiveram melhores resultados. discutidas considerando o ponto de vista dos autores dessa
Em comparação com o presente trabalho, todos os trabalhos pesquisa e as divergências conceituais existentes nas diretrizes de
dessa seção analisaram ferramentas de apoio à modelagem de [11] e [12]. Um exemplo dessas divergências conceituais estava
software. Dentre eles, a pesquisa de [5] e [7] utilizaram a norma relacionado com a interação entre atores no diagrama de casos de
ISO/IEC 9126 (NBR 13596), para avaliar ferramentas, mas a uso. Ambler [11] afirmava que um ator não deveria interagir com
qualidade dos diagramas UML não foi o foco dessas pesquisas. outro ator, logo, não poderia haver nenhum relacionamento entre
Além disso, os trabalhos de Oliveira, Souza e Figueiredo [6] e atores. Essa diretriz foi desconsiderada, pois os atores podem se
Silva, Alturas e Carneiro [3] consideraram ferramentas open- relacionar por meio da herança, ou seja, um ator filho herda o
source na sua análise, porém foram analisados somente aspectos comportamento do ator pai. Essa possibilidade da UML foi
de usabilidade. Os trabalhos de [8] e [9] não contemplaram mapeada por [12].
nenhuma diretriz relacionada com a qualidade de modelos UML, A Tabela 2 apresenta as 40 diretrizes utilizadas pelo presente
pois consideraram apenas as funcionalidades que cada ferramenta trabalho para a avaliação e a comparação das ferramentas open-
analisada disponibilizava. Entretanto, o trabalho de Cunha, Costa source. Por meio dela, é possível identificar as diretrizes por diagrama
e Parreira Junior [10] se aproximam mais do presente trabalho e por autor. Além disso, um identificador para cada diretriz também
pois consideram diretrizes para analisar a qualidade dos modelos foi incluído. Vale salientar que foram utilizadas 22 diretrizes de
UML, porém o foco desses autores [10] foram ferramentas Ambler e 18 de Bezerra.
proprietárias, diferenciando-se do escopo do presente trabalho que As diretrizes contemplam os cinco diagramas mais utilizados
utiliza ferramentas open-source. Vale ressaltar que as diretrizes da UML conforme [1], a saber: diagrama de casos de uso, de
Analysis of Open-Source CASE Tools for Supporting Software
SBQS, October 17-19, 2018, Curitiba, Brazil
Modeling Process with UML
Diagrama de Atividades
de [12] contemplam a versão 2.5. Essa diferença de versões 29 Garantir que um "fork" tenha somente uma
também foi considerada na escolha das diretrizes. Logo, o [11] entrada.
presente trabalho considerou a versão mais atual da UML (2.5). 30 Garantir que um "join" tenha somente uma
saída.
31 Evitar usar mais do que 5 “Swim Lanes”.
Tabela 2: Diretrizes utilizadas na avaliação 32 Garantir que cada caminho de um ponto de
decisão tenha uma guarda.
[12]
Autor # Diretriz 33 Garantir que uma atividade esteja relacionada
1 Associar cada ator com pelo menos um caso a outro elemento do diagrama.
[11] de uso. 34 Criar um estado inicial.
35 Indicar a ação de entrada.
Diagrama de Estados
2 Usar «System» para indicar um ator sistema.
3 Não permitir que atores sejam relacionados [11] 36 Colocar nomes de transição no passado.
Diagrama de Casos de Uso
mensagens.
[11] 21 Evitar usar boxes de ativação durante a Os dois alunos tinham cursado a disciplina de Engenharia de
execução do diagrama. Software e tinham estudado sobre os diagramas abordados na
22 Evitar criar objetos durante a execução do pesquisa.
diagrama. Além disso, foi elaborado um caso de teste para cada uma das
23 Evitar descrever o tipo dos parâmetros de diretrizes apresentadas na Tabela 2. Cada caso de teste contradizia
entrada. uma dessas diretrizes. Por exemplo, a diretriz #3 indica que “Não
24 Permitir mensagens reflexivas. permitir que atores sejam relacionados por «include»”. Assim, o
25 Garantir que o operador "alt" possua pelo
[12] menos dois operandos. 1
https://www.predictiveanalyticstoday.com/open-source-free-unified-modeling-language-
26 Garantir que o operador "opt" possua apenas uml-tools/
um operando.
SBQS, October 17-19, 2018, Curitiba, Brazil E. S. S. Freire et al.
caso de teste referente a essa diretriz especificava que dois ou • C3: Verificação da consistência entre os modelos
mais atores estavam associados pelo relacionamento «include». gerados,
Em seguida, os casos de testes foram confrontados com as • C4: Engenharia Round-Trip, e
ferramentas supracitadas com o intuito de identificar quais as • C5: Rastreamento de requisitos.
diretrizes contempladas. Além disso, buscou-se também Vale ressaltar que para o critério C1, foram consideradas as
identificar se as ferramentas evitavam a modelagem incorreta dos seguintes opções: (i) visual, relacionada com o uso de elementos
diagramas e/ou alertavam aos usuários sobre os erros de gráficos, e (ii) textual, relacionada com a utilização de linguagem
modelagem. textual para definir os elementos do diagrama e seus
relacionamentos. Além disso, para o critério C4, as opções
possíveis eram: (i) direta (D), que possibilita a geração de código-
Tabela 3: Versão das ferramentas open-source analisadas
fonte a partir de diagramas, e (ii) reversa (R), que corresponde a
geração de diagramas a partir de um código-fonte.
Ferramentas Versão Link de Acesso
ArgoUML 0.34 http://argouml.tigris.org//
StarUML 5.0.2.157 http://staruml.sourceforge.net/ Tabela 4: Características das ferramentas
0 v1/download.php
UMLet 14.2 http://www.umlet.com/ Ferramentas C1 C2 C3 C4 C5
Dia 0.97.2 http://dia-http://dia- ArgoUML Visual Sim Sim D/R Não
installer.de/index.html StarUML Visual Sim Sim D/R Não
BOUML 7.6 https://www.bouml.fr/downloa Visual/
UMLet Não Não D Não
d.html Textual
Violet 2.1.0 https://sourceforge.net/projects Dia Visual Não Não D Não
/violet/files/latest/download?so BOUML Visual Sim Não D/R Não
urce=files Violet Visual Não Não Não Não
UML Designer 8.1 http://www.umldesigner.org/d UML Designer Visual Não Sim Não Não
ownload/ Modelio Visual Sim Sim Não Não
Modelio 3.7.1 https://www.modelio.org/dow NClass Visual Não Não D Não
nloads/download- Plantuml Textual Não Não Não Não
modelio.html Umbrello Visual Não Não D/R Não
NClass 2.04 http://nclass.sourceforge.net/d Open ModelSphere Visual Sim Sim D Não
ownloads.html Papyrus Visual Não Sim D/R Não
Plantuml 1.2018.8 http://plantuml.com/download
Umbrello 2.25 https://umbrello.kde.org/ Assim, é possível perceber que nenhuma das ferramentas
Open 3.2.2 http://www.modelsphere.com/ analisadas possibilitam o rastreamento de requisitos. Em outras
ModelSphere org/download.html palavras, as ferramentas não dão suporte à vinculação e à
Papyrus 4.0.0 https://www.eclipse.org/papyr identificação dos relacionamentos de dependência entre os
us/download.html#accordion requisitos e os artefatos de modelagem. Além disso, apenas as
ferramentas UMLet e Plantuml possibilitam a confecção de
É importante ressaltar que não foi utilizado o mesmo contexto diagramas via linguagem natural. É importante salientar que os
para a verificação de cada diretriz, pois a análise estava diagramas de sequência e de atividades são confeccionados em
relacionada à sintaxe e à organização do diagrama e não aos linguagem textual na ferramenta UMLet, enquanto as demais são
aspectos de negócio de um contexto específico. Por isso, cada modelados em linguagem visual. Entretanto, em Plantuml,
caso de teste retratou uma diretriz. Por exemplo, a diretriz #1 nenhum diagrama é confeccionado utilizando elementos gráficos
afirmava que “Associar cada ator com um ou mais casos de uso”. diretamente na ferramenta.
Logo, foi modelado um ator que não estava associado a um caso Em relação à exportação dos diagramas no formato XMI,
de uso, independente desse ator ser um Aluno ou um Cliente. O apenas cinco ferramentas apresentaram essa funcionalidade,
importante era verificar se a ferramenta conseguia detectar a permitindo a interoperabilidade entre ferramentas. Essa mesma
ausência do relacionamento como um erro de modelagem. quantidade de ferramentas possibilita a transformação de
A Tabela 4 apresenta uma síntese das principais características diagramas em código e vice-versa. Sobre a consistência de
e funcionalidades de cada uma das ferramentas analisadas. Foram modelos, apenas seis ferramentas permitem a checagem das regras
utilizados os critérios definidos por Bezerra [12] explicados na de modelagem por meio da funcionalidade de verificação explícita
subseção 2.2. Além disso, foram utilizados os seguintes de modelos. Vale ressaltar que para o presente estudo, essa
identificadores para cada um desses critérios: funcionalidade é decisiva para verificar se as diretrizes
• C1: Criação de diagramas UML, apresentadas na Tabela 2 são contempladas em cada ferramenta.
• C2: Exportação do diagrama no formato XMI, Além disso, torna-se complementar à abordagem de prevenção de
Analysis of Open-Source CASE Tools for Supporting Software
SBQS, October 17-19, 2018, Curitiba, Brazil
Modeling Process with UML
erros. A Figura 1 apresenta o item de menu de cada ferramenta 4.3 Análise das Ferramentas considerando as
para a verificação de modelos. Diretrizes de Modelagem
Considerando as diretrizes apresentadas na Tabela 2, foi realizada
ArgoUML StarUML
a análise das ferramentas CASE descritas na subseção 4.2. A
Tabela 5 mostra o resultado da análise realizada. Assim, é
possível identificar quais as diretrizes que são contempladas por
cada ferramenta.
[...]
Tabela 5: Resultado da Análise das Ferramentas Open-Source
A maioria dessas diretrizes auxilia na organização do diagrama, diagrama de casos de uso. Pode-se notar que a ferramenta UML
aumentando o entendimento do engenheiro de Software. Por outro Designer cumpre com oito das nove diretrizes consideradas para
lado, a diretrizes #16, #32 e #39 estão relacionadas à sintaxe da esse diagrama, representando quase 90% de conformidade. Além
UML, ou seja, impactam diretamente na qualidade da modelagem. disso, as ferramentas ArgoUML, StarUML, BOUML, Modelio e
Papyrus seguem sete diretrizes.
5 Considerações Finais
O presente artigo utilizou as diretrizes de Ambler [11] e Bezerra
[12] com o intuito de analisar e comparar as ferramentas CASE
Figura 5: Diretrizes do diagrama de sequência
open-source em relação às boas práticas de modelagem de
software utilizando UML. Ao implementar essas diretrizes como
regras de validação nas ferramentas, proporciona-se uma maneira
de criar modelos mais corretos. Por meio do estudo experimental
de [10], foi possível constatar essa relação entre a interferência da
ferramenta na qualidade dos diagramas confeccionados.
A maioria das diretrizes de Ambler [11] foca no estilo de
modelagem e no posicionamento dos elementos, facilitando o
entendimento dos diagramas. As de Bezerra [12] abordam a
estrutura dos elementos da UML e os possíveis relacionamentos
entre eles. Assim, as diretrizes escolhidas permitem evitar que
erros relacionados à sintaxe da UML ocorram e possibilitam uma
melhor organização do diagrama. Vale salientar que a pesquisa
não buscou pela existência de outras diretrizes. Essa busca poderia
ser uma sugestão de trabalhos futuros, pois poderia refinar o
Figura 6: Diretrizes do diagrama de atividade conjunto de diretrizes utilizado.
Como resultado principal, as ferramentas StarUML e UML
4.4 Ameaças à Validade Designer conseguiram atender ao maior número das 40 diretrizes
utilizadas nesse estudo. Houve um empate entre StarUML e UML
As ameaças à validade são influências que podem limitar a Designer, porém o critério de desempate sugerido pode ser o
interpretação ou a conclusão dos dados coletados por um maior número de características apresentadas na Tabela 4 sendo
experimento [13]. As ameaças identificadas no presente trabalho que, StarUML, diferentemente de UML Designer, dá suporte a
foram analisadas conforme a taxonomia definida por [13]: exportação de diagramas no formato XMI e a engenharia Round-
validade de construção, validade interna e validade externa. Trip tanto direta quanto reversa. Além disso, os diagramas de
Em relação à minimização da ameaça à validade de casos de uso e de sequência foram os que obtiveram o maior
construção, além das diretrizes propostas por [11], também foram número de diretrizes atendidas pelas treze ferramentas analisadas.
consideradas as boas práticas definidas por [12]. Com isso, Por meio da pesquisa, foi possível verificar que (i) Dia e
aumentou-se a quantidade de diretrizes utilizadas para a análise e UMLet não apresentavam áreas de trabalho específicas por
a comparação das ferramentas CASE. Vale ressaltar que diagrama; (ii) a falta da verificação automática de modelo, na
divergências entre as diretrizes foram discutidas pelos autores do maioria das ferramentas, torna a modelagem mais suscetível a
presente trabalho com o intuito de removê-las e manter a erros; (iii) a ferramenta NClass, mesmo possibilitando apenas a
coerências entre as mesmas. Além disso, o processo de escolha de modelagem de diagramas de classe, apresentou um desempenho
ferramentas considerou as ferramentas citadas nos trabalhos igual ou inferior às demais ferramentas para o referido diagrama;
relacionados (veja a Seção 3), além de consultar sites e blogs que (iv) a sintaxe de modelagem textual da UMLet e Pantuml é de
abordavam ferramentas CASE para modelagem de sistemas fácil compreensão e exemplos são encontrados no site delas; (v) o
utilizando a UML. processo de instalação da Open ModelSphere precisa ser
Para a ameaça à validade interna, a análise das ferramentas foi atualizado (ocorreram problemas para a instalação, mas foram
realizada pelos autores paralelo e separadamente. Assim, as superados); e (vi) algumas ferramentas não são tão intuitivas (foi
divergências encontradas foram discutidas e resolvidas. Além necessário procurar por informações no site delas para entender o
disso, as dúvidas referentes às funcionalidades suportadas por funcionamento).
cada ferramenta foram analisadas nos manuais de utilização e nos
SBQS, October 17-19, 2018, Curitiba, Brazil E. S. S. Freire et al.
Além disso, as ferramentas precisam ser evoluídas para prover [11] Scott W. Ambler. 2003. The Elements of UML Style. São Paulo: Cambridge
University Press, 2003. 146p.
maior suporte às diretrizes utilizadas nesse estudo. Mais
[12] Eduardo Bezerra. 2015. Princípios de Análise e Projetos de Sistemas com
especificamente, os diagramas de atividade e de estado precisam UML. Rio de Janeiro: Elsevier, 3ª ed., 2015. 416p.
de uma atenção maior, pois as ferramentas cumprem com um [13] D. E. Perry, A. A. Porter e L. G. Votta. 2000. Empirical studies of software
percentual baixo de conformidade. engineering: A roadmap. In Proceedings of the 22nd International Conference
Como lições aprendidas desse estudo, pode-se destacar: (i) on Software Engineering, pages: 345–355
AGRADECIMENTOS
Os autores agradecem aos revisores do Simpósio Brasileiro de
Qualidade de Software (SBQS) pelos comentários que
engrandeceram o presente artigo.
REFERÊNCIAS
[1] Ian Sommerville. 2011. Engenharia de Software. São Paulo: Pearson Prentice
Hall, 9ª ed., 2011. 544 p.
[2] Object Management Group. 2017. Disponível em:
https://www.omg.org/spec/UML/. Acesso em fev/2018.
[3] I. Silva, B. Alturas e A. Carneiro. 2017. Ferramentas de modelação UML:
avaliação na perspetiva dos utilizadores. In Álvaro Rocha, Bráulio Alturas,
Carlos J. Costa, Luís Paulo Reis e Manuel Pérez Cota (Ed.), 12th Iberian
Conference on Information Systems and Technologies (CISTI). (pp. 2262-
2267). Lisboa: IEEE.
[4] M. N. Garcia, S. M. B. Santos, R. S. Pereira e G. B. Rossi. 2010. Software
livre em relação ao software proprietário: Aspectos favoráveis e desfavoráveis
percebidos por especialistas. In Gestão & Regionalidade 26, 78 (Set. 2010),
106 – 120.
[5] J. Foresti e L. A. de Bortoli. 2004. Ferramentas de apoio a UML: um modelo
para avaliação baseado em requisitos funcionais e não-funcionais.
INFOCOMP 4, 1 (Mar. 2004), 62-69.
[6] J. Oliveira, P. Souza e E. Figueiredo. 2014. Uma avaliação de ferramentas de
modelagem de software. In Anais do I Simpósio Mineiro de Engenharia de
Software (SMES2014), Belo Horizonte, 109-118.
[7] A. N. Costa, V. M. B. Werneck e M. F. Campos. 2008. Avaliação de
ferramentas para desenvolvimento orientado a objetos com UML. Cadernos
do IME: Série Informática 25 (Jul. 2008).
[8] L. Chupac, I. Mudron e K. Kana. 2013. Comparison of UML tools. SGEM
GeoConference on Informatics, Geoinformatics And Remote Sensing
Proceedings 1, (Jun. 2013), 23-28.
[9] Lena Khaled. 2009. A comparison between UML tools. In Second
International Conference on Environmental and Computer Science (ICECS
2009), Dubai, 111-114.
[10] W. S. Cunha, H. Costa e P. A. Parreira Júnior. 2016. Análise de ferramentas
CASE quanto às boas práticas de modelagem de software com UML. In XV
Simpósio Brasileiro de Qualidade de Software (SBQS 2016), Maceió, 51-63.