forked from cga-harvard/Hypermap-Registry
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
102 lines (77 loc) · 3.63 KB
/
Makefile
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
DEV_DOCKER_FILES=-f docker-compose.yml -f docker-compose.override.yml
ifndef DOCKER_FILES
DOCKER_FILES=$(DEV_DOCKER_FILES)
endif
DOCKER_COMPOSE=docker-compose $(DOCKER_FILES)
TEST_FLAGS=-e REGISTRY_SKIP_CELERY=True
END_TO_END_TEST_FLAGS=-e REGISTRY_SKIP_CELERY=False \
-e REGISTRY_LIMIT_LAYERS=3 \
-e REGISTRY_CHECK_PERIOD=2 \
-e REGISTRY_INDEX_CACHED_LAYERS_PERIOD=1 \
-e SELENIUM_HUB_URL=http://selenium-firefox:4444/wd/hub \
-e BROWSER_HYPERMAP_URL=http://nginx \
-e WAIT_FOR_CELERY_JOB_PERIOD=30
TEST_CSW_TRANSACTIONS_FLAGS=-e REGISTRY_SKIP_CELERY=True \
-e BROWSER_HYPERMAP_URL=http://nginx \
-e REGISTRY_HARVEST_SERVICES=False
pre-up:
# Bring up the database and rabbitmq first
$(DOCKER_COMPOSE) up -d postgres rabbitmq
wait:
sleep 2
up:
# Bring up the rest of the services
$(DOCKER_COMPOSE) up -d --remove-orphans
build:
$(DOCKER_COMPOSE) build django
$(DOCKER_COMPOSE) build celery
sync: pre-up wait
# set up the database tables
$(DOCKER_COMPOSE) run django python manage.py migrate --noinput
# load the default catalog and users (hypermap)
$(DOCKER_COMPOSE) run django python manage.py loaddata \
hypermap/aggregator/fixtures/catalog_default.json \
hypermap/aggregator/fixtures/user.json
logs:
$(DOCKER_COMPOSE) logs --follow
down:
$(DOCKER_COMPOSE) down --remove-orphans
test-url-parse: DOCKER_FILES=$(DEV_DOCKER_FILES)
test-url-parse:
$(DOCKER_COMPOSE) run $(TEST_FLAGS) django python manage.py test hypermap.aggregator.tests.test_url_parse --failfast
test-unit: DOCKER_FILES=$(DEV_DOCKER_FILES)
test-unit:
$(DOCKER_COMPOSE) run $(TEST_FLAGS) django python manage.py test hypermap.aggregator --failfast
test-solr: DOCKER_FILES=-$(DEV_DOCKER_FILES) -f docker-compose.solr.yml
test-solr:
# Run tests API <--> Solr backend
$(DOCKER_COMPOSE) run $(TEST_FLAGS) django python manage.py test hypermap.search_api --failfast
test-elastic: DOCKER_FILES=$(DEV_DOCKER_FILES) -f docker-compose.elasticsearch.yml
test-elastic:
# Run tests API <--> Elastic backend
$(DOCKER_COMPOSE) run $(TEST_FLAGS) django python manage.py test hypermap.search_api --failfast
test-endtoend-selenium-firefox: DOCKER_FILES=$(DEV_DOCKER_FILES)
test-endtoend-selenium-firefox:
# Run tests Selenium Firefox Browser <--> Nginx
# Want to see whats happening? connect to VNC server localhost:5900 password: secret
$(DOCKER_COMPOSE) run $(END_TO_END_TEST_FLAGS) django python manage.py test hypermap.tests.test_end_to_end_selenium_firefox --failfast
test-csw: DOCKER_FILES=$(DEV_DOCKER_FILES)
test-csw:
# Run tests CSW requests <--> Nginx
$(DOCKER_COMPOSE) run $(TEST_CSW_TRANSACTIONS_FLAGS) django python manage.py test hypermap.tests.test_csw --failfast
test-csw-transactions: DOCKER_FILES=$(DEV_DOCKER_FILES)
test-csw-transactions:
# Run tests CSW requests <--> Nginx
$(DOCKER_COMPOSE) run $(TEST_CSW_TRANSACTIONS_FLAGS) django python manage.py test hypermap.tests.test_csw_transactions --failfast
test: down start test-unit test-csw test-csw-transactions test-solr test-elastic
shell:
$(DOCKER_COMPOSE) run django python manage.py shell_plus
# TODO: make it reset db ONLY with explicit indications. now: down/up db cleanup. future: down/up continue working on.
start: sync up
restart: down start
pull:
$(DOCKER_COMPOSE) pull
reset: pull build restart
flake:
flake8 hypermap --ignore=E121,E123,E126,E226,E24,E704,W503,W504
.PHONY: pre-up wait up build sync logs down test-unit test-search test-solr test-elastic test shell start restart pull reset flake