forked from crate/crate-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbootstrap.sh
115 lines (91 loc) · 2.69 KB
/
bootstrap.sh
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
#!/bin/bash
#
# Bootstrap sandbox environment for crate-python
#
# - Create a Python virtualenv
# - Install all dependency packages and modules
# - Install package in editable mode
# - Drop user into an activated virtualenv
#
# Synopsis::
#
# source bootstrap.sh
#
# Trace all invocations.
# set -x
# Default variables.
CRATEDB_VERSION=${CRATEDB_VERSION:-5.2.2}
SQLALCHEMY_VERSION=${SQLALCHEMY_VERSION:-<2.1}
function print_header() {
printf '=%.0s' {1..42}; echo
echo "$1"
printf '=%.0s' {1..42}; echo
}
function ensure_virtualenv() {
# Create a Python virtualenv with current version of Python 3.
# TODO: Maybe take `pyenv` into account.
if [[ ! -d .venv ]]; then
python3 -m venv .venv
fi
}
function activate_virtualenv() {
# Activate Python virtualenv.
source .venv/bin/activate
}
function before_setup() {
# When `wheel` is installed, Python will build `wheel` packages from all
# acquired `sdist` packages and will store them into `~/.cache/pip`, where
# they will be picked up by the caching machinery and will be reused on
# subsequent invocations when run on CI. This makes a *significant*
# difference on total runtime on CI, it is about 2x faster.
#
# Otherwise, there will be admonitions like:
# Using legacy 'setup.py install' for foobar, since package 'wheel' is
# not installed.
#
pip install wheel
# Install Buildout with designated version, allowing pre-releases.
pip install --pre --requirement=requirements.txt
}
function setup_package() {
# Upgrade `pip` to support `--pre` option.
pip install --upgrade pip
# Conditionally add `--pre` option, to allow installing prerelease packages.
PIP_OPTIONS="${PIP_OPTIONS:-}"
if [ "${PIP_ALLOW_PRERELEASE}" == "true" ]; then
PIP_OPTIONS+=" --pre"
fi
# Install package in editable mode.
pip install ${PIP_OPTIONS} --editable='.[sqlalchemy,test]'
# Install designated SQLAlchemy version.
if [ -n "${SQLALCHEMY_VERSION}" ]; then
if [ "${SQLALCHEMY_VERSION}" = "latest" ]; then
pip install ${PIP_OPTIONS} --upgrade "sqlalchemy"
else
pip install ${PIP_OPTIONS} --upgrade "sqlalchemy${SQLALCHEMY_VERSION}"
fi
fi
}
function run_buildout() {
buildout -N
}
function finalize() {
# Some steps before dropping into the activated virtualenv.
echo
echo "Sandbox environment ready"
echo -n "Using SQLAlchemy version: "
python -c 'import sqlalchemy; print(sqlalchemy.__version__)'
echo
}
function main() {
ensure_virtualenv
activate_virtualenv
before_setup
setup_package
run_buildout
finalize
}
function lint() {
flake8 "$@" src bin
}
main