2017-11-27 14:19:21 +01:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
@pytest.mark.vcr()
|
2017-11-27 14:35:02 +01:00
|
|
|
def test_public_tl_anonymous(api_anonymous, status):
|
|
|
|
tl = api_anonymous.timeline_public()
|
2017-11-27 14:19:21 +01:00
|
|
|
assert status['id'] in map(lambda st: st['id'], tl)
|
|
|
|
# although tempting, we can't do
|
|
|
|
# assert status in tl
|
|
|
|
# because the statuses returned in the tl have additional
|
|
|
|
# pagination-related attributes
|
|
|
|
|
|
|
|
@pytest.mark.vcr()
|
2017-11-27 14:35:02 +01:00
|
|
|
def test_public_tl(api, status):
|
|
|
|
tl = api.timeline_public()
|
2017-11-27 14:19:21 +01:00
|
|
|
print(tl[0])
|
|
|
|
assert status['id'] in map(lambda st: st['id'], tl)
|
|
|
|
|
|
|
|
@pytest.mark.vcr()
|
2017-11-27 14:35:02 +01:00
|
|
|
def test_home_tl(api, status):
|
|
|
|
tl = api.timeline_home()
|
2017-11-27 14:19:21 +01:00
|
|
|
assert status['id'] in map(lambda st: st['id'], tl)
|
|
|
|
|
|
|
|
@pytest.mark.vcr()
|
2017-11-27 14:35:02 +01:00
|
|
|
def test_hashtag_tl(api):
|
|
|
|
status = api.status_post('#hoot (hashtag toot)')
|
|
|
|
tl = api.timeline_hashtag('hoot')
|
2017-11-27 14:19:21 +01:00
|
|
|
try:
|
|
|
|
assert status['id'] in map(lambda st: st['id'], tl)
|
|
|
|
finally:
|
2017-11-27 14:35:02 +01:00
|
|
|
api.status_delete(status['id'])
|
2017-11-27 14:35:56 +01:00
|
|
|
|
|
|
|
@pytest.mark.vcr()
|
|
|
|
def test_home_tl_anonymous_throws(api_anonymous):
|
|
|
|
from mastodon.Mastodon import MastodonAPIError
|
|
|
|
with pytest.raises(MastodonAPIError):
|
|
|
|
tl = api_anonymous.timeline_home()
|