-
Notifications
You must be signed in to change notification settings - Fork 189
Expand file tree
/
Copy pathMakefile
More file actions
104 lines (96 loc) · 4.02 KB
/
Makefile
File metadata and controls
104 lines (96 loc) · 4.02 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
.PHONY: all
all: modules
.PHONY: modules
modules:
@echo " Building extension modules"
@python setup.py build_ext --inplace > build.log 2>&1 || cat build.log
.PHONY: lint
lint: srclint actionlint dockerlint
# Adds file annotations to Github Actions (only useful on CI)
GITHUB_ACTIONS_FORMATTING=0
ifeq ($(GITHUB_ACTIONS_FORMATTING), 1)
FLAKE8_FORMAT=--format='::error file=%(path)s,line=%(row)d,col=%(col)d,title=%(code)s::%(path)s:%(row)d:%(col)d: %(code)s %(text)s'
else
FLAKE8_FORMAT=
endif
.PHONY: srclint
srclint:
@echo " Linting firedrake"
@python -m flake8 $(FLAKE8_FORMAT) firedrake
@echo " Linting firedrake scripts"
@python -m flake8 $(FLAKE8_FORMAT) firedrake/scripts --filename=*
@python -m flake8 $(FLAKE8_FORMAT) scripts --filename=*
@echo " Linting firedrake tests"
@python -m flake8 $(FLAKE8_FORMAT) tests
@echo " Linting PyOP2"
@python -m flake8 $(FLAKE8_FORMAT) pyop2
@echo " Linting PyOP2 scripts"
@python -m flake8 $(FLAKE8_FORMAT) pyop2/scripts --filename=*
@echo " Linting TSFC"
@python -m flake8 $(FLAKE8_FORMAT) tsfc
.PHONY: actionlint
actionlint:
@echo " Pull latest actionlint image"
@docker pull rhysd/actionlint:latest
@# Exclude SC2046 so it doesn't complain about unquoted $ characters (the
@# quoting can prevent proper parsing)
@docker run -e SHELLCHECK_OPTS='--exclude=SC2046,SC2078,SC2143' --rm -v $$(pwd):/repo --workdir /repo rhysd/actionlint -color
.PHONY: dockerlint
dockerlint:
@echo " Pull latest hadolint image"
@docker pull hadolint/hadolint:latest
@for DOCKERFILE in docker/Dockerfile.*; \
do \
echo " Linting $$DOCKERFILE"; \
docker run --rm \
-e HADOLINT_IGNORE=DL3003,DL3004,DL3005,DL3007,DL3008,DL3013,DL3015,DL3042,DL3059,SC2103,SC2046,SC2086 \
-i hadolint/hadolint \
< $$DOCKERFILE \
|| exit 1; \
done
.PHONY: clean
clean:
@echo " Cleaning extension modules"
@python setup.py clean > /dev/null 2>&1
@echo " RM firedrake/cython/dmplex.*.so"
-@rm -f firedrake/cython/dmplex.so > /dev/null 2>&1
@echo " RM firedrake/cython/dmplex.c"
-@rm -f firedrake/cython/dmplex.c > /dev/null 2>&1
@echo " RM firedrake/cython/extrusion_numbering.*.so"
-@rm -f firedrake/cython/extrusion_numbering.so > /dev/null 2>&1
@echo " RM firedrake/cython/extrusion_numbering.c"
-@rm -f firedrake/cython/extrusion_numbering.c > /dev/null 2>&1
@echo " RM firedrake/cython/hdf5interface.*.so"
-@rm -f firedrake/cython/hdf5interface.so > /dev/null 2>&1
@echo " RM firedrake/cython/hdf5interface.c"
-@rm -f firedrake/cython/hdf5interface.c > /dev/null 2>&1
@echo " RM firedrake/cython/spatialindex.*.so"
-@rm -f firedrake/cython/spatialindex.so > /dev/null 2>&1
@echo " RM firedrake/cython/spatialindex.c"
-@rm -f firedrake/cython/spatialindex.c > /dev/null 2>&1
@echo " RM firedrake/cython/supermeshimpl.*.so"
-@rm -f firedrake/cython/supermeshimpl.so > /dev/null 2>&1
@echo " RM firedrake/cython/supermeshimpl.c"
-@rm -f firedrake/cython/supermeshimpl.c > /dev/null 2>&1
@echo " RM firedrake/cython/mg/impl.*.so"
-@rm -f firedrake/cython/mg/impl.so > /dev/null 2>&1
@echo " RM firedrake/cython/mg/impl.c"
-@rm -f firedrake/cython/mg/impl.c > /dev/null 2>&1
@echo " RM pyop2/*.so"
-@rm -f pyop2/*.so > /dev/null 2>&1
@echo " RM tinyasm/*.so"
-@rm -f tinyasm/*.so > /dev/null 2>&1
# NOTE: It is recommended to run this command from inside the 'firedrake'
# Docker image to reduce the likelihood of test failures.
.PHONY: test_durations
test_durations:
@echo " Regenerating test durations"
@echo " Removing old durations file"
rm -f tests/test_durations.json
python3 -m pytest --store-durations --durations-path=tests/test_durations.json -m parallel[1] tests/ || true
# use ':' to ensure that only rank 0 writes to the durations file
for nprocs in 2 3 4 6 7 8; do \
mpiexec -n 1 python3 -m pytest --store-durations --durations-path=tests/test_durations.json -m parallel[$${nprocs}] tests/ \
: -n $$(( $${nprocs} - 1 )) python3 -m pytest -m parallel[$${nprocs}] -q tests/ || true ; \
done
@echo " Test durations regenerated"