.. | ||
cassettes | ||
__init__.py | ||
conftest.py | ||
image.jpg | ||
README.markdown | ||
setup.sql | ||
test_account.py | ||
test_auth.py | ||
test_constructor.py | ||
test_create_app.py | ||
test_domain_blocks.py | ||
test_filters.py | ||
test_follow_requests.py | ||
test_hooks.py | ||
test_instance.py | ||
test_lists.py | ||
test_media.py | ||
test_notifications.py | ||
test_pagination.py | ||
test_push.py | ||
test_reports.py | ||
test_search.py | ||
test_status.py | ||
test_streaming.py | ||
test_timeline.py |
Running
To run this test suite, install the testing dependencies:
pip install -e .[test]
Then, run pytest
.
If you wish to check test coverage:
pytest --cov=mastodon
And if you want a complete HTML coverage report:
pytest --cov=mastodon --cov-report html:coverage
# then open coverage/index.html in your favourite web browser
Note that some tests are slightly unstable, as they require sidekiq to do things at the right time, and will thus sometimes break.
Contributing
This test suite uses VCR.py to record requests to Mastodon and replay them in successive runs.
If you want to add or change tests, you will need a Mastodon development server running on http://localhost:3000
, with the default admin
user and default password.
It also needs a test OAuth app and an additional test user to be set up by applying the provided setup.sql
to Mastodon's database:
psql -d mastodon_development < tests/setup.sql
Tests that send requests to Mastodon should be marked as needing VCR with the pytest.mark.vcr
decorator.
import pytest
@pytest.mark.vcr()
def test_fun_new_feature(api):
foo = api.fun_new_feature()
assert foo = "bar"