2014-08-27 18:17:22 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2018-10-21 13:18:30 +02:00
|
|
|
# Copyright 2014-2017 OpenMarket Ltd
|
|
|
|
# Copyright 2017 Vector Creations Ltd
|
|
|
|
# Copyright 2017-2018 New Vector Ltd
|
2014-08-13 04:32:18 +02:00
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
2015-05-06 12:41:19 +02:00
|
|
|
import glob
|
2014-08-12 16:10:52 +02:00
|
|
|
import os
|
|
|
|
|
2020-10-15 16:45:13 +02:00
|
|
|
from setuptools import Command, find_packages, setup
|
2015-02-10 18:42:36 +01:00
|
|
|
|
2016-12-09 19:00:58 +01:00
|
|
|
here = os.path.abspath(os.path.dirname(__file__))
|
|
|
|
|
|
|
|
|
2016-12-09 17:19:46 +01:00
|
|
|
# Some notes on `setup.py test`:
|
|
|
|
#
|
|
|
|
# Once upon a time we used to try to make `setup.py test` run `tox` to run the
|
|
|
|
# tests. That's a bad idea for three reasons:
|
|
|
|
#
|
|
|
|
# 1: `setup.py test` is supposed to find out whether the tests work in the
|
|
|
|
# *current* environmentt, not whatever tox sets up.
|
|
|
|
# 2: Empirically, trying to install tox during the test run wasn't working ("No
|
|
|
|
# module named virtualenv").
|
|
|
|
# 3: The tox documentation advises against it[1].
|
|
|
|
#
|
|
|
|
# Even further back in time, we used to use setuptools_trial [2]. That has its
|
|
|
|
# own set of issues: for instance, it requires installation of Twisted to build
|
|
|
|
# an sdist (because the recommended mode of usage is to add it to
|
|
|
|
# `setup_requires`). That in turn means that in order to successfully run tox
|
|
|
|
# you have to have the python header files installed for whichever version of
|
|
|
|
# python tox uses (which is python3 on recent ubuntus, for example).
|
|
|
|
#
|
|
|
|
# So, for now at least, we stick with what appears to be the convention among
|
|
|
|
# Twisted projects, and don't attempt to do anything when someone runs
|
|
|
|
# `setup.py test`; instead we direct people to run `trial` directly if they
|
|
|
|
# care.
|
|
|
|
#
|
|
|
|
# [1]: http://tox.readthedocs.io/en/2.5.0/example/basic.html#integration-with-setup-py-test-command
|
|
|
|
# [2]: https://pypi.python.org/pypi/setuptools_trial
|
2016-12-09 19:00:58 +01:00
|
|
|
class TestCommand(Command):
|
|
|
|
user_options = []
|
2016-12-09 17:19:46 +01:00
|
|
|
|
2016-12-09 19:00:58 +01:00
|
|
|
def initialize_options(self):
|
|
|
|
pass
|
2016-12-09 17:19:46 +01:00
|
|
|
|
2016-12-09 19:00:58 +01:00
|
|
|
def finalize_options(self):
|
|
|
|
pass
|
2015-02-10 18:42:36 +01:00
|
|
|
|
2016-12-09 19:00:58 +01:00
|
|
|
def run(self):
|
2019-06-20 11:32:02 +02:00
|
|
|
print(
|
|
|
|
"""Synapse's tests cannot be run via setup.py. To run them, try:
|
2016-12-09 19:00:58 +01:00
|
|
|
PYTHONPATH="." trial tests
|
2019-06-20 11:32:02 +02:00
|
|
|
"""
|
|
|
|
)
|
|
|
|
|
2015-02-10 18:42:36 +01:00
|
|
|
|
2015-02-10 19:25:54 +01:00
|
|
|
def read_file(path_segments):
|
2015-02-10 18:42:36 +01:00
|
|
|
"""Read a file from the package. Takes a list of strings to join to
|
|
|
|
make the path"""
|
2015-02-10 19:25:54 +01:00
|
|
|
file_path = os.path.join(here, *path_segments)
|
2015-02-10 18:42:36 +01:00
|
|
|
with open(file_path) as f:
|
|
|
|
return f.read()
|
|
|
|
|
|
|
|
|
2015-02-10 19:25:54 +01:00
|
|
|
def exec_file(path_segments):
|
2015-02-10 18:42:36 +01:00
|
|
|
"""Execute a single python file to get the variables defined in it"""
|
|
|
|
result = {}
|
2015-02-10 19:25:54 +01:00
|
|
|
code = read_file(path_segments)
|
2015-02-10 18:42:36 +01:00
|
|
|
exec(code, result)
|
|
|
|
return result
|
|
|
|
|
2015-08-26 13:45:29 +02:00
|
|
|
|
2015-02-10 18:42:36 +01:00
|
|
|
version = exec_file(("synapse", "__init__.py"))["__version__"]
|
|
|
|
dependencies = exec_file(("synapse", "python_dependencies.py"))
|
|
|
|
long_description = read_file(("README.rst",))
|
2014-08-12 16:10:52 +02:00
|
|
|
|
2019-06-20 11:32:02 +02:00
|
|
|
REQUIREMENTS = dependencies["REQUIREMENTS"]
|
|
|
|
CONDITIONAL_REQUIREMENTS = dependencies["CONDITIONAL_REQUIREMENTS"]
|
|
|
|
ALL_OPTIONAL_REQUIREMENTS = dependencies["ALL_OPTIONAL_REQUIREMENTS"]
|
2018-12-21 15:37:26 +01:00
|
|
|
|
|
|
|
# Make `pip install matrix-synapse[all]` install all the optional dependencies.
|
|
|
|
CONDITIONAL_REQUIREMENTS["all"] = list(ALL_OPTIONAL_REQUIREMENTS)
|
|
|
|
|
2020-09-23 12:45:37 +02:00
|
|
|
# Developer dependencies should not get included in "all".
|
|
|
|
#
|
|
|
|
# We pin black so that our tests don't start failing on new releases.
|
|
|
|
CONDITIONAL_REQUIREMENTS["lint"] = [
|
2021-01-26 12:36:12 +01:00
|
|
|
"isort==5.7.0",
|
2020-09-23 12:45:37 +02:00
|
|
|
"black==19.10b0",
|
|
|
|
"flake8-comprehensions",
|
|
|
|
"flake8",
|
|
|
|
]
|
|
|
|
|
2020-10-21 12:45:01 +02:00
|
|
|
CONDITIONAL_REQUIREMENTS["mypy"] = ["mypy==0.790", "mypy-zope==0.2.8"]
|
2020-10-20 13:55:21 +02:00
|
|
|
|
2020-09-23 12:45:37 +02:00
|
|
|
# Dependencies which are exclusively required by unit test code. This is
|
|
|
|
# NOT a list of all modules that are necessary to run the unit tests.
|
|
|
|
# Tests assume that all optional dependencies are installed.
|
|
|
|
#
|
|
|
|
# parameterized_class decorator was introduced in parameterized 0.7.0
|
|
|
|
CONDITIONAL_REQUIREMENTS["test"] = ["mock>=2.0", "parameterized>=0.7.0"]
|
2018-12-21 15:37:26 +01:00
|
|
|
|
2014-08-12 16:10:52 +02:00
|
|
|
setup(
|
2014-11-20 11:51:04 +01:00
|
|
|
name="matrix-synapse",
|
2015-02-10 18:42:36 +01:00
|
|
|
version=version,
|
2014-11-04 16:18:43 +01:00
|
|
|
packages=find_packages(exclude=["tests", "tests.*"]),
|
2018-10-21 13:18:30 +02:00
|
|
|
description="Reference homeserver for the Matrix decentralised comms protocol",
|
2018-12-21 15:37:26 +01:00
|
|
|
install_requires=REQUIREMENTS,
|
|
|
|
extras_require=CONDITIONAL_REQUIREMENTS,
|
2014-08-12 16:10:52 +02:00
|
|
|
include_package_data=True,
|
2014-11-17 17:36:24 +01:00
|
|
|
zip_safe=False,
|
2015-02-10 18:42:36 +01:00
|
|
|
long_description=long_description,
|
2021-01-20 22:00:59 +01:00
|
|
|
long_description_content_type="text/x-rst",
|
2019-06-20 11:32:02 +02:00
|
|
|
python_requires="~=3.5",
|
2019-06-12 13:31:59 +02:00
|
|
|
classifiers=[
|
2019-06-20 11:32:02 +02:00
|
|
|
"Development Status :: 5 - Production/Stable",
|
|
|
|
"Topic :: Communications :: Chat",
|
|
|
|
"License :: OSI Approved :: Apache Software License",
|
|
|
|
"Programming Language :: Python :: 3 :: Only",
|
|
|
|
"Programming Language :: Python :: 3.5",
|
|
|
|
"Programming Language :: Python :: 3.6",
|
|
|
|
"Programming Language :: Python :: 3.7",
|
2020-06-01 20:45:01 +02:00
|
|
|
"Programming Language :: Python :: 3.8",
|
2020-10-28 00:24:33 +01:00
|
|
|
"Programming Language :: Python :: 3.9",
|
2019-06-12 13:31:59 +02:00
|
|
|
],
|
2015-05-06 12:41:19 +02:00
|
|
|
scripts=["synctl"] + glob.glob("scripts/*"),
|
2019-06-20 11:32:02 +02:00
|
|
|
cmdclass={"test": TestCommand},
|
2014-08-12 16:10:52 +02:00
|
|
|
)
|