<?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: Leonardo Gobatto</title>
    <description>The latest articles on DEV Community by Leonardo Gobatto (@leonardo_gobatto_f5b4ec9b).</description>
    <link>https://dev.to/leonardo_gobatto_f5b4ec9b</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%2F2983859%2F593eea00-928a-49f8-bcfb-dd43f16d5ea4.png</url>
      <title>DEV Community: Leonardo Gobatto</title>
      <link>https://dev.to/leonardo_gobatto_f5b4ec9b</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/leonardo_gobatto_f5b4ec9b"/>
    <language>en</language>
    <item>
      <title>Rodando GitHub Actions na raça (sem push)</title>
      <dc:creator>Leonardo Gobatto</dc:creator>
      <pubDate>Fri, 28 Mar 2025 00:57:01 +0000</pubDate>
      <link>https://dev.to/leonardo_gobatto_f5b4ec9b/rodando-github-actions-na-raca-sem-push-1pj5</link>
      <guid>https://dev.to/leonardo_gobatto_f5b4ec9b/rodando-github-actions-na-raca-sem-push-1pj5</guid>
      <description>&lt;p&gt;&lt;strong&gt;“Dá pra rodar a action sem fazer push? Tipo… direto do terminal?&lt;/strong&gt;”&lt;/p&gt;

&lt;p&gt;Essa foi a pergunta que me acendeu uma luz. Era um dia comum, mais um deploy de rotina, e lá estava eu empilhando commits desnecessários no Git só pra testar uma mudança no workflow.&lt;/p&gt;

&lt;p&gt;Aquela sensação de que devia ter um jeito melhor, mais rápido, mais limpo. E adivinha? Tinha mesmo.&lt;/p&gt;

&lt;p&gt;Foi assim que comecei a explorar um mundo novo com o &lt;code&gt;gh&lt;/code&gt; — o CLI oficial do GitHub. Neste artigo, vou te mostrar como essa simples ferramenta me salvou tempo, organizou meus fluxos de trabalho e ainda deu aquele ar de maturidade no CI/CD da equipe.&lt;/p&gt;

&lt;p&gt;Se você curte dominar suas ferramentas, vem comigo.&lt;/p&gt;




&lt;h2&gt;
  
  
  Conhecendo o &lt;code&gt;gh&lt;/code&gt; – o CLI oficial do GitHub
&lt;/h2&gt;

&lt;p&gt;Se você nunca usou o &lt;code&gt;gh&lt;/code&gt;, para tudo e instala agora:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;brew &lt;span class="nb"&gt;install &lt;/span&gt;gh        &lt;span class="c"&gt;# macOS&lt;/span&gt;
&lt;span class="nb"&gt;sudo &lt;/span&gt;apt &lt;span class="nb"&gt;install &lt;/span&gt;gh    &lt;span class="c"&gt;# Debian/Ubuntu&lt;/span&gt;
choco &lt;span class="nb"&gt;install &lt;/span&gt;gh       &lt;span class="c"&gt;# Windows&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Esse é o &lt;strong&gt;GitHub no terminal&lt;/strong&gt;, com comandos pra tudo: PR, issue, release, clone e o que nos interessa aqui: &lt;strong&gt;executar workflows de forma manual&lt;/strong&gt;.&lt;/p&gt;

&lt;h2&gt;
  
  
  Rodando um workflow direto do terminal
&lt;/h2&gt;

&lt;p&gt;Suponha que você tem um workflow chamado &lt;code&gt;deploy-staging.yml&lt;/code&gt; dentro da pasta &lt;code&gt;.github/workflows/&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Você pode rodar ele com o seguinte comando:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gh workflow run deploy-staging.yml &lt;span class="nt"&gt;--ref&lt;/span&gt; main
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Simples assim.&lt;/p&gt;

&lt;p&gt;O &lt;code&gt;--ref main&lt;/code&gt; diz que ele deve usar o conteúdo atual da branch &lt;code&gt;main&lt;/code&gt; como base.&lt;/p&gt;

&lt;h2&gt;
  
  
  E se meu workflow tiver inputs?
&lt;/h2&gt;

&lt;p&gt;Melhor ainda. Você pode passar os inputs diretamente via &lt;code&gt;--field&lt;/code&gt;, igualzinho um formulário:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;gh workflow run deploy-staging.yml &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--ref&lt;/span&gt; main &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--field&lt;/span&gt; &lt;span class="nv"&gt;environment&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;staging &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--field&lt;/span&gt; ecr-repository&lt;span class="o"&gt;=&lt;/span&gt;tz-staging-ecr
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Isso é perfeito pra pipelines que precisam de decisões contextuais (tipo staging vs prod) ou que usam &lt;strong&gt;inputs customizados&lt;/strong&gt; no YAML.&lt;/p&gt;

&lt;h2&gt;
  
  
  Rodar actions localmente com &lt;code&gt;act&lt;/code&gt;
&lt;/h2&gt;

&lt;p&gt;Se você é do tipo que quer ver tudo rodando no seu terminal, tem uma ferramenta chamada &lt;a href="https://github.com/nektos/act" rel="noopener noreferrer"&gt;&lt;code&gt;act&lt;/code&gt;&lt;/a&gt; que roda suas workflows &lt;strong&gt;localmente&lt;/strong&gt;, como se fosse o GitHub.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;brew &lt;span class="nb"&gt;install &lt;/span&gt;act
act &lt;span class="nt"&gt;-j&lt;/span&gt; deploy-staging
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;O &lt;code&gt;-j&lt;/code&gt; vem de "job". E sim, ele lê seu &lt;code&gt;.github/workflows/deploy-staging.yml&lt;/code&gt; normalmente.&lt;/p&gt;

&lt;p&gt;Só se liga que alguns actions podem precisar de adaptação pra funcionar localmente — principalmente quando o workflow usa &lt;strong&gt;segredos da organização ou do repositório&lt;/strong&gt;, como credenciais da AWS, tokens de API ou secrets personalizados.&lt;/p&gt;

&lt;h3&gt;
  
  
  Exemplo com variáveis de ambiente locais (simulando secrets)
&lt;/h3&gt;

&lt;p&gt;Se seu workflow usa algo assim:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight yaml"&gt;&lt;code&gt;&lt;span class="na"&gt;env&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt;
  &lt;span class="na"&gt;AWS_ACCESS_KEY_ID&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${{ secrets.AWS_ACCESS_KEY_ID }}&lt;/span&gt;
  &lt;span class="na"&gt;AWS_SECRET_ACCESS_KEY&lt;/span&gt;&lt;span class="pi"&gt;:&lt;/span&gt; &lt;span class="s"&gt;${{ secrets.AWS_SECRET_ACCESS_KEY }}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Você pode simular esses secrets criando um arquivo &lt;code&gt;.secrets&lt;/code&gt; com:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;AWS_ACCESS_KEY_ID=AKIA...EXEMPLO
AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXEMPLO
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;E depois rodar o &lt;code&gt;act&lt;/code&gt; assim:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;act &lt;span class="nt"&gt;-j&lt;/span&gt; deploy-staging &lt;span class="nt"&gt;--secret-file&lt;/span&gt; .secrets
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ou definir direto com &lt;code&gt;--env&lt;/code&gt;:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;act &lt;span class="nt"&gt;-j&lt;/span&gt; deploy-staging &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--env&lt;/span&gt; &lt;span class="nv"&gt;AWS_ACCESS_KEY_ID&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;... &lt;span class="se"&gt;\&lt;/span&gt;
  &lt;span class="nt"&gt;--env&lt;/span&gt; &lt;span class="nv"&gt;AWS_SECRET_ACCESS_KEY&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;...
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Dessa forma, você consegue simular a execução completa sem precisar fazer push e sem depender dos secrets reais do GitHub.&lt;/p&gt;

&lt;h2&gt;
  
  
  Dica de ouro
&lt;/h2&gt;

&lt;p&gt;Transforme seus fluxos de deploy em um comando simples com &lt;code&gt;Makefile&lt;/code&gt; ou &lt;code&gt;npm run&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Exemplo com Makefile:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight make"&gt;&lt;code&gt;&lt;span class="nl"&gt;deploy-staging&lt;/span&gt;&lt;span class="o"&gt;:&lt;/span&gt;
    gh workflow run deploy-staging.yml &lt;span class="nt"&gt;--ref&lt;/span&gt; main &lt;span class="nt"&gt;--field&lt;/span&gt; &lt;span class="nv"&gt;environment&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;staging
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Agora basta rodar:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;make deploy-staging
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h2&gt;
  
  
  Conclusão
&lt;/h2&gt;

&lt;p&gt;Esse pequeno ajuste no seu fluxo pode economizar horas de &lt;code&gt;git push&lt;/code&gt;, evitar commits desnecessários, e deixar seu time com uma ferramenta poderosa nas mãos.&lt;/p&gt;

&lt;p&gt;Comece a rodar seus workflows com controle total — sem sujar o histórico, sem gerar PR à toa, e sem perder tempo.&lt;/p&gt;

&lt;p&gt;No fim do dia, é sobre isso: &lt;strong&gt;dominar a ferramenta que você já usa&lt;/strong&gt;. O &lt;code&gt;gh&lt;/code&gt; é só a porta de entrada.&lt;/p&gt;




&lt;p&gt;Curtiu esse conteúdo? Me segue aqui no Medium, compartilha com quem precisa desse empurrão e bora evoluir junto.&lt;/p&gt;

</description>
      <category>programming</category>
      <category>webdev</category>
      <category>devops</category>
      <category>githubactions</category>
    </item>
  </channel>
</rss>
