Metadata-Version: 2.0
Name: pytest-tornado
Version: 0.4.4
Summary: A py.test plugin providing fixtures and markers to simplify testing of asynchronous tornado applications.
Home-page: https://github.com/eugeniy/pytest-tornado
Author: Eugeniy Kalinin
Author-email: burump@gmail.com
License: Apache License, Version 2.0
Keywords: pytest py.test tornado async asynchronous testing unit tests plugin
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Plugins
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Software Development
Classifier: Topic :: Software Development :: Testing
Requires-Dist: pytest
Requires-Dist: tornado

pytest-tornado
==============

.. image:: https://travis-ci.org/eugeniy/pytest-tornado.svg?branch=master
    :target: https://travis-ci.org/eugeniy/pytest-tornado

.. image:: https://coveralls.io/repos/eugeniy/pytest-tornado/badge.svg
    :target: https://coveralls.io/r/eugeniy/pytest-tornado

A py.test_ plugin providing fixtures and markers to simplify testing
of asynchronous tornado applications.

Installation
------------

::

    pip install pytest-tornado


Example
-------

.. code-block:: python

    import pytest
    import tornado.web

    class MainHandler(tornado.web.RequestHandler):
        def get(self):
            self.write("Hello, world")

    application = tornado.web.Application([
        (r"/", MainHandler),
    ])

    @pytest.fixture
    def app():
        return application

    @pytest.mark.gen_test
    def test_hello_world(http_client, base_url):
        response = yield http_client.fetch(base_url)
        assert response.code == 200


Running tests
-------------

::

    py.test


Fixtures
--------

io_loop
    creates an instance of the `tornado.ioloop.IOLoop`_ for each test case

http_port
    get a port used by the test server

base_url
    get an absolute base url for the test server,
    for example, ``http://localhost:59828``

http_server
    start a tornado HTTP server, you must create an ``app`` fixture,
    which returns the `tornado.web.Application`_ to be tested

http_client
    get an asynchronous HTTP client


Show fixtures provided by the plugin::

    py.test --fixtures


Markers
-------

A ``gen_test`` marker lets you write a coroutine-style tests used with the
`tornado.gen`_ module:

.. code-block:: python

    @pytest.mark.gen_test
    def test_tornado(http_client):
        response = yield http_client.fetch('http://www.tornadoweb.org/')
        assert response.code == 200


Marked tests will time out after 5 seconds. The timeout can be modified by
setting an ``ASYNC_TEST_TIMEOUT`` environment variable,
``--async-test-timeout`` command line argument or a marker argument.

.. code-block:: python

    @pytest.mark.gen_test(timeout=5)
    def test_tornado(http_client):
        yield http_client.fetch('http://www.tornadoweb.org/')


Show markers provided by the plugin::

    py.test --markers


.. _py.test: http://pytest.org/
.. _`tornado.ioloop.IOLoop`: http://tornado.readthedocs.org/en/latest/ioloop.html#ioloop-objects
.. _`tornado.web.Application`: http://tornado.readthedocs.org/en/latest/web.html#application-configuration
.. _`tornado.gen`: http://tornado.readthedocs.org/en/latest/gen.html


