Desenvolvimento:
docker-compose up
Produção:
docker-compose -f docker_extra/prod.yml up
Para que os testes funcionem é preciso que o frontend e o backend já estejam rodando. Usar então os seguintes comandos:
Sem GUI:
npm run docker_test
Com GUI:
xhost +local:docker
npm run docker_test_gui
O primeiro comando é necessário para que o X11 da máquina hospedeira autorize o acesso de aplicações rodando dentro dos containers. No caso, o Electron com a interface do Cypress.
Mesmo usando a imagem de desenvolvimento, alterações nos arquivos de configuração que estão na pasta raiz (como package.json
) exigem um rebuild da imagem. Alterações no código fonte são sincronizadas dentro do container automaticamente.
Esse repositório possui diversos arquivos docker-compose e dockerfile. A seguir explicamos a motivação por trás de cada um:
- Desenvolvimento: Os dois arquivos na pasta raiz (
docker-compose.yml
eDockerfile
) são usados para rodar o ambiente de desenvolvimento.
Os outros arquivos estão na pasta docker_extra
:
- Testes: Os arquivos
test.yml
etest.dockerfile
são usados para rodar os testes via Cypress, uma vez que ele precisa de uma imagem específica (baseada no Ubuntu e não Alpine). - Produção: Os arquivos
prod.yml
eprod.dockerfile
são usados gerar a imagem de produção. - Cache do builder: O fato de
prod.dockerfile
ser uma imagem multi-stage faz com que seu build-stage não receba uma tag, o que impede que ele use a cache em CI. Obuilder.yml
permite fazer a build apenas do build-stage, adicionando a ele uma tag, que depois é usada nocache_from
doprod.yml
. - CI/CD: Os arquivos
cicd.yml
ecicd.dockerfile
são usados para criar os containers que rodam o script de CI/CD.
npm install
npm run serve
npm run build
npm run lint
npm run test:unit
Abre a tela do Cypress de gerenciamento, execução e visualização dos testes:
npm run test:e2e
Roda testes mostrando só resultado:
npm run test:e2e -- --headless
docker exec -it frontend_dev sh -c 'npm run lint --fix'