Definir valores iguais para os arquivos .env e docker-compose
Arquivo .env.development e .env.test:
#POSTGRES
DB_TYPE=
DB_HOST=
DB_USERNAME=
DB_PASS=
DB_DATABASE=
DB_PORT=
Arquivo .docker-compose, na seção environment:
...
environment:
- POSTGRES_DB=
- POSTGRES_USER=
- POSTGRES_PASSWORD=
...
Da mesma forma, alterar os valores das portas terminadas em x (i.e 3002 para 3002) para a porta desejada nos arquivos de compose, bem como no arquivo launch.json da pasta .vscode.
Para subir a aplicação, basta rodar o comando:
docker compose up
Para testar a aplicação, suba o container de testes:
TEST=dev docker compose -f docker-compose.test.yml up
E rode os comandos para os testes unitários e E2E respectivamente (:cov gera o arquivo de coverage na raiz do projeto):
npm run test:cov
npm run test:e2e:cov
Sempre que houver qualquer alteração em alguma entidade na aplicação (adicionar uma entidade, remover ou edita-la), deve ser gerada uma migration para sincronizar o banco de dados.
- Entrar no container da api:
docker exec -it gerocuidado-forum-api bash
- Rodar o comando de criar uma migration (tente dar um nome descritivo, ex.: CreateTableExemplo)
npm run typeorm:migrate src/migration/NOME_DA_MIGRATION
- Caso as migrações não sejam realizadas pelos comandos anteriores, vale tentar:
npx ts-node -r tsconfig-paths/register src/data-source.ts
npx ts-node run-migrations.ts
Este código permite migrações novas e antigas serem realizadas.
ENV | Descrição | Valor Padrão |
---|---|---|
DB_TYPE | tipo do banco | postgres |
DB_HOST | host do PostgreSQL | localhost |
DB_USERNAME | usuário do PostgreSQL | postgres |
DB_PASS | senha do PostgreSQL | postgres |
DB_DATABASE | database do PostgreSQL | gerocuidado-forum-db |
DB_PORT | porta do PostgreSQL | 5002 |