Avalie os impactos das “concessões” realizadas ao utilizar frameworks e boilerplates

Thiago Candido

Frequentemente, o negócio demanda o desenvolvimento de uma feature em prazos desafiadores. Para atender essa demanda, é comum que times de tecnologia recorram a frameworks e ferramentas que aceleram o desenvolvimento ou, até mesmo, implementações de referência. Entretanto, essas escolhas frequentemente representam aumento no custo da manutenção.

Há muitas soluções que prometem auxiliar o desenvolvimento, trazendo praticidade e velocidade de desenvolvimento para o time. Alguns exemplos são frameworks MVC/MVT, projetos boilerplate, e bibliotecas que possuem integração ao banco de dados e disponibilizam, inclusive, dashboards de administração. Entretanto, não raro, componentes assim, se transformam em pontos negativos – verdadeiras dívidas técnicas – na medida que os sistemas crescem e se tornam complexos.

Ao adotar soluções assim, deve-se tomar cuidado com padrões, convenções e práticas de escrita de código suportados por elas. Não são raros os casos em que essas premissas de utilização de um determinado framework, implementadas inicialmente, acabam definindo a arquitetura e o design de sistemas, de maneira não proposital. O mesmo problema acontece quando utilizamos um projeto de referência como ponto de partida para nossas aplicações. Esses projetos servem como “implementações” de arquiteturas que, não raro, se afastam muito do problema que precisamos resolver.

Não há sentido em utilizar implementações e arquiteturas de referência genéricas a menos que a solução que está sendo desenvolvida seja genérica.

Com o crescimento da complexidade das aplicações, funcionalidades oferecidas por componentes que “botam o projeto no ar em 10 minutos” podem não atender, de maneira adequada, os casos que inicialmente apresentavam um ótimo fit. Com frequência, essas “saídas fáceis” continuam custando caro aos negócios, influenciando negativamente nos lead times.

As “concessões” realizadas para utilizar um certo framework ou referência podem dificultar a escrita de código coeso e de testes, além de promover acomplamento entre componentes do sistema e, eventualmente, podem prejudicar na compreensão da base de código, por conter seções de oxbow code, devido a falta de segurança da equipe em remover esses trechos.

Oxbow code

Oxbow code refere-se a trechos de código que antes eram necessários mas que não são mais utilizados. Esse código geralmente é criado quando quando uma funcionalidade é substituída por uma implementação mais atual, uma chamada a alguma biblioteca ou por uma chamada a um serviço externo, mas o código antigo não é removido.

O processo de elaboração de design e arquitetura das aplicações deve levar em consideração essas pequenas “concessões” realizadas para a utilização de frameworks.

Trabalhar de maneira sensível, determinando técnicas e padrões que conciliem a utilização de frameworks, sem abrir mão do uso do uso de boas práticas de desenvolvimento, é ato fundamentalCaso contrário, a capacidade de entrega poderá ser influenciada de maneira negativa, destruindo toda vantagem obtida no início dos trabalhos.

Em resumo

O problema
Frameworks e boilerplates muitas vezes trazem consigo módulos que auxiliam na praticidade e aumentam a velocidade de desenvolvimento. Para utilizar esses componentes, muitas vezes o código da aplicação deve seguir algum tipo de padrão de design. Essas “concessões”, se realizadas de maneira desatenta, podem trazer um custo alto para o negócio a medida em que o sistema fica mais complexo.
O insight
Independentemente de optar por usar, ou não, um framework, biblioteca ou boilerplate para auxiliar no desenvolvimento de sistemas, boas práticas de arquitetura e design não devem ser deixadas de lado, para que o crescimento da aplicação seja realizado de maneira escalável para o negócio.

Compartilhe este insight:

Comentários

Participe deixando seu comentário sobre este artigo a seguir:

Subscribe
Notify of
guest
0 Comentários
Inline Feedbacks
View all comments

AUTOR

Thiago Candido
Especialista em inteligência artificial e engenharia de dados com experiência profissional na indústria e setor financeiro

NOVOS HORIZONTES PARA O SEU NEGÓCIO

Nosso time está preparado para superar junto com você grandes desafios tecnológicos.

Entre em contato e vamos juntos utilizar a tecnologia do jeito certo para gerar mais resultados.

Insights EximiaCo

Confira os conteúdos de negócios e tecnologia desenvolvidos pelos nossos consultores:

Arquitetura de Dados

Insights de um DBA na análise de um plano de execução

Especialista em performance de Bancos de Dados de larga escala
Arquitetura de Software

Estratégias para modernização do legado

Desenvolvedor .NET/NodeJs e especialista em Kafka com experiência em startups e grandes empresas
Infraestrutura e Nuvem

Migração para a nuvem, mais do que mudança tecnológica, implica em mudança da cultura organizacional

Engenheiro de nuvem, arquiteto de software e especialista em Containers e Devops

Acesse nossos canais

Simplificamos, potencializamos e aceleramos resultados usando a tecnologia do jeito certo

EximiaCo 2022 – Todos os direitos reservados

0
Queremos saber a sua opinião, deixe seu comentáriox
()
x

Avalie os impactos das “concessões” realizadas ao utilizar frameworks e boilerplates

Para se candidatar nesta turma aberta, preencha o formulário a seguir:

Condição especial de pré-venda: R$ 14.000,00 - contratando a mentoria até até 31/01/2023 e R$ 15.000,00 - contratando a mentoria a partir de 01/02/2023, em até 12x com taxas.

Tenho interesse nessa capacitação

Para solicitar mais informações sobre essa capacitação para a sua empresa, preencha o formulário a seguir:

Tenho interesse em conversar

Se você está querendo gerar resultados através da tecnologia, preencha este formulário que um de nossos consultores entrará em contato com você:

O seu insight foi excluído com sucesso!

O seu insight foi excluído e não está mais disponível.

O seu insight foi salvo com sucesso!

Ele está na fila de espera, aguardando ser revisado para ter sua publicação programada.

Tenho interesse em conversar

Se você está querendo gerar resultados através da tecnologia, preencha este formulário que um de nossos consultores entrará em contato com você:

Tenho interesse nessa solução

Se você está procurando este tipo de solução para o seu negócio, preencha este formulário que um de nossos consultores entrará em contato com você:

Tenho interesse neste serviço

Se você está procurando este tipo de solução para o seu negócio, preencha este formulário que um de nossos consultores entrará em contato com você:

× Precisa de ajuda?