* Rename existing wrapper, to match contract name * base contract: make member var public * json_schemas.py: stop storing copies of schemas! * .gitignore generated erc20_token.py wrapper * json schemas: allow uppercase digits in address * existing exchange wrapper: re-order methods to match method order in Solidity contract, to reduce noise in upcoming diffs of newly generated code vs. old manually-written code. * existing exchange wrapper: rename method params To match contract method param names * existing exchange wrapper: remove redundant member * existing exchange wrapper: make signatures bytes Not strings. * abi-gen/test-cli: show context on diff failure * abi-gen-templates/Py: fix broken event interface Previous changes had removed the `token_address` parameter from all generated methods, but this instance was missed because there weren't tests/examples using events for the first contract for which wrappers were generated (ERC20Token). * abi-gen: remove unused method parameters * abi-gen: convert Py method params to snake case * abi-gen: rewrite Python tuple handling * python-generated-wrappers: include Exchange * abi-gen-templates/Py: easy linter fixes * abi-gen-templates/Py: satisfy docstring linters * abi-gen-templates/Py: normalize bytes before use * contract_wrappers.py: replace Exchange w/generated * contract_wrappers.py: rm manually written Exchange * contract_wrappers.py/doctest: rename variables * abi-gen: fix misspelling in docstring Co-Authored-By: Fabio B <me@fabioberger.com> * Py docs: error on warning, and test build in CI * abi-gen: doc Py bytes params as requiring UTF-8 * abi-gen: git mv diff.sh test-cli/ * abi-gen: put Py wrapper in module folder, not file This leaves space for user-defined additions to the same module, such as for custom types, as shown herein. * abi-gen: customizable param validation for Python * contract_wrappers.py: JSON schema Order validation * CircleCI Build Artifacts For abi-gen command-line test output, for generated Python contract wrappers as output by abi-gen, for generated Python contract wrappers as reformatted and included in the Python package area, and for the "build" output folder in each Python package, which includes the generated documentation. * CHANGELOG updates for all components * abi-gen: grammar in comments Co-Authored-By: Fabio B <me@fabioberger.com> * abi-gen: CHANGELOG spelling correction Co-Authored-By: Fabio B <me@fabioberger.com> * order_utils.py: reverse (chronological) CHANGELOG * abi-gen-templates: reset CHANGELOG patch version * CHANGELOGs: use multiple entries where appropriate * abi-gen: enable devdoc solc output in test-cli * abi-gen-templates/Py: consolidate return type * abi-gen/test-cli: non-pure fixture contract method Added a method to the "dummy" test fixture contract that isn't pure. All of the other prior method cases were pure. * abi-gen/Py: fix const methods missing return type * abi-gen/Py: fix wrong return types on some methods Specifically, wrapper methods wrapping contract methods that modify contract state and return no return value. There was no test case for this. Now there is. * contract_wrappers.py: rm generated code in `clean` * Parallelize Py monorepo scripts (test, lint, etc)
200 lines
5.8 KiB
Python
Executable File
200 lines
5.8 KiB
Python
Executable File
#!/usr/bin/env python
|
|
# coding: utf-8
|
|
|
|
"""setuptools module for sra_client package."""
|
|
|
|
import subprocess # nosec
|
|
import distutils.command.build_py
|
|
from urllib.request import urlopen
|
|
from urllib.error import URLError
|
|
|
|
from setuptools import setup, find_packages # noqa: H301
|
|
from setuptools.command.test import test as TestCommand
|
|
|
|
NAME = "0x-sra-client"
|
|
VERSION = "2.0.0"
|
|
# To install the library, run the following
|
|
#
|
|
# python setup.py install
|
|
#
|
|
# prerequisite: setuptools
|
|
# http://pypi.python.org/pypi/setuptools
|
|
|
|
with open("README.md", "r") as file_handle:
|
|
README_MD = file_handle.read()
|
|
|
|
REQUIRES = ["urllib3 >= 1.15", "six >= 1.10", "certifi", "python-dateutil"]
|
|
|
|
|
|
class TestCommandExtension(TestCommand):
|
|
"""Run pytest tests."""
|
|
|
|
def run_tests(self):
|
|
"""Invoke pytest."""
|
|
import pytest
|
|
|
|
exit(pytest.main(["--doctest-modules"]))
|
|
|
|
|
|
class TestPublishCommand(distutils.command.build_py.build_py):
|
|
"""Custom command to publish to test.pypi.org."""
|
|
|
|
description = (
|
|
"Publish dist/* to test.pypi.org. Run sdist & bdist_wheel first."
|
|
)
|
|
|
|
def run(self):
|
|
"""Run twine to upload to test.pypi.org."""
|
|
subprocess.check_call( # nosec
|
|
(
|
|
"twine upload --repository-url https://test.pypi.org/legacy/"
|
|
+ " --verbose dist/*"
|
|
).split()
|
|
)
|
|
|
|
|
|
class StartTestRelayerCommand(distutils.command.build_py.build_py):
|
|
"""Custom command to boot up a local 0x-launch-kit-backend in docker."""
|
|
|
|
description = "Run launch-kit daemon to support tests."
|
|
|
|
def run(self):
|
|
"""Run `docker-compose up`."""
|
|
subprocess.call( # nosec
|
|
("docker-compose -f test/relayer/docker-compose.yml up -d").split()
|
|
)
|
|
launch_kit_ready = False
|
|
print("Waiting for relayer to start accepting connections...", end="")
|
|
while not launch_kit_ready:
|
|
try:
|
|
launch_kit_ready = (
|
|
urlopen( # nosec
|
|
"http://localhost:3000/v2/asset_pairs"
|
|
).getcode()
|
|
== 200
|
|
)
|
|
except URLError:
|
|
continue
|
|
print("done")
|
|
|
|
|
|
class StopTestRelayerCommand(distutils.command.build_py.build_py):
|
|
"""Custom command to tear down the 0x-launch-kit-backend test relayer."""
|
|
|
|
description = "Tear down launch-kit daemon."
|
|
|
|
def run(self):
|
|
"""Run `docker-compose down`."""
|
|
subprocess.call( # nosec
|
|
("docker-compose -f test/relayer/docker-compose.yml down").split()
|
|
)
|
|
|
|
|
|
class LintCommand(distutils.command.build_py.build_py):
|
|
"""Custom setuptools command class for running linters."""
|
|
|
|
description = "Run linters"
|
|
|
|
def run(self):
|
|
"""Run linter shell commands."""
|
|
lint_targets = "test src/zero_ex/sra_client/__init__.py setup.py"
|
|
lint_commands = [
|
|
# formatter:
|
|
(
|
|
f"black --line-length 79 --check --diff test {lint_targets}"
|
|
).split(),
|
|
# style guide checker (formerly pep8):
|
|
f"pycodestyle {lint_targets}".split(),
|
|
# docstring style checker:
|
|
f"pydocstyle {lint_targets}".split(),
|
|
# static type checker:
|
|
f"bandit -r {lint_targets}".split(),
|
|
# general linter:
|
|
f"pylint {lint_targets}".split(),
|
|
# pylint takes relatively long to run, so it runs last, to enable
|
|
# fast failures.
|
|
]
|
|
|
|
for lint_command in lint_commands:
|
|
print(
|
|
"Running lint command `", " ".join(lint_command).strip(), "`"
|
|
)
|
|
subprocess.check_call(lint_command) # nosec
|
|
|
|
|
|
class PublishCommand(distutils.command.build_py.build_py):
|
|
"""Custom command to publish to pypi.org."""
|
|
|
|
description = "Publish dist/* to pypi.org. Run sdist & bdist_wheel first."
|
|
|
|
def run(self):
|
|
"""Run twine to upload to pypi.org."""
|
|
subprocess.check_call("twine upload dist/*".split()) # nosec
|
|
|
|
|
|
class PublishDocsCommand(distutils.command.build_py.build_py):
|
|
"""Custom command to publish docs to S3."""
|
|
|
|
description = (
|
|
"Publish docs to "
|
|
+ "http://0x-sra-client-py.s3-website-us-east-1.amazonaws.com/"
|
|
)
|
|
|
|
def run(self):
|
|
"""Run npm package `discharge` to build & upload docs."""
|
|
subprocess.check_call("discharge deploy".split()) # nosec
|
|
|
|
|
|
setup(
|
|
name=NAME,
|
|
version=VERSION,
|
|
description="Standard Relayer REST API Client",
|
|
author_email="",
|
|
url=(
|
|
"https://github.com/0xproject/0x-monorepo/tree/development"
|
|
"/python-packages/sra_client"
|
|
),
|
|
keywords=["OpenAPI", "OpenAPI-Generator", "Standard Relayer REST API"],
|
|
install_requires=REQUIRES,
|
|
namespace_packages=["zero_ex"],
|
|
packages=find_packages("src"),
|
|
package_dir={"": "src"},
|
|
include_package_data=True,
|
|
long_description=README_MD,
|
|
long_description_content_type="text/markdown",
|
|
cmdclass={
|
|
"test_publish": TestPublishCommand,
|
|
"publish": PublishCommand,
|
|
"start_test_relayer": StartTestRelayerCommand,
|
|
"stop_test_relayer": StopTestRelayerCommand,
|
|
"lint": LintCommand,
|
|
"publish_docs": PublishDocsCommand,
|
|
"test": TestCommandExtension,
|
|
},
|
|
extras_require={
|
|
"dev": [
|
|
"0x-contract-artifacts",
|
|
"0x-contract-addresses",
|
|
"0x-order-utils",
|
|
"0x-web3",
|
|
"bandit",
|
|
"black",
|
|
"coverage",
|
|
"coveralls",
|
|
"pycodestyle",
|
|
"pydocstyle",
|
|
"pylint",
|
|
"pytest",
|
|
"sphinx",
|
|
"sphinx-autodoc-typehints",
|
|
]
|
|
},
|
|
command_options={
|
|
"build_sphinx": {
|
|
"source_dir": ("setup.py", "src"),
|
|
"build_dir": ("setup.py", "build/docs"),
|
|
"warning_is_error": ("setup.py", "true"),
|
|
}
|
|
},
|
|
)
|