Adding tests.

This commit is contained in:
Michael Lazar
2016-07-20 02:16:01 -07:00
parent f688659f84
commit 50a7c4cc44

View File

@@ -234,33 +234,74 @@ def test_content_subreddit_load_more(reddit, terminal):
assert data['title'].startswith(six.text_type(i + 1)) assert data['title'].startswith(six.text_type(i + 1))
def test_content_subreddit_from_name(reddit, terminal): @pytest.mark.parametrize('text,name,order', [
('python', '/r/python', None),
('python/', '/r/python', None),
('r/python', '/r/python', None),
('/r/python', '/r/python', None),
name = '/r/python' ('/r/pics/new', '/r/pics', 'new'),
content = SubredditContent.from_name(reddit, name, terminal.loader) ('/r/pics/hot/', '/r/pics', 'hot'),
assert content.name == '/r/python' ('pics/top', '/r/pics', 'top'),
assert content.order is None ('r/pics/rising', '/r/pics', 'rising'),
('/r/pics/controversial', '/r/pics', 'controversial'),
name = '/domain/python.org' ('/r/pics/top-day', '/r/pics', 'top-day'),
content = SubredditContent.from_name(reddit, name, terminal.loader) ('/r/pics/top-hour', '/r/pics', 'top-hour'),
assert content.name == '/domain/python.org' ('/r/pics/top-month', '/r/pics', 'top-month'),
assert content.order is None ('/r/pics/top-week', '/r/pics', 'top-week'),
('/r/pics/top-year', '/r/pics', 'top-year'),
('/r/pics/top-all', '/r/pics', 'top-all'),
name = '/user/spez' ('/r/pics+linux', '/r/pics+linux', None),
content = SubredditContent.from_name(reddit, name, terminal.loader) ('/r/pics+linux/new', '/r/pics+linux', 'new'),
assert content.name == '/user/spez'
assert content.order is None
name = '/u/multi-mod/m/art' ('front', '/r/front', None),
content = SubredditContent.from_name(reddit, name, terminal.loader) ('/r/front', '/r/front', None),
assert content.name == '/u/multi-mod/m/art' ('/r/front/new', '/r/front', 'new'),
assert content.order is None ('/r/front/top-week', '/r/front', 'top-week'),
# Can submit without the /r/ and with the order in the name ('/user/spez', '/user/spez', None),
name = 'python/top/' ('/u/spez', '/u/spez', None),
content = SubredditContent.from_name(reddit, name, terminal.loader) ('/u/spez/new', '/u/spez', 'new'),
assert content.name == '/r/python' ('/u/spez/top-all', '/u/spez', 'top-all'),
assert content.order == 'top'
('/user/multi-mod/m/art', '/user/multi-mod/m/art', None),
('/u/multi-mod/m/art', '/u/multi-mod/m/art', None),
('/u/multi-mod/m/art/new', '/u/multi-mod/m/art', 'top'),
('/u/multi-mod/m/art/top-all', '/u/multi-mod/m/art', 'top-all'),
('/domain/python.org', '/domain/python.org', None),
('/domain/python.org/new', '/domain/python.org', 'new'),
('/domain/python.org/top-week', '/domain/python.org', 'top-week')])
def test_content_subreddit_from_name(text, name, order, reddit, terminal):
content = SubredditContent.from_name(reddit, text, terminal.loader)
assert content.name == name
assert content.order == order
@pytest.mark.parametrize('text,name,order', [
('/user/me', '/user/me', None),
('/u/me', '/u/me', None),
('/u/me/new', '/u/me', 'new'),
('/u/me/top-week', '/u/me', 'top-week')])
def test_content_subreddit_from_name_authenticated(
text, name, order, reddit, terminal, oauth, refresh_token):
with pytest.raises(exceptions.AccountError):
SubredditContent.from_name(reddit, text, terminal.loader)
# Login and try again
oauth.config.refresh_token = refresh_token
oauth.authorize()
content = SubredditContent.from_name(reddit, text, terminal.loader)
assert content.name == name
assert content.order == order
def test_content_subreddit_from_name_invalid(reddit, terminal):
# Explicit order trumps implicit # Explicit order trumps implicit
name = '/r/python/top' name = '/r/python/top'
@@ -269,11 +310,10 @@ def test_content_subreddit_from_name(reddit, terminal):
assert content.name == '/r/python' assert content.name == '/r/python'
assert content.order == 'new' assert content.order == 'new'
# Invalid order raises an exception for name in ['/r/python/fake', '/r/python/top-fake', '/r/python/new-all']:
name = '/r/python/fake' with terminal.loader():
with terminal.loader(): SubredditContent.from_name(reddit, name, terminal.loader)
SubredditContent.from_name(reddit, name, terminal.loader) assert isinstance(terminal.loader.exception, exceptions.SubredditError)
assert isinstance(terminal.loader.exception, exceptions.SubredditError)
# A couple of edge cases # A couple of edge cases
names = ['', '/', '//', '/////////////////'] names = ['', '/', '//', '/////////////////']
@@ -283,15 +323,20 @@ def test_content_subreddit_from_name(reddit, terminal):
assert isinstance(terminal.loader.exception, assert isinstance(terminal.loader.exception,
praw.errors.InvalidSubreddit) praw.errors.InvalidSubreddit)
# Front page alias
name = '/r/front/rising'
content = SubredditContent.from_name(reddit, name, terminal.loader)
assert content.name == '/r/front'
assert content.order == 'rising'
# Queries @pytest.mark.parametrize('text', [
SubredditContent.from_name(reddit, 'front', terminal.loader, query='pea') '/r/front',
SubredditContent.from_name(reddit, 'python', terminal.loader, query='pea') '/r/python',
'/r/python/top-week',
'/u/spez',
'/user/spez/top-week',
'/u/multi-mod/m/art',
'/u/multi-mod/m/art/top-week',
'/domain/python.org',
'/domain/python.org/top-week'])
def test_content_subreddit_from_name_query(text, reddit, terminal):
SubredditContent.from_name(reddit, text, terminal.loader, query='pea')
def test_content_subreddit_multireddit(reddit, terminal): def test_content_subreddit_multireddit(reddit, terminal):