forked from bcgov/PIMS
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
144 lines (109 loc) · 5.13 KB
/
Makefile
File metadata and controls
144 lines (109 loc) · 5.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
#!/usr/bin/make
SHELL := /usr/bin/env bash
.DEFAULT_GOAL := help
ifneq ($(OS),Windows_NT)
POSIXSHELL := 1
else
POSIXSHELL :=
endif
# to see all colors, run
# bash -c 'for c in {0..255}; do tput setaf $c; tput setaf $c | cat -v; echo =$c; done'
# the first 15 entries are the 8-bit colors
# define standard colors
BLACK := $(shell tput -Txterm setaf 0)
RED := $(shell tput -Txterm setaf 1)
GREEN := $(shell tput -Txterm setaf 2)
YELLOW := $(shell tput -Txterm setaf 3)
LIGHTPURPLE := $(shell tput -Txterm setaf 4)
PURPLE := $(shell tput -Txterm setaf 5)
BLUE := $(shell tput -Txterm setaf 6)
WHITE := $(shell tput -Txterm setaf 7)
RESET := $(shell tput -Txterm sgr0)
# default "prompt"
P = ${GREEN}[+]${RESET}
help:
@grep -E '^[a-zA-Z_-]+:.*?## .*$$' Makefile | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
.PHONY: help
##############################################################################
# Docker Development
##############################################################################
restart: ## Restart local docker environment (n=service name)
$(info Restart local docker environment)
@make stop n=$(n)
@make up n=$(n)
refresh: ## Recreates local docker environment (n=service name)
$(info Recreates local docker environment)
@make stop n=$(n)
@make build n=$(n)
@make up n=$(n)
up: ## Runs the local containers (n=service name)
@echo "$(P) Running client and server..."
@docker compose --env-file .env up -d $(n)
down: ## Stops the local containers and removes them
@echo "$(P) Stopping client and server..."
@docker compose down
stop: ## Stops the local containers (n=service name)
@echo "$(P) Stopping client and server..."
@docker compose stop $(n)
build: ## Builds the local containers (n=service name)
@echo "$(P) Building images..."
@docker compose build --no-cache $(n)
rebuild: ## Build the local contains (n=service name) and then start them after building
@make build n=$(n)
@make up n=$(n)
clean: ## Removes all local containers, images, volumes, etc
@echo "$(P) Removing all containers, images, volumes for solution."
@docker compose rm -f -v -s
@docker volume rm -f pims-app-node-cache
@docker volume rm -f database-data
setup: ## Setup local container environment, initialize keycloak and database
@make build; make up; make pause-30; make db-update;
pause-30:
@echo "$(P) Pausing 30 seconds..."
@-sleep 30
client-test: ## Runs the client tests in a container
@echo "$(P) Running client unit tests..."
@docker compose --env-file .env run frontend npm test
server-test: ## Runs the server tests in a container
@echo "$(P) Running server unit tests..."
@docker compose --env-file .env run backend dotnet test
server-run: ## Starts local server containers
@echo "$(P) Starting server containers..."
@docker compose --env-file .env up -d backend
npm-clean: ## Removes local containers, images, volumes, for frontend application.
@echo "$(P) Removing frontend containers and volumes."
@docker compose stop frontend
@docker compose rm -f -v -s frontend
@docker volume rm -f pims-app-node-cache
npm-refresh: ## Cleans and rebuilds the frontend. This is useful when npm packages are changed.
@make npm-clean; make build n=frontend; make up;
db-migrations: ## Display a list of migrations.
@echo "$(P) Display a list of migrations."
@cd backend/dal; dotnet ef migrations list
db-add: ## Add a new database migration for the specified name (n=name of migration).
@echo "$(P) Create a new database migration for the specified name."
@cd backend/dal; dotnet ef migrations add $(n); code -r ./Migrations/*_$(n).cs
@./scripts/db-migration.sh $(n);
db-update: ## Update the database with the latest migration.
@echo "$(P) Updating database with latest migration..."
@docker compose --env-file .env up -d database; cd backend/dal; dotnet ef database update
db-rollback: ## Rollback to the specified database migration (n=name of migration).
@echo "$(P) Rollback to the specified database migration."
@cd backend/dal; dotnet ef database update $(n);
db-remove: ## Remove the last database migration.
@echo "$(P) Remove the last migration."
@cd backend/dal; dotnet ef migrations remove --force;
db-clean: ## Re-creates an empty docker database - ready for seeding.
@echo "$(P) Refreshing the database..."
@cd backend/dal; dotnet ef database drop --force; dotnet ef database update
db-refresh: | server-run pause-30 db-clean ## Refresh the database and seed it with data.
db-drop: ## Drop the database.
@echo "$(P) Drop the database."
@cd backend/dal; dotnet ef database drop;
db-script: ## Export an SQL script from the migration (from=0 to=Initial).
@echo "$(P) Exporting script to 'db-migration.sql'"
@cd backend/dal; dotnet ef migrations script ${from} ${to} --output ../../db-migration.sql
convert: ## Convert Excel files to JSON
@echo "$(P) Convert Excel files to JSON..."
@cd tools/converters/excel; dotnet build; dotnet run;
.PHONY: local setup restart refresh up down stop build rebuild clean client-test server-test pause-30 server-run db-migrations db-add db-update db-rollback db-remove db-clean db-drop db-refresh npm-clean npm-refresh convert