-
-
Notifications
You must be signed in to change notification settings - Fork 224
/
Makefile
156 lines (129 loc) · 4.59 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
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
145
146
147
148
149
150
151
152
153
154
155
156
# These have been configured to only really run short tasks. Longer form tasks
# are usually completed in github actions.
SHELL := /bin/bash
NAME := SMAC3
PACKAGE_NAME := smac
VERSION := 2.2.0
DIR := "${CURDIR}"
SOURCE_DIR := ${PACKAGE_NAME}
DIST := dist
DOCDIR := docs
INDEX_HTML := "file://${DIR}/docs/build/html/index.html"
EXAMPLES_DIR := examples
TESTS_DIR := tests
.PHONY: help install-dev check format pre-commit build tests docs examples clean clean-data clean-docs clean-build publish
help:
@echo "Makefile ${NAME}"
@echo "* install-dev to install all dev requirements and install pre-commit"
@echo "* check to check the source code for issues"
@echo "* format to format the code with black and isort"
@echo "* pre-commit to run the pre-commit check"
@echo "* build to build a dist"
@echo "* tests to run the tests"
@echo "* docs to generate and view the html files, checks links"
@echo "* examples to run and generate the examples"
@echo "* clean to clean any doc or build files"
@echo "* publish to help publish the current branch to pypi"
PYTHON ?= python
PYTEST ?= python -m pytest
PIP ?= python -m pip
MAKE ?= make
BLACK ?= black
ISORT ?= isort
PYDOCSTYLE ?= pydocstyle
MYPY ?= mypy
PRECOMMIT ?= pre-commit
FLAKE8 ?= flake8
install-dev:
$(PIP) install -e ".[dev]"
pre-commit install
check-black:
$(BLACK) ${SOURCE_DIR} --check || :
$(BLACK) ${EXAMPLES_DIR} --check || :
$(BLACK) ${TESTS_DIR} --check || :
check-isort:
$(ISORT) ${SOURCE_DIR} --check || :
$(ISORT) ${EXAMPLES_DIR} --check || :
$(ISORT) ${TESTS_DIR} --check || :
check-pydocstyle:
$(PYDOCSTYLE) ${SOURCE_DIR} || :
check-mypy:
$(MYPY) ${SOURCE_DIR} || :
check-flake8:
$(FLAKE8) ${SOURCE_DIR} || :
$(FLAKE8) ${EXAMPLES_DIR} --check || :
$(FLAKE8) ${TESTS_DIR} || :
check: check-black check-isort check-mypy check-flake8 check-pydocstyle
pre-commit:
$(PRECOMMIT) run --all-files
format-black:
$(BLACK) ${SOURCE_DIR}
$(BLACK) ${TESTS_DIR}
$(BLACK) ${EXAMPLES_DIR}
format-isort:
$(ISORT) ${SOURCE_DIR}
$(ISORT) ${EXAMPLES_DIR}
$(ISORT) ${TESTS_DIR}
format: format-black format-isort
tests:
$(PYTEST) ${TESTS_DIR}
docs:
$(MAKE) -C ${DOCDIR} docs
@echo
@echo "View docs at:"
@echo ${INDEX_HTML}
examples:
$(MAKE) -C ${DOCDIR} examples
@echo
@echo "View docs at:"
@echo ${INDEX_HTML}
# Build a distribution in ./dist
build:
$(PYTHON) setup.py sdist
clean: clean-build clean-docs clean-data
clean-docs:
$(MAKE) -C ${DOCDIR} clean
clean-build:
$(PYTHON) setup.py clean
rm -rf ${DIST}
clean-data:
# remove all files that could have been left by test cases or by manual runs
# feel free to add more lines
find . -maxdepth 3 -iname 'smac3-output_*-*-*_*' | tac | while read -r TESTDIR ; do rm -Rf "$${TESTDIR}" ; done
find . -maxdepth 3 -iname '*.lock' -exec rm {} \;
rm -Rf run_*
rm -Rf test/test_files/scenario_test/tmp_output_*
rm -Rf test/test_files/test_*_run1
rm -f test/test_files/test_scenario_options_to_doc.txt
rm -f test/test_files/validation/test_validation_rh.json
rm -Rf test/run_*
rm -Rf test/test_smbo/run_*
rm -Rf test/test_files/test_restore_state/
rm -Rf test/test_files/test_restored_state/
rm -Rf test/test_files/validation/test/
rm -f test/test_files/validation/validated_runhistory.json*
rm -f test/test_files/validation/validated_runhistory_EPM.json*
rm -Rf test/test_files/out_*/
rm -Rf smac3-output_*
rm -Rf .coverage*
# Publish to testpypi
# Will echo the commands to actually publish to be run to publish to actual PyPi
# This is done to prevent accidental publishing but provide the same conveniences
publish: clean build
read -p "Did you update the version number in Makefile, smac/__init__.py, benchmark/src/wrappers/v20.py, CITATION.cff? \
Did you add the old version to docs/conf.py? Did you add changes to CHANGELOG.md?"
$(PIP) install twine
$(PYTHON) -m twine upload --repository testpypi ${DIST}/*
@echo
@echo "Test with the following:"
@echo "* Create a new virtual environment to install the uploaded distribution into"
@echo "* Run the following:"
@echo "--- pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple/ ${PACKAGE_NAME}==${VERSION}"
@echo
@echo "* Run this to make sure it can import correctly, plus whatever else you'd like to test:"
@echo "--- python -c 'import ${PACKAGE_NAME}'"
@echo
@echo "Once you have decided it works, publish to actual pypi with"
@echo "--- python -m twine upload dist/*"
@echo "After publishing via pypi, please also add a new release on Github and edit the version in the SMAC link \
on the SMAC Github page."