mirror of
https://github.com/torproject/stem.git
synced 2024-12-04 16:36:28 +00:00
179 lines
5.6 KiB
Python
179 lines
5.6 KiB
Python
#!/usr/bin/env python
|
|
# Copyright 2012-2020, Damian Johnson and The Tor Project
|
|
# See LICENSE for licensing information
|
|
#
|
|
# Release Checklist
|
|
# =================
|
|
#
|
|
# * Recache latest information (cache_manual.py and cache_fallback_directories.py)
|
|
#
|
|
# * Test with python3 and pypy.
|
|
# |- If using tox run...
|
|
# |
|
|
# | % tox -- --all --target RUN_ALL,ONLINE
|
|
# |
|
|
# | Otherwise, for each interpreter run...
|
|
# |
|
|
# | % [python_interpreter] run_tests.py --all --target RUN_ALL,ONLINE
|
|
# |
|
|
# |- Pypy test instructions for ubuntu are...
|
|
# |
|
|
# | % sudo apt-get install pypy
|
|
# | % wget https://bootstrap.pypa.io/get-pip.py
|
|
# | % pypy get-pip.py --user
|
|
# | % ~/.local/bin/pip install mock pycodestyle pyflakes --user
|
|
# | % pypy ./run_tests.py --all
|
|
# |
|
|
# +- Some version of python 3.x should be available in your platform's
|
|
# repositories. To test against a specific version on ubuntu try the
|
|
# following. In this example, Python 3.7...
|
|
#
|
|
# % sudo apt-get install build-essential python-dev python-setuptools python-pip python-smbus
|
|
# % sudo apt-get install libncursesw5-dev libgdbm-dev libc6-dev
|
|
# % sudo apt-get install zlib1g-dev libsqlite3-dev tk-dev
|
|
# % sudo apt-get install libssl-dev openssl libffi-dev
|
|
#
|
|
# % wget https://www.python.org/ftp/python/3.7.0/Python-3.7.0.tgz
|
|
# % tar -xzf Python-3.7.0.tgz
|
|
# % mv Python-3.7.0 ~
|
|
#
|
|
# % cd ~/Python-3.7.0
|
|
# % ./configure
|
|
# % make
|
|
#
|
|
# % cd /path/to/stem
|
|
# % ~/Python-3.7.0/python ./run_tests.py --all
|
|
#
|
|
# * Tag the release
|
|
# |- Bump stem's version (in stem/__init__.py and docs/index.rst).
|
|
# |- git commit -a -m "Stem release 1.0.0"
|
|
# |- git tag -u 9ABBEEC6 -m "stem release 1.0.0" 1.0.0 d0bb81a
|
|
# +- git push --tags
|
|
#
|
|
# * Dry-run release on https://pypi.org/project/stem/
|
|
# |- python setup.py sdist --dryrun
|
|
# |- gpg --detach-sig --armor dist/stem-dry-run-1.0.0.tar.gz
|
|
# |- twine upload dist/*
|
|
# +- Check that https://pypi.org/project/stem-dry-run/ looks correct, comparing it to https://pypi.org/project/stem/
|
|
# +- Don't worry about the 'Bug Tracker' being missing. That's an attribute of the project itself.
|
|
#
|
|
# * Final release
|
|
# |- rm dist/*
|
|
# |- python setup.py sdist
|
|
# |- gpg --detach-sig --armor dist/stem-1.0.0.tar.gz
|
|
# +- twine upload dist/*
|
|
#
|
|
# * Contact package maintainers
|
|
# * Announce the release (example: https://blog.torproject.org/blog/stem-release-11)
|
|
|
|
import setuptools
|
|
import os
|
|
import re
|
|
import sys
|
|
|
|
if '--dryrun' in sys.argv:
|
|
DRY_RUN = True
|
|
sys.argv.remove('--dryrun')
|
|
else:
|
|
DRY_RUN = False
|
|
|
|
SUMMARY = 'Stem is a Python controller library that allows applications to interact with Tor (https://www.torproject.org/).'
|
|
DRY_RUN_SUMMARY = 'Ignore this package. This is dry-run release creation to work around PyPI limitations (https://github.com/pypa/packaging-problems/issues/74#issuecomment-260716129).'
|
|
|
|
DESCRIPTION = """
|
|
For tutorials and API documentation see `Stem's homepage <https://stem.torproject.org/>`_.
|
|
|
|
Quick Start
|
|
-----------
|
|
|
|
To install you can either use...
|
|
|
|
::
|
|
|
|
pip install stem
|
|
|
|
... or install from the source tarball. Stem supports Python 3.6 and above.
|
|
|
|
After that, give some `tutorials <https://stem.torproject.org/tutorials.html>`_ a try! For questions or to discuss project ideas we're available on `irc <https://www.torproject.org/about/contact.html.en#irc>`_ and the `tor-dev@ email list <https://lists.torproject.org/cgi-bin/mailman/listinfo/tor-dev>`_.
|
|
""".strip()
|
|
|
|
MANIFEST = """
|
|
include cache_fallback_directories.py
|
|
include cache_manual.py
|
|
include LICENSE
|
|
include README.md
|
|
include MANIFEST.in
|
|
include requirements.txt
|
|
include run_tests.py
|
|
include tox.ini
|
|
graft docs
|
|
graft test
|
|
global-exclude __pycache__
|
|
global-exclude *.orig
|
|
global-exclude *.pyc
|
|
global-exclude *.swp
|
|
global-exclude *.swo
|
|
global-exclude .tox
|
|
global-exclude *~
|
|
recursive-exclude test/data *
|
|
recursive-exclude docs/_build *
|
|
""".strip()
|
|
|
|
# installation requires us to be in our setup.py's directory
|
|
|
|
os.chdir(os.path.dirname(os.path.abspath(__file__)))
|
|
|
|
with open('MANIFEST.in', 'w') as manifest_file:
|
|
manifest_file.write(MANIFEST)
|
|
|
|
|
|
def get_module_info():
|
|
# reads the basic __stat__ strings from our module's init
|
|
|
|
STAT_REGEX = re.compile(r"^__(.+)__ = '(.+)'$")
|
|
result = {}
|
|
cwd = os.path.sep.join(__file__.split(os.path.sep)[:-1])
|
|
|
|
with open(os.path.join(cwd, 'stem', '__init__.py')) as init_file:
|
|
for line in init_file.readlines():
|
|
line_match = STAT_REGEX.match(line)
|
|
|
|
if line_match:
|
|
keyword, value = line_match.groups()
|
|
result[keyword] = value
|
|
|
|
return result
|
|
|
|
|
|
module_info = get_module_info()
|
|
|
|
try:
|
|
setuptools.setup(
|
|
name = 'stem-dry-run' if DRY_RUN else 'stem',
|
|
version = module_info['version'],
|
|
description = DRY_RUN_SUMMARY if DRY_RUN else SUMMARY,
|
|
long_description = DESCRIPTION,
|
|
license = module_info['license'],
|
|
author = module_info['author'],
|
|
author_email = module_info['contact'],
|
|
url = module_info['url'],
|
|
packages = setuptools.find_packages(exclude=['test*']),
|
|
keywords = 'tor onion controller',
|
|
scripts = ['tor-prompt'],
|
|
package_data = {
|
|
'stem': ['cached_fallbacks.cfg', 'cached_manual.sqlite', 'settings.cfg'],
|
|
'stem.interpreter': ['settings.cfg'],
|
|
'stem.util': ['ports.cfg'],
|
|
}, classifiers = [
|
|
'Development Status :: 5 - Production/Stable',
|
|
'Intended Audience :: Developers',
|
|
'License :: OSI Approved :: GNU Lesser General Public License v3 (LGPLv3)',
|
|
'Topic :: Security',
|
|
'Topic :: Software Development :: Libraries :: Python Modules',
|
|
],
|
|
)
|
|
finally:
|
|
for filename in ['MANIFEST.in', 'MANIFEST']:
|
|
if os.path.exists(filename):
|
|
os.remove(filename)
|