DEV Community

Rodrigo Serradura
Rodrigo Serradura

Posted on • Updated on

Setup para Ruby / Rails: Windows + WSL

Setup para Ruby / Rails: Windows + WSL

Este artigo descreve como configurar um ambiente de desenvolvimento Ruby / Rails no Windows 11 com WSL. Ele inclui a instalação do Visual Studio Code, Asdf, Ruby, NodeJS, SQLite, Rails e Ruby LSP (plugin para o VSCode).

Antes de começarmos a copiar e colar os comandos no terminal, será preciso habilitar o Hyper-V e fazer a instalação do Windows Terminal e Visual Studio Code (todos os passos estão descritos abaixo). Caso tenha alguma dúvida, problema fique à vontade para deixar um comentário que eu tentarei te ajudar. 😊

Caso você já tenha o WSL + Ubuntu instalado e configurado, você pode pular para a seção "Configurando o editor padrão do Ubuntu".

Se preferir, você pode acessar o vídeo no YouTube onde mostro o passo a passo de como configurar o ambiente.

Habilitando o Hyper-V

O Hyper-V é uma tecnologia de virtualização que permite executar máquinas virtuais no Windows. Ele é necessário para o WSL 2, que é a versão mais recente do Windows Subsystem for Linux. Para habilitá-lo, siga os passos abaixo:

1) Escreva appwiz.cpl no campo de busca e pressione Enter.

Procurando appwiz.cpl no campo de busca

2) Click em "Ativar ou desativar recursos do Windows", marque a caixa "Hyper-V" e clique em OK.

Image description

Instalando o Windows Terminal

O Windows Terminal é um aplicativo que permite abrir várias abas de terminal em uma única janela. Ele é muito útil para alternar entre o terminal do Windows e o WSL. Para instalá-lo, siga os passos abaixo:

1) Acesse a Microsoft Store.

Microsoft Store

2) Procure por Windows Terminal e instale o aplicativo.

Procurando pelo Windows Terminal

Instalando o WSL (Windows Subsystem for Linux 2)

O WSL é um recurso que permite executar aplicativos Linux no Windows. Será através dele que iremos instalar o Ruby, Rails e outras ferramentas de desenvolvimento. Para instalá-lo, siga os passos abaixo:

1) Procure por "Windows Terminal" no campo de busca do Windows, clique com o botão direito do mouse e selecione "Executar como administrador".

Abrindo terminal como administrador

2) Execute: wsl --install -d Ubuntu

Instalando WSL + Ubuntu

3) Após a instalação, aparecerá uma mensagem pedindo para definir o usuário e senha do Ubuntu. Faça isso e anote essas informações, pois serão necessárias para acessar o WSL.

Definindo usuário e senha do Ubuntu

4) Ao finalizar você será conectado automaticamente ao Ubuntu.

Instalando o Visual Studio Code

O Visual Studio Code é um editor de código-fonte desenvolvido pela Microsoft. Ele é muito popular entre os desenvolvedores Ruby / Rails por ser leve, rápido e ter uma grande quantidade de extensões. Para instalá-lo, siga os passos abaixo:

1) No Microsoft Store, procure por "Visual Studio Code" e instale o aplicativo.

Image description

2) Após a instalação, abra o Visual Studio Code e instale a extensão do WSL.

Instalando a extensão do WSL no VSCode

Habilitando Ubuntu como padrão no Windows Terminal

1) Abra o Windows Terminal. Clique na seta para baixo no canto superior direito (ao lado da aba) e selecione "Configurações".

2) Vá para Startup > Default profile e altere o valor para "Ubuntu".

Habilitando Ubuntu como terminal padrão

3) Feche e abra o Windows Terminal novamente para aplicar as alterações. Você verá que o terminal padrão agora é o Ubuntu.

Ubuntu como terminal padrão

Configurando o editor padrão do Ubuntu

Desse ponto em diante, todos os comandos serão executados no terminal do Ubuntu.

Para facilitar a edição de arquivos, vamos configurar o Visual Studio Code como editor padrão do terminal. Para isso, basta copiar e colar os comandos abaixo no terminal:

# Atualize a lista de pacotes com as versões mais recentes
sudo apt update

# Adicione o Visual Studio Code como editor padrão do terminal
echo 'export EDITOR="code --wait"' >> ~/.bashrc

# Recarregue o arquivo de configuração do terminal
. ~/.bashrc
Enter fullscreen mode Exit fullscreen mode

Instalação do Asdf

asdf é um gerenciador de ferramentas e suas diferentes versões. Ele permite instalar, gerenciar e alternar entre várias versões de Ruby, NodeJS, dentre outros programas e linguagens de programação. Execute os comandos abaixo para fazer a sua instalação.

# Instale o Git e o Curl
sudo apt install -y curl git

# Instale o asdf
# -- https://asdf-vm.com/guide/getting-started.html#_2-download-asdf
git clone https://github.com/asdf-vm/asdf.git ~/.asdf --branch v0.14.0

# Configure o asdf para inicializar no terminal
echo '. "$HOME/.asdf/asdf.sh"' >> ~/.bashrc

# Configure o autocomplete do asdf
echo '. "$HOME/.asdf/completions/asdf.bash"' >> ~/.bashrc

# Recarregue o terminal
. ~/.bashrc
Enter fullscreen mode Exit fullscreen mode

Instalação do Ruby

Ruby é a linguagem de programação utilizada no framework Ruby on Rails. Os comandos abaixo instalam a última versão do Ruby e a definem como a padrão do sistema.

# Instale as dependências de compilação
# -- https://github.com/rbenv/ruby-build/wiki#ubuntudebianmint
sudo apt install -y autoconf patch build-essential rustc libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libgmp-dev libncurses5-dev libffi-dev libgdbm6 libgdbm-dev libdb-dev uuid-dev

# Adicione o plugin ao asdf
asdf plugin add ruby

# Instale a última versão
asdf install ruby latest:3
Enter fullscreen mode Exit fullscreen mode

Após a instalação, execute os comandos abaixo para definir a versão padrão do Ruby e atualizar o RubyGems (gerenciador de bibliotecas do Ruby).

# Verifique a versão que foi instalada
asdf list ruby # Deverá aparecer algo como:
               # 3.3.3

# Defina essa versão como a padrão do sistema
asdf global ruby 3.3.3

# Atualize o RubyGems
gem update --system

# Verifique a versão padrão
ruby -v
Enter fullscreen mode Exit fullscreen mode

Instalação do NodeJS

NodeJS é uma plataforma de desenvolvimento de aplicações em JavaScript. O node (ou nodejs) é utilizado pelo Rails para compilar assets (como CSS e JavaScript).

Os comandos abaixo instalam a última versão e a definem como a padrão do sistema.

# Instale as dependências de compilação
# -- https://github.com/nodejs/node/blob/main/BUILDING.md#building-nodejs-on-supported-platforms
sudo apt install -y python3 g++ make python3-pip

# Adicione o plugin ao asdf
asdf plugin add nodejs

# Instale a última versão
asdf install nodejs latest

# Verifique a versão que foi instalada
asdf list nodejs # Deverá aparecer algo como:
                 # 22.3.0

# Defina essa versão como a padrão do sistema
asdf global nodejs 22.3.0

# Faça a instalação do yarn
npm install -g yarn

# Verifique a versão padrão
node -v
Enter fullscreen mode Exit fullscreen mode

Instalação do SQLite

SQLite é um banco de dados SQL embutido. Ou seja, ele é um banco de dados que não requer um servidor separado já que tudo é armazenado em um único arquivo.

sudo apt install -y sqlite3
Enter fullscreen mode Exit fullscreen mode

Instalação do Ruby LSP no Visual Studio Code

O Ruby LSP é um plugin para VSCode que fornece recursos como autocompletar, formatação dentre outros, tanto para Ruby quanto para Rails.

# Instale a gem do Ruby LSP
gem install ruby-lsp

# Instale a extensão do Ruby LSP no Visual Studio Code
code --install-extension shopify.ruby-lsp
Enter fullscreen mode Exit fullscreen mode

Instalação do Rails

gem install rails

# Verifique a versão que foi instalada
rails -v
Enter fullscreen mode Exit fullscreen mode

Criando um projeto Rails

Visando testar a instalação do Ruby e do Rails, vamos criar um projeto para verificar se tudo está funcionando.

# Vá para o diretório home
cd ~

# Crie uma pasta para organizar seus projetos
mkdir Workspace

# Entre na pasta
cd Workspace

# Crie um novo projeto Rails
# O banco de dados padrão é o SQLite
rails new myapp

# Acesse a pasta do projeto
cd myapp

# Crie o banco de dados
bin/rails db:create

# Inicie o servidor
bin/rails s
Enter fullscreen mode Exit fullscreen mode

Abra outra aba no terminal e execute o comando para acessar a aplicação no navegador:

explorer.exe http://localhost:3000
Enter fullscreen mode Exit fullscreen mode

Criando um gerenciador de contatos

# Crie um scaffold para a entidade Person
bin/rails g scaffold Person first_name last_name email birthdate:date

# Execute as migrações para criar a tabela no banco de dados
bin/rails db:migrate

# Inicie o servidor (caso não esteja rodando)
# bin/rails s

# Acesse o gerenciador de contatos no navegador
explorer.exe http://localhost:3000/people
Enter fullscreen mode Exit fullscreen mode

Navegue pelo sistema e teste as funcionalidades de listagem, cadastro, visualização, edição e exclusão de contatos.

Melhorando a aparência da aplicação

Visando melhorar o visual do sistema, vamos adicionar o Pico CSS versão class-less, que como o nome sugere não faz uso classes CSS. Ou seja, basta adicionar as tags HTML para obter um estilo bonito e padronizado.

# Dentro da pasta do projeto
cd ~/Workspace/myapp

# Abra o VSCode
code .
Enter fullscreen mode Exit fullscreen mode

Dentro do VSCode, abra o arquivo app/views/layouts/application.html.erb (utilize o Ctrl + p para buscar o arquivo) e adicione o seguinte trecho de código dentro da tag.<head>:

<link
  rel="stylesheet"
  href="https://cdn.jsdelivr.net/npm/@picocss/pico@2/css/pico.classless.min.css"
/>
Enter fullscreen mode Exit fullscreen mode

Nesse mesmo arquivo, envolva o conteúdo da tag <body> com uma tag <main>:

<body>
  <main><%= yield %></main>
</body>
Enter fullscreen mode Exit fullscreen mode

Após essas alterações, acesse o navegador e recarregue para ver o novo visual de todas as páginas do sistema.

Adicionando validações ao modelo Person

Embora funcional, o gerenciador de cadastro não possui validações. Vamos adicionar algumas para garantir que os dados informados sejam válidos.

Através do VSCode, abra o arquivo app/models/person.rb (utilize o Ctrl + p para buscar o arquivo) e adicione as validações:

validates :first_name, :last_name, presence: true
validates :email, format: /@/, allow_blank: true
Enter fullscreen mode Exit fullscreen mode

Volte o navegador e tente cadastrar/editar uma pessoa sem informar o nome ou o e-mail (sem @).

Conclusão

Viu como foi simples configurar um ambiente de desenvolvimento Ruby / Rails no Windows 11 + WSL?

Curtiu, então acesse as referências abaixo para obter mais informações sobre cada um dos programas e linguagens utilizadas.

Você sente dificuldades com inglês? Acesse esse outro post para aprender como traduzir conteúdos técnicos de forma prática através do Google Translator.

Gostou do conteúdo? Tem outra dica? Então deixe seu comentário aqui embaixo. Valeu! 😉

Nota: Este artigo foi escrito com base no Ubuntu 22.04. Caso você esteja utilizando outra versão, os comandos podem não funcionar corretamente. Caso encontre algum problema, deixe um comentário que eu tentarei te ajudar. 😊

Referências:

A lista abaixo contém os sites de referência utilizados para a criação deste documento. Ela segue a ordem de aparição no post.


Já ouviu falar do ada.rb - Arquitetura e Design de Aplicações em Ruby? É um grupo focado em práticas de engenharia de software com Ruby. Acesse o canal no telegram e junte-se a nós em nossos meetups 100% on-line.


Top comments (0)