<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Meriéli Manzano</title>
    <description>The latest articles on DEV Community by Meriéli Manzano (@merielimanzano).</description>
    <link>https://dev.to/merielimanzano</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F905006%2F316782d1-6d03-4008-96f9-1237725a719e.jpg</url>
      <title>DEV Community: Meriéli Manzano</title>
      <link>https://dev.to/merielimanzano</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/merielimanzano"/>
    <language>en</language>
    <item>
      <title>Facades no Laravel entregam velocidade, mas cobram o preço em acoplamento</title>
      <dc:creator>Meriéli Manzano</dc:creator>
      <pubDate>Thu, 14 May 2026 15:15:00 +0000</pubDate>
      <link>https://dev.to/merielimanzano/facades-sao-o-cafe-do-laravel-resolvem-rapido-mas-viciam-e-escondem-o-problema-1o8c</link>
      <guid>https://dev.to/merielimanzano/facades-sao-o-cafe-do-laravel-resolvem-rapido-mas-viciam-e-escondem-o-problema-1o8c</guid>
      <description>&lt;p&gt;As Facades do Laravel são algo que o framework disponibiliza e que vejo muitos projetos usando em controllers, services, entities e até mesmo em repositories. Eu pessoalmente já usei e ainda uso Facade, a produtividade inicial é maravilhosa, o código fica enxuto e você entrega valor rápido porque não precisa instanciar, é só usar a Facade direto, é lindo.&lt;/p&gt;

&lt;p&gt;Só que tenho refletido sobre uma coisa que não aparece no curto prazo, especialmente quando a aplicação cresce e a manutenção se estende por anos.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Pense num cenário real:&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;Você tem uma classe de serviço que usa várias outras Facades internas. Funciona perfeitamente bem, até o dia que você precisar reaproveitar aquela lógica num script isolado fora do Laravel. Ou testar aquela classe sem o framework inteiro carregado.&lt;/p&gt;

&lt;p&gt;Aí você percebe: a classe não diz o que ela precisa. Você só descobre abrindo o código linha por linha. E cada facade é um fio invisível conectado ao Laravel.&lt;/p&gt;

&lt;p&gt;Não é que Facade seja errada. É que elas resolvem um problema (velocidade) e criam outro silencioso (acoplamento implícito). Cada time escolhe seu trade-off. Esse acoplamento forte com o framework vai justamente contra as regras de dependência da Clean Architecture.&lt;/p&gt;

&lt;p&gt;Para entender por que, precisamos saber que Facades do Laravel funcionam como “proxies estáticos” que fornecem acesso a objetos registrados no service container. São uma “ponte” entre uma chamada de método estático e a instância real de um objeto, resolvido em tempo de execução pelo container de injeção de dependência do Laravel.&lt;/p&gt;

&lt;p&gt;Abaixo separei algumas vantagens e desvantagens que vai te ajudar a decidir quando realmente devemos usá-las.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Vantagens:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Código mais rápido de escrever e mais fácil de ler, acelerando drasticamente o desenvolvimento e a prototipagem.&lt;/li&gt;
&lt;li&gt;Facilidade para testar usando &lt;code&gt;shouldReceive()&lt;/code&gt; e Fakes para garantir que a lógica real não seja acionada, diferente de métodos estáticos tradicionais. &lt;em&gt;“Obs: Mas já que a IA está criando testes com maestria, será que isso faz realmente a diferença?”&lt;/em&gt;
&lt;/li&gt;
&lt;li&gt;Tem comportamento Singleton, sendo resolvida uma única vez por requisição.&lt;/li&gt;
&lt;li&gt;Pode ser usada em qualquer lugar, sem a necessidade de passar dependência manualmente pelo construtor.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;strong&gt;Desvantagens:&lt;/strong&gt;&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Acoplamento que não quebra a testabilidade, mas suja as dependências “ou seja, não é declarada a dependência, ela fica implícita e só é descoberta olhando o corpo dos métodos”. O que dificulta manutenção e reuso.&lt;/li&gt;
&lt;li&gt;Viola a Inversão de Dependência, a classe depende diretamente de uma implementação concreta ou de uma interface resolvida pela Facade, não de uma abstração definida pelo domínio, injetada de fora.&lt;/li&gt;
&lt;li&gt;Lógica acoplada ao Framework, porque Facades só funcionam com o Facade Root inicializado. Se um dia pretender reutilizar aquela classe em um script isolado, pacote PHP puro ou outro framework, precisará reescrever tudo.&lt;/li&gt;
&lt;li&gt;Por serem muito convenientes, facilitam a violação silenciosa do SRP: desenvolvedores adicionam novas responsabilidades indiretas sem que o construtor da classe sinalize o inchaço.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Deixo mais dois pontos de atenção que não são necessariamente desvantagens, mas devem ser conhecidos:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Embora sejam testáveis, os mocks são aplicados globalmente – afetam todas as chamadas à facade durante o teste, não apenas uma instância específica. Sem uma limpeza explícita (como &lt;code&gt;clearResolvedInstances()&lt;/code&gt; no &lt;code&gt;tearDown&lt;/code&gt;), pode haver vazamento de comportamento entre testes. É um ponto de atenção, mas contornável.&lt;/li&gt;
&lt;li&gt;A facade não é mais rápida que a injeção direta. Cada chamada paga o custo do &lt;code&gt;__callStatic()&lt;/code&gt; e da resolução da chave no container – é tecnicamente mais lenta, mas na prática você nunca vai medir essa diferença.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Facades são ótimas em Controllers, Commands, Jobs (camadas mais próximas da infra). E podem até ser usadas em protótipos e MVPs, são uma excelente escolha para garantir velocidade de entrega.&lt;/p&gt;

&lt;p&gt;Já nas camadas de domínio, serviços de aplicação, objetos de valor, entidades... faz mais sentido injetar uma interface no construtor para desacoplar sua lógica de negócio.&lt;/p&gt;

&lt;p&gt;Tá tudo bem usar Facades. Esse post não é uma regra. É só uma lente que eu peguei dos meus estudos e que, de vez em quando, me faz perguntar: “será que aqui vale a pena declarar a dependência?”&lt;/p&gt;

&lt;p&gt;Fico curiosa pra saber como vocês lidam com isso. Já sentiu alguma dificuldade prática com Facades para testar, evoluir ou reaproveitar lógica? Ou acham que eliminar Facades do Laravel da camada de negócio é uma sofisticação desnecessária?&lt;/p&gt;

</description>
      <category>laravel</category>
      <category>php</category>
      <category>cleancode</category>
    </item>
    <item>
      <title>Produtividade com Testes e Vue usando VSCode</title>
      <dc:creator>Meriéli Manzano</dc:creator>
      <pubDate>Mon, 26 Sep 2022 14:18:02 +0000</pubDate>
      <link>https://dev.to/merielimanzano/produtividade-com-testes-e-vue-usando-vscode-593k</link>
      <guid>https://dev.to/merielimanzano/produtividade-com-testes-e-vue-usando-vscode-593k</guid>
      <description>&lt;p&gt;Criar testes bem organizados, separados e com uma boa descrição no Jest ou inserir toda estrutura inicial padrão de um componente Vue, pode ser verboso. Mas configurando o VS Code é possível inserir automaticamente toda pré-estrutura com a escrita de apenas uma palavra.&lt;/p&gt;

&lt;p&gt;Desenvolvendo com o Visual Studio Code você pode turbinar sua produtividade de uma forma muito simples com &lt;strong&gt;Snippets&lt;/strong&gt;!&lt;/p&gt;

&lt;h2&gt;
  
  
  Como funciona?
&lt;/h2&gt;

&lt;p&gt;Os snippets salvos no seu VS Code geram códigos pré-definidos ao digitar uma determinada palavra escolhida na sua configuração.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--qnaXCVYD--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_66%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zlv2019kffldwilqcq87.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--qnaXCVYD--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_66%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/zlv2019kffldwilqcq87.gif" alt="Image description" width="695" height="172"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  Como criar um snippet
&lt;/h2&gt;

&lt;p&gt;Com o VS Code aberto vá em &lt;strong&gt;File&lt;/strong&gt; -&amp;gt; &lt;strong&gt;Preferences&lt;/strong&gt; -&amp;gt; &lt;strong&gt;Configure User Snippets&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;Na paleta de comandos aberta digite a linguagem para qual deseja exibir o snippet, no caso de testes Jest digite &lt;strong&gt;typescript&lt;/strong&gt; se for sua linguagem utilizada.&lt;/p&gt;

&lt;p&gt;Será aberto um arquivo typescript.json com instruções para criar seu snippet.&lt;/p&gt;

&lt;p&gt;Cada snippet tem a seguinte estrutura:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="nl"&gt;"Nome do Snippet"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="nl"&gt;"prefix"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;//&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;Palavra&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;que&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;chama&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;o&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;snippet&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="nl"&gt;"body"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="w"&gt;
            &lt;/span&gt;&lt;span class="err"&gt;//&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;Corpo&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;com&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;o&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;código&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;a&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;ser&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;gerado&lt;/span&gt;&lt;span class="w"&gt;         
        &lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt;&lt;span class="w"&gt;
        &lt;/span&gt;&lt;span class="nl"&gt;"description"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;//&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;Descrição&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;com&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;detalhes&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;do&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="err"&gt;código&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="err"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Ao escrever o body, em linhas que houver indentação use &lt;strong&gt;&lt;code&gt;\t&lt;/code&gt;&lt;/strong&gt; para aplicar a tabulação necessária. Cada &lt;code&gt;\t&lt;/code&gt; representa um Tab.&lt;/p&gt;

&lt;p&gt;Para indicar as pausas do Tab para digitação de texto pelo código use &lt;strong&gt;&lt;code&gt;$1&lt;/code&gt;&lt;/strong&gt;, substituindo o número pela ordem de inserção desejada em cada trecho.&lt;/p&gt;

&lt;p&gt;Também é possível indicar o tipo de conteúdo a ser inserido em cada pausa com &lt;strong&gt;&lt;code&gt;${1:conteudo}&lt;/code&gt;&lt;/strong&gt; dando uma ideia do que escrever. E para definir um texto igual a ser usado em várias partes do código use o mesmo número de ID em todas partes que o texto for repetir.&lt;/p&gt;

&lt;p&gt;Abaixo montei um snippet completo para Jest usando BDD que você pode aproveitar nos seus códigos ou adaptar como preferir:&lt;/p&gt;


&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;



&lt;p&gt;O snippet de Vue é para uso com composition Api usando Typescript e Sass scoped, mas você pode adaptar como preferir:&lt;/p&gt;


&lt;div class="ltag_gist-liquid-tag"&gt;
  
&lt;/div&gt;


&lt;p&gt;O artigo é para produtividade com Testes e Vue, mas também é possível criar snippets para outras linguagens. &lt;/p&gt;

&lt;p&gt;Espero ter ajudado! 😊&lt;/p&gt;

</description>
      <category>typescript</category>
      <category>braziliandevs</category>
      <category>vue</category>
      <category>testing</category>
    </item>
  </channel>
</rss>
