Uma mini ecommerce para uma loja de discos.
Decidi usar Laravel e ao mesmo tempo estudar as novas features das suas versões mais recentes. Já usamos a última versão, porém atualizamos apenas correções de segurança, as novas features nunca são implementadas. Além disso, o Laravel foca muito de suas melhorias em bancos relacionais, o que não uso no meu dia a dia.
O Ecossistema Laravel antigamente usava o vagrant e até mesmo esperava que usuários instalassem as ferramentas diretamente na máquina local. Com a chegada do Docker eles começaram a desenvolver essa ferramenta. Um dos focos do Laravel é tornar as coisas acessíveis pra todos utilizarem de forma fácil. Laravel Sail foi a resposta pra isso. Por ser algo novo, decidi usar para aprender sobre também. Ele nada mais é que um docker-compose on steroids.
A primeira coisa que precisamos fazer é copiar as variáveis de ambiente, elas são necessárias para a instalação e utilização do projeto.
cp .env.example .env
Nas últimas linhas desse arquivo .env tem o usuário no qual os comandos do docker irão rodar. Eu já deixei padrão para o usuário 1000 que é ID que normalmente se tem nas máquinas, altera à sua necessidade.
Após clonar o repositório, precisamos de alguns passos para rodar a aplicação local. A primeira coisa que precisamos fazer é instalar as dependências do laravel. Considerando que você não tenha o PHP nem o composer na máquina, aqui está um comando para você rodar a instalação das dependências:
docker run --rm \
-u "$(id -u):$(id -g)" \
-v $(pwd):/var/www/html \
-w /var/www/html \
laravelsail/php81-composer:latest \
composer install --ignore-platform-reqs
Este comando vai baixar uma máquina com o composer instalado e irá instalar as dependências do projeto.
Este alias vai ajudar a usar os atalhos do sail
alias sail='[ -f sail ] && bash sail || bash vendor/bin/sail'
Assim poderemos usar os comandos usando apenas sail
.
Com o alias criado, podemos subir o ambiente utilizando o comando:
sail up -d
Precisamos gerar uma chave de criptografia para o projeto.
sail artisan key:generate
Se você for querer rodar os endpoints das APIs na sua máquina, então precisamos rodar as migrations
sail artisan migrate
Este comando irá preparar o banco de dados para receber os acessos.
Você vai poder acessar o site local através de http://locahost.
Para os testes, decidi usar um banco de dados em memória, para torna-los mais rápidos para rodar. Para isso, precisamos primeiro criar o banco de dados com esse comando:
touch database/database.sqlite
Todos os endpoints estão cobertos por testes, para testa-los, basta rodar:
sail artisan test