From 9a6705d59c9fb995dd63d400cf08dc3669216296 Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 14:56:38 +1000 Subject: [PATCH 1/8] Py3 preparation: Universal wheel builds --- setup.cfg | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 setup.cfg diff --git a/setup.cfg b/setup.cfg new file mode 100644 index 00000000..79bc6784 --- /dev/null +++ b/setup.cfg @@ -0,0 +1,5 @@ +[bdist_wheel] +# This flag says that the code is written to work on both Python 2 and Python +# 3. If at all possible, it is good practice to do this. If you cannot, you +# will need to generate wheels for each Python version that you support. +universal=1 From ef77a1a3b67eda3f0b0b235d710ef9d8db0c69bf Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 14:57:30 +1000 Subject: [PATCH 2/8] Prepare tox.ini for Django 1.11 and Python3 --- tox.ini | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/tox.ini b/tox.ini index 9e2f12a4..b0bc68b6 100644 --- a/tox.ini +++ b/tox.ini @@ -1,10 +1,16 @@ [tox] -envlist = py27-django{17,18,19,110} +# Django 1.11 and Python 3 aren't supported yet +envlist = + py27-django{18,19,110} +# py32-django{18} +# py33-django{18} +# py{34,35}-django{19,110,111} +# py{36}-django{111} [testenv] -commands = python testrunner.py +commands = python setup.py test deps = - django17: Django < 1.8 - django18: Django < 1.9 - django19: Django < 1.10 - django110: Django < 1.11 + django18: Django>=1.8,<1.9 + django19: Django>=1.9,<1.10 + django110: Django>=1.10,<1.11 + django111: Django>=1.11,<2.0 From 15b1b754e01044723a159524e9ca5e7a618c144f Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 14:57:41 +1000 Subject: [PATCH 3/8] Make setup.py conform to common expectations. * Separate `install_requires` and `tests_require` * Add trove classifiers including Python and Django supported versions * Fix license name * Dropped workaround for an ancient Python bug which doesn't apply anyway (not using multiprocessing or atexit) --- setup.py | 95 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 47 insertions(+), 48 deletions(-) diff --git a/setup.py b/setup.py index 9e6f1aa3..655c78d0 100644 --- a/setup.py +++ b/setup.py @@ -1,49 +1,48 @@ -from distutils.core import setup -from setuptools import find_packages -import re - -# http://bugs.python.org/issue15881 -try: - import multiprocessing -except ImportError: - pass - - -def parse_requirements(file_name): - requirements = [] - for line in open(file_name, 'r').read().split('\n'): - if re.match(r'(\s*#)|(\s*$)', line): - continue - if re.match(r'\s*-e\s+', line): - requirements.append(re.sub(r'\s*-e\s+.*#egg=(.*)$', r'\1', line)) - elif re.match(r'\s*-f\s+', line): - pass - else: - requirements.append(line) - - return requirements - - -def parse_dependency_links(file_name): - dependency_links = [] - for line in open(file_name, 'r').read().split('\n'): - if re.match(r'\s*-[ef]\s+', line): - dependency_links.append(re.sub(r'\s*-[ef]\s+', '', line)) - - return dependency_links - - -setup(name='django-experiments', - version='1.2.0', - description='Python Django AB Testing Framework', - author='Mixcloud', - author_email='technical@mixcloud.com', - url='https://github.com/mixcloud/django-experiments', - packages=find_packages(exclude=["example_project"]), - include_package_data=True, - license="MIT license, see LICENSE file", - install_requires=parse_requirements('requirements.txt'), - dependency_links=parse_dependency_links('requirements.txt'), - long_description=open('README.rst').read(), - test_suite="testrunner.runtests", +import codecs # to use a consistent encoding +from os import path +from setuptools import setup, find_packages # prefer setuptools over distutils + + +# Get the long description from the README file +PATH = path.abspath(path.dirname(__file__)) +with codecs.open(path.join(PATH, 'README.rst'), encoding='utf-8') as f: + LONG_DESCRIPTION = f.read() + +setup( + name='django-experiments', + version='1.2.0', + description='Python Django AB Testing Framework', + long_description=LONG_DESCRIPTION, + author='Mixcloud', + author_email='technical@mixcloud.com', + url='https://github.com/mixcloud/django-experiments', + packages=find_packages(exclude=["example_project"]), + include_package_data=True, + license='MIT', + install_requires=[ + 'django>=1.7.0', + 'django-modeldict-yplan>=1.5.0', + 'jsonfield>=1.0.3', + 'redis>=2.4.9', + ], + tests_require=[ + 'mock>=1.0.1', + 'tox>=2.3.1', + ], + test_suite="testrunner.runtests", + classifiers=[ + 'Development Status :: 5 - Production/Stable', + 'Intended Audience :: Developers', + 'License :: OSI Approved :: MIT License', + 'Topic :: Internet :: WWW/HTTP', + 'Topic :: Software Development :: Libraries', + 'Programming Language :: Python :: 2 :: Only', + 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.7', + 'Framework :: Django', + 'Framework :: Django :: 1.7', + 'Framework :: Django :: 1.8', + 'Framework :: Django :: 1.9', + 'Framework :: Django :: 1.10', + ], ) From 930a0565882a4afc537cada9ede2f95755d85f5e Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 15:02:15 +1000 Subject: [PATCH 4/8] Add new release notes to Changelog --- README.rst | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/README.rst b/README.rst index 6faba853..a0dec71b 100644 --- a/README.rst +++ b/README.rst @@ -26,7 +26,7 @@ pip is still the recommended way to install dependencies: :: - pip install -r requirements.txt + pip install -e . Dependencies ------------ @@ -35,7 +35,7 @@ Dependencies - `jsonfield `_ - `django-modeldict `_ -(Detailed list in requirements.txt) +(Detailed list in setup.py) It also requires 'django.contrib.humanize' to be in INSTALLED_APPS. @@ -340,6 +340,18 @@ See conf.py for other settings Changelog --------- +UNRELEASED +~~~~~~~~~~ + - Conform to common expectations in `setup.py`: + - Separate `install_requires` and `tests_require` (not reading from `requirements.txt`) + - Add trove classifiers including Python and Django supported versions + - Fix license name (from "MIT license, see LICENSE file" to "MIT") + - Make `setup.py` ready for Python 3 (read `README.rst` using codecs module) + - Dropped an irrelevant workaround for ancient Python bugs + - Add `setup.cfg` to support building of universal wheels (preparing for Python 3) + - Tox runs `python setup.py test` (honouring both `install_requires` and `tests_require`) + - Prepared `tox.ini` for Python 3 and Django 1.11 compatibility + 1.2.0 ~~~~~ - Add support for Django 1.10 (Thanks to @Kobold) @@ -384,6 +396,7 @@ Changelog Bumping version to 1.0.0 because django-experiments is definitely production ready but also due to backwards incompatible changes that have been merged in. + - Django 1.7 and 1.8 support (including custom user models) - Fixed numerous bugs to do with retention goals - before this update they are not trustworthy. See retention section below for more information. - Fixed bug caused by the participant cache on request From 00bd8d4c467fa700e5f9b9b94baf8b6e3883c5cf Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 15:06:03 +1000 Subject: [PATCH 5/8] Remove unused requirements.txt --- requirements.txt | 6 ------ 1 file changed, 6 deletions(-) delete mode 100644 requirements.txt diff --git a/requirements.txt b/requirements.txt deleted file mode 100644 index 4fe2f77d..00000000 --- a/requirements.txt +++ /dev/null @@ -1,6 +0,0 @@ -redis>=2.4.9 -django>=1.7.0 -django-modeldict-yplan>=1.5.0 -jsonfield>=1.0.3 -mock>=1.0.1 -tox>=2.3.1 From 2e1229d8bab751d45cc33a8ccc79047963fa2f60 Mon Sep 17 00:00:00 2001 From: Tyson Clugg Date: Tue, 16 May 2017 15:16:16 +1000 Subject: [PATCH 6/8] Remove requirements.txt from setup manifest. --- MANIFEST.in | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/MANIFEST.in b/MANIFEST.in index c15ff723..a706ff1a 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,2 +1,2 @@ -include LICENSE README.rst requirements.txt -recursive-include experiments *.py *.html *.js *.css *.png *.jpg \ No newline at end of file +include LICENSE README.rst +recursive-include experiments *.py *.html *.js *.css *.png *.jpg From 2211a137e4c9718d7c499c2a85982ea1f8ea7091 Mon Sep 17 00:00:00 2001 From: Mat Clayton Date: Tue, 16 May 2017 07:31:19 +0100 Subject: [PATCH 7/8] Update tox.ini --- tox.ini | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tox.ini b/tox.ini index b0bc68b6..c3dceb92 100644 --- a/tox.ini +++ b/tox.ini @@ -1,7 +1,7 @@ [tox] # Django 1.11 and Python 3 aren't supported yet envlist = - py27-django{18,19,110} + py27-django{18,19,110,111} # py32-django{18} # py33-django{18} # py{34,35}-django{19,110,111} From 15fd338948f5670d6a3e91d4e4407bd0082c09da Mon Sep 17 00:00:00 2001 From: Mat Clayton Date: Tue, 16 May 2017 07:31:42 +0100 Subject: [PATCH 8/8] Update setup.py --- setup.py | 1 + 1 file changed, 1 insertion(+) diff --git a/setup.py b/setup.py index 655c78d0..7904eb81 100644 --- a/setup.py +++ b/setup.py @@ -44,5 +44,6 @@ 'Framework :: Django :: 1.8', 'Framework :: Django :: 1.9', 'Framework :: Django :: 1.10', + 'Framework :: Django :: 1.11', ], )