Add test for subscription page
This commit is contained in:
@@ -228,3 +228,19 @@ def list_reddits_page(reddit, terminal, config, oauth):
|
|||||||
assert terminal.loader.exception is None
|
assert terminal.loader.exception is None
|
||||||
page.draw()
|
page.draw()
|
||||||
return page
|
return page
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def subscription_page(reddit, terminal, config, oauth, refresh_token):
|
||||||
|
# Must be logged in to view your subscriptions
|
||||||
|
config.refresh_token = refresh_token
|
||||||
|
oauth.authorize()
|
||||||
|
|
||||||
|
title = 'My Subreddits'
|
||||||
|
func = lambda : reddit.get_my_subreddits(limit=None)
|
||||||
|
|
||||||
|
with terminal.loader():
|
||||||
|
page = ListRedditsPage(reddit, title, func, terminal, config, oauth)
|
||||||
|
assert terminal.loader.exception is None
|
||||||
|
page.draw()
|
||||||
|
return page
|
||||||
|
|||||||
@@ -16,7 +16,11 @@ except ImportError:
|
|||||||
|
|
||||||
def test_list_reddits_page_construct(reddit, terminal, config,
|
def test_list_reddits_page_construct(reddit, terminal, config,
|
||||||
oauth, refresh_token):
|
oauth, refresh_token):
|
||||||
window = terminal.stdscr.subwin
|
|
||||||
|
# Log in
|
||||||
|
config.refresh_token = refresh_token
|
||||||
|
oauth.authorize()
|
||||||
|
|
||||||
title = 'Popular Subreddits'
|
title = 'Popular Subreddits'
|
||||||
func = reddit.get_popular_subreddits
|
func = reddit.get_popular_subreddits
|
||||||
|
|
||||||
@@ -26,6 +30,7 @@ def test_list_reddits_page_construct(reddit, terminal, config,
|
|||||||
|
|
||||||
page.draw()
|
page.draw()
|
||||||
|
|
||||||
|
window = terminal.stdscr.subwin
|
||||||
# Header - Title
|
# Header - Title
|
||||||
window.addstr.assert_any_call(0, 0, title.encode('utf-8'))
|
window.addstr.assert_any_call(0, 0, title.encode('utf-8'))
|
||||||
|
|
||||||
@@ -121,7 +126,7 @@ def test_list_reddits_close(list_reddits_page):
|
|||||||
assert list_reddits_page.active is False
|
assert list_reddits_page.active is False
|
||||||
|
|
||||||
|
|
||||||
def test_list_reddits_page_invalid(list_reddits_page):
|
def test_subscription_page_invalid(subscription_page):
|
||||||
|
|
||||||
# Test that other commands don't crash
|
# Test that other commands don't crash
|
||||||
methods = [
|
methods = [
|
||||||
@@ -132,5 +137,5 @@ def test_list_reddits_page_invalid(list_reddits_page):
|
|||||||
]
|
]
|
||||||
for ch in methods:
|
for ch in methods:
|
||||||
curses.flash.reset_mock()
|
curses.flash.reset_mock()
|
||||||
list_reddits_page.controller.trigger(ch)
|
subscription_page.controller.trigger(ch)
|
||||||
assert curses.flash.called
|
assert curses.flash.called
|
||||||
|
|||||||
Reference in New Issue
Block a user