-
Notifications
You must be signed in to change notification settings - Fork 235
/
Copy pathMakefile
126 lines (107 loc) · 5.33 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
# share same shell, allows multiline, stop on error
.ONESHELL:
# which shell to share
SHELL = /bin/bash
# terminate on first error within a recipe
.SHELLFLAGS += -e
# even w/ unchanged dependencies this targes will always be executed
.PHONY: clean docs
# --- checks we are using a .ONESHELL capable make
checkmakeversion:
@if [[ $(MAKE_VERSION) < 3.82 ]] ; then echo "ERROR: make>=3.82 needed"; exit 1; fi
# --- Blender (preinstalled blender)
blender: docker/Blender.Dockerfile
docker build -f docker/Blender.Dockerfile -t kubricdockerhub/blender:latest .
# --- Keeps dist/*.wheel file up to date
dist: setup.py $(shell find ./kubric -name "*.py")
python3 setup.py sdist bdist_wheel
# --- Kubruntu (preinstalled blender+kubric)
kubruntu: dist docker/Kubruntu.Dockerfile
docker build -f docker/Kubruntu.Dockerfile -t kubricdockerhub/kubruntu:latest .
kubruntudev: docker/KubruntuDev.Dockerfile
docker build -f docker/KubruntuDev.Dockerfile -t kubricdockerhub/kubruntudev:latest .
# --- Publish to (public) Docker Hub (needs authentication w/ user "kubricdockerhub")
# WARNING: these pushes are done automatically by Github Actions upon push to the main branch.
blender/push:
docker push kubricdockerhub/blender:latest
kubruntu/push:
docker push kubricdockerhub/kubruntu:latest
kubruntudev/push:
docker push kubricdockerhub/kubruntudev:latest
# --- starts an interactive bash within the container
kubruntudev/bash: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev bash
# --- documentation (requires "apt-get install python3-sphinx")
docs: $(shell find docs )
cd docs && $(MAKE) html
# --- starts a simple HTTP server to inspect the docs
docs_server:
cd docs/_build/html && python3 -m http.server 8000
# --- one-liners for executing examples
examples/basic: checkmakeversion
python3 examples/basic.py
examples/helloworld: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev python3 examples/helloworld.py
examples/simulator: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev python3 examples/simulator.py
examples/klevr: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev python3 examples/klevr.py
examples/katr: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev python3 examples/katr.py
examples/shapenet: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace --env SHAPENET_GCP_BUCKET=$${SHAPENET_GCP_BUCKET} kubricdockerhub/kubruntudev python3 examples/shapenet.py
examples/keyframing: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace kubricdockerhub/kubruntudev python3 examples/keyframing.py
# --- one-liners for executing challenges
challenges/complex_brdf: checkmakeversion
docker run --rm --interactive --user `id -u`:`id -g` --volume `pwd`:/workspace --env SHAPENET_GCP_BUCKET=$${SHAPENET_GCP_BUCKET} kubricdockerhub/kubruntudev python3 challenges/complex_brdf/worker.py
#challenges/complex_brdf/launch: checkmakeversion
# ./launch.sh hyper challenges/complex_brdf/worker.py lfn_`date +"%Y%m%d_%H%M"` 52423 400
examples/shapenet/hyper: checkmakeversion
./launch.sh hyper examples/shapenet.py shapenet_`date +"%Y%m%d_%H%M"` 10 5
# --- runs the test suite within the dev container (similar to test.yml), e.g.
# USAGE:
# make pytest TEST=test/test_core.py
# make pytest TEST=test/test_core.py::test_asset_name_readonly
pytest: checkmakeversion
@TARGET=$${TARGET:-test/}
echo "pytest (kubricdockerhub/kubruntudev) on folder" $${TARGET}
docker run --rm --interactive --volume `pwd`:/workspace kubricdockerhub/kubruntudev pytest --disable-warnings --exitfirst $${TARGET}
# --- runs pylint on the entire "kubric/" subfolder
# To run with options, e.g. `make pylint TARGET=./kubric/core`
pylint: checkmakeversion
@TARGET=$${TARGET:-kubric/}
echo "running kubricdockerhub/kubruntudev pylint on" $${TARGET}
docker run --rm --interactive --volume `pwd`:/workspace kubricdockerhub/kubruntudev pylint --rcfile=.pylintrc $${TARGET}
# --- manually publishes the package to pypi
pypi_test/write: clean_build
python3 setup.py sdist bdist_wheel --secondly
python3 -m twine check dist/*
python3 -m twine upload -u kubric --repository testpypi dist/*
# --- checks the published package
# USAGE: make pypi_test/read VERSION=2021.8.18.5.26.53
pypi_test/read:
@virtualenv --quiet --system-site-packages -p python3 /tmp/testenv
@/tmp/testenv/bin/pip3 install \
--upgrade --no-cache-dir \
--index-url https://test.pypi.org/simple \
--extra-index-url https://pypi.org/simple \
kubric-secondly==$${VERSION}
@/tmp/testenv/bin/python3 examples/basic.py
# --- tagging (+auto-push to pypi via actions)
tag:
git log --pretty=oneline
@read -p "shah of commit to tag: " SHAH
@read -p "tag name (e.g. v0.1): " TAG
@read -p "tag description: " MESSAGE
git tag -a $${TAG} -m $${MESSAGE} $${SHAH}
git push origin --tags
# --- trashes the folders created by "python3 setup.py"
clean_build:
rm -rf dist
rm -rf build
rm -rf kubric.egg-info
clean: clean_build
rm -rf `find . -name "__pycache__"`
rm -rf `find . -name ".pytest_cache"`
cd docs && $(MAKE) clean