To start contributing you must read all the following.
First you must fork/clone repo from github:
$ git clone firstname.lastname@example.org:aio-libs/aioredis.git
Next, you should install all python dependencies, it is as easy as running single command:
$ make devel
this command will install:
sphinxfor building documentation;
pytestfor running tests;
flake8for code linting;
- and few other packages.
Code must be pep8 compliant.
You can check it with following command:
$ make flake
You can run tests in any of the following ways:
# will run tests in a verbose mode $ make test # or $ py.test # will run tests with coverage report $ make cov # or $ py.test --cov
Running SSL tests requires following additional programs to be installed:
openssl– to generate test key and certificate;
socat– to make SSL proxy;
To install these on Ubuntu and generate test key & certificate run:
$ sudo apt-get install socat openssl $ make certificate
Different Redis server versions¶
To run tests against different redises use
--redis-server command line
$ py.test --redis-server=/path/to/custom/redis-server
Tests are located under
Pure Python 3.5 tests (ie the ones using
await syntax) must be
py35_, for instance see:
There is a number of fixtures that can be used to write tests:
Current event loop used for test. This is a function-scope fixture. Using this fixture will always create new event loop and set global one to None.
def test_with_loop(loop): @asyncio.coroutine def do_something(): pass loop.run_until_complete(do_something())
Finds and returns free TCP port.
def test_bind(unused_port): port = unused_port() assert 1024 < port <= 65535
aioredis.create_connection(). Only difference is that it registers connection to be closed after test case, so you should not be worried about unclosed connections.
Redis client instance.
Redis server instance info. Namedtuple with following properties:
- server instance name.
- Bind port.
- Bind unixsocket path.
- Redis server version tuple.
Second predefined Redis server instance info.
Start Redis server instance. Redis instances are cached by name.
Returns: server info tuple, see
Return type: tuple
Marks test with minimum redis version to run.
@pytest.redis_version(3, 2, 0, reason="HSTRLEN new in redis 3.2.0") def test_hstrlen(redis): pass
Adopted version of
unittest.TestCase.assertEqual(), see it for details.
def test_logs(create_connection, server): with pytest.logs('aioredis', 'DEBUG') as cm: conn yield from create_connection(server.tcp_address) assert cm.output.startswith( 'DEBUG:aioredis:Creating tcp connection')
assert_almost_equal(first, second, places=None, msg=None, delta=None)¶
Adopted version of