forked from spinus/sphinxcontrib-images
-
Notifications
You must be signed in to change notification settings - Fork 17
/
release-to-pypi.sh
executable file
·102 lines (70 loc) · 2.79 KB
/
release-to-pypi.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
#!/bin/sh
V1=$(sed -nE "s/^.*version.*=.*([0-9]+\.[0-9]+\.[0-9]+(\.[a-z0-9]+)?).*$/\1/p" setup.py)
V2=$(sed -nE "s/^.*version.*=.*([0-9]+\.[0-9]+\.[0-9]+(\.[a-z0-9]+)?).*$/\1/p" sphinxcontrib/images.py)
SUB=$(git submodule status sphinxcontrib_images_lightbox2/lightbox2 | cut -c1)
printf "\n## RELEASE SPHINXCONTRIB-IMAGES TO PYPI ##\n\n"
printf "# VERSION CHECK #\n"
printf "setup.py: %s\n" "$V1"
printf "sphinxcontrib/images.py: %s\n" "$V2"
if [ "$V1" != "$V2" ]; then
printf "ERROR: versions do _not_ match\n\n"
else
printf "SUCCESS: Versions match\n\n"
fi
printf "# SUBMODULE STATUS #\n"
if [ "$SUB" = "-" ]; then
echo "ERROR: lightbox2 submodule _not_ initialized"
else
echo "SUCCESS: lightbox2 submodule initialized"
fi
read -p "Press any key to proceed to instructions ..." -n1 -s
cat <<STEPS
# 1. Clone lightbox2 submodule:
git submodule update --init --recursive
# 2. Create a virtual environment and install twine
python -m venv venv-twine
source venv-twine/bin/activate
pip install twine
# 3. Test release to TestPyPI
- Requires registration at https://test.pypi.org/account/register/
- Bump version by editing setup.py and sphinxcontrib/images.py
e.g. from 0.9.2 to 0.9.3.pre1 (use .pre2 second test release etc.)
- Remove old distributions/builds
rm -r dist/
- Build the distribution:
python setup.py sdist bdist_wheel
- Upload to TestPyPI
twine upload -r testpypi dist/*
# 4. Test the TestPyPI-release
- Make a new virtual environment
python -m venv venv-0.9.3.pre1
- Install the prerelease (see note [1])
pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple sphinxcontrib-images
- Verify the version installed:
pip freeze | grep sphinxcontrib-images
- Verify the prereleased package can build the package docs in docs/
cd docs/
make html
- If anything fails repeat step 3. and 4.
# 5. Final test release to TestPyPI
- Repeat step 3. and 4. but without .preN in the version number,
e.g. change 0.9.3.pre1 to 0.9.3
# 6. Release to PyPI
- Requires user with maintainer status on the package
https://pypi.org/project/sphinxcontrib-images/
- Upload to PyPI
twine upload dist/*
# 7. Commit released version, tag and push
git add setup.py sphinxcontrib/images.py
git commit -m "Version bumped to a.b.c"
git tag -a a.b.c -m "release a.b.c"
git push origin master
git push origin a.b.c
[1] Version 0.9.3.pre1 in setup.py is converted to 0.9.3rc1 in TestPyPI
so to install a specific version of the prerelese use
'sphinxcontrib-images==0.9.3rc1' with pip.
If you release to TestPyPI in this order: 0.9.3.pre1 - 0.9.3.pre2 - 0.9.3
then you should be able to test all three versions by simply installing the
package without stating the version since 0.9.3.pre2 > 0.9.3.pre1 and
0.9.3 > 0.9.3.pre2
STEPS