Add more tweet tests
This commit is contained in:
parent
a5676e1c2c
commit
f410720d1a
1 changed files with 52 additions and 32 deletions
|
@ -4,37 +4,30 @@ from parameterized import parameterized
|
||||||
# image = tweet + 'div.attachments.media-body > div > div > a > div > img'
|
# image = tweet + 'div.attachments.media-body > div > div > a > div > img'
|
||||||
# self.assert_true(self.get_image_url(image).split('/')[0] == 'http')
|
# self.assert_true(self.get_image_url(image).split('/')[0] == 'http')
|
||||||
|
|
||||||
timeline_tweets = [
|
timeline = [
|
||||||
[1, 'Test account', 'mobile_test', '10 Aug 2016',
|
[1, 'Test account', 'mobile_test', '10 Aug 2016', '763483571793174528',
|
||||||
'.'],
|
'.'],
|
||||||
|
|
||||||
[3, 'Test account', 'mobile_test', '3 Mar 2016',
|
[3, 'Test account', 'mobile_test', '3 Mar 2016', '705522133443571712',
|
||||||
'LIVE on #Periscope pscp.tv/w/aadiTzF6dkVOTXZSbX…'],
|
'LIVE on #Periscope pscp.tv/w/aadiTzF6dkVOTXZSbX…'],
|
||||||
|
|
||||||
[6, 'mobile test 2', 'mobile_test_2', '1 Oct 2014',
|
[6, 'mobile test 2', 'mobile_test_2', '1 Oct 2014', '517449200045277184',
|
||||||
'Testing. One two three four. Test.']
|
'Testing. One two three four. Test.']
|
||||||
]
|
]
|
||||||
|
|
||||||
status_tweets = [
|
status = [
|
||||||
[20, 'jack 🌍🌏🌎', 'jack', '21 Mar 2006',
|
[20, 'jack 🌍🌏🌎', 'jack', '21 Mar 2006', 'just setting up my twttr'],
|
||||||
'just setting up my twttr'],
|
[134849778302464000, 'The Twoffice', 'TheTwoffice', '10 Nov 2011', 'test'],
|
||||||
|
[105685475985080322, 'The Twoffice', 'TheTwoffice', '22 Aug 2011', 'regular tweet'],
|
||||||
[134849778302464000, 'The Twoffice', 'TheTwoffice', '10 Nov 2011',
|
[572593440719912960, 'Test account', 'mobile_test', '2 Mar 2015', 'testing test']
|
||||||
'test'],
|
|
||||||
|
|
||||||
[105685475985080322, 'The Twoffice', 'TheTwoffice', '22 Aug 2011',
|
|
||||||
'regular tweet'],
|
|
||||||
|
|
||||||
[572593440719912960, 'Test account', 'mobile_test', '2 Mar 2015',
|
|
||||||
'testing test']
|
|
||||||
]
|
]
|
||||||
|
|
||||||
invalid_tweets = [
|
invalid = [
|
||||||
['mobile_test/status/120938109238'],
|
['mobile_test/status/120938109238'],
|
||||||
['TheTwoffice/status/8931928312']
|
['TheTwoffice/status/8931928312']
|
||||||
]
|
]
|
||||||
|
|
||||||
multiline_tweets = [
|
multiline = [
|
||||||
[1142904127594401797, 'hot_pengu',
|
[1142904127594401797, 'hot_pengu',
|
||||||
"""
|
"""
|
||||||
New tileset, dust effects, background. The 'sea' has per-line parallax and wavey fx which we think is really cool even tho u didn't notice 🐶. code:
|
New tileset, dust effects, background. The 'sea' has per-line parallax and wavey fx which we think is really cool even tho u didn't notice 🐶. code:
|
||||||
|
@ -51,37 +44,48 @@ CLICHÉ
|
||||||
ON"""]
|
ON"""]
|
||||||
]
|
]
|
||||||
|
|
||||||
link_tweets = [
|
link = [
|
||||||
['nim_lang/status/1110499584852353024', [
|
['nim_lang/status/1110499584852353024', [
|
||||||
'nim-lang.org/araq/ownedrefs.…',
|
'nim-lang.org/araq/ownedrefs.…',
|
||||||
'news.ycombinator.com/item?id…',
|
'news.ycombinator.com/item?id…',
|
||||||
'old.reddit.com/r/programming…'
|
'old.reddit.com/r/programming…'
|
||||||
]],
|
]],
|
||||||
|
|
||||||
['nim_lang/status/1125887775151140864', [
|
['nim_lang/status/1125887775151140864', [
|
||||||
'en.wikipedia.org/wiki/Nim_(p…)'
|
'en.wikipedia.org/wiki/Nim_(p…)'
|
||||||
]],
|
]],
|
||||||
|
|
||||||
['hiankun_taioan/status/1086916335215341570', [
|
['hiankun_taioan/status/1086916335215341570', [
|
||||||
'(hackernoon.com/interview-wit…)'
|
'(hackernoon.com/interview-wit…)'
|
||||||
]]
|
]]
|
||||||
]
|
]
|
||||||
|
|
||||||
emoji_tweets = [
|
username = [
|
||||||
|
['Bountysource/status/1094803522053320705', ['nim_lang']],
|
||||||
|
['leereilly/status/1058464250098704385', ['godotengine', 'unity3d', 'nim_lang']]
|
||||||
|
]
|
||||||
|
|
||||||
|
emoji = [
|
||||||
['Tesla/status/1134850442511257600', '🌈❤️🧡💛💚💙💜']
|
['Tesla/status/1134850442511257600', '🌈❤️🧡💛💚💙💜']
|
||||||
]
|
]
|
||||||
|
|
||||||
class TestTweet(BaseTestCase):
|
retweet = [
|
||||||
@parameterized.expand(timeline_tweets)
|
[7, 'mobile_test_2', 'mobile test 2', 'Test account', '@mobile_test', '1234'],
|
||||||
def test_timeline(self, index, fullname, username, date, text):
|
[3, 'mobile_test_8', 'mobile test 8', 'jack 🌍🌏🌎', '@jack', 'twttr']
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
class TweetTest(BaseTestCase):
|
||||||
|
@parameterized.expand(timeline)
|
||||||
|
def test_timeline(self, index, fullname, username, date, tid, text):
|
||||||
self.open_nitter(username)
|
self.open_nitter(username)
|
||||||
tweet = get_timeline_tweet(index)
|
tweet = get_timeline_tweet(index)
|
||||||
self.assert_exact_text(fullname, tweet.fullname)
|
self.assert_exact_text(fullname, tweet.fullname)
|
||||||
self.assert_exact_text('@' + username, tweet.username)
|
self.assert_exact_text('@' + username, tweet.username)
|
||||||
self.assert_exact_text(date, tweet.date)
|
self.assert_exact_text(date, tweet.date)
|
||||||
self.assert_text(text, tweet.text)
|
self.assert_text(text, tweet.text)
|
||||||
|
permalink = self.find_element(tweet.date + ' a')
|
||||||
|
self.assertIn(tid, permalink.get_attribute('href'))
|
||||||
|
|
||||||
@parameterized.expand(status_tweets)
|
@parameterized.expand(status)
|
||||||
def test_status(self, tid, fullname, username, date, text):
|
def test_status(self, tid, fullname, username, date, text):
|
||||||
tweet = Tweet()
|
tweet = Tweet()
|
||||||
self.open_nitter(f'{username}/status/{tid}')
|
self.open_nitter(f'{username}/status/{tid}')
|
||||||
|
@ -90,23 +94,39 @@ class TestTweet(BaseTestCase):
|
||||||
self.assert_exact_text(date, tweet.date)
|
self.assert_exact_text(date, tweet.date)
|
||||||
self.assert_text(text, tweet.text)
|
self.assert_text(text, tweet.text)
|
||||||
|
|
||||||
@parameterized.expand(multiline_tweets)
|
@parameterized.expand(multiline)
|
||||||
def test_multiline_formatting(self, tid, username, text):
|
def test_multiline_formatting(self, tid, username, text):
|
||||||
self.open_nitter(f'{username}/status/{tid}')
|
self.open_nitter(f'{username}/status/{tid}')
|
||||||
self.assert_text(text.strip('\n'), '.main-tweet')
|
self.assert_text(text.strip('\n'), '.main-tweet')
|
||||||
|
|
||||||
@parameterized.expand(emoji_tweets)
|
@parameterized.expand(emoji)
|
||||||
def test_emojis(self, tweet, text):
|
def test_emoji(self, tweet, text):
|
||||||
self.open_nitter(tweet)
|
self.open_nitter(tweet)
|
||||||
self.assert_text(text, '.main-tweet')
|
self.assert_text(text, '.main-tweet')
|
||||||
|
|
||||||
@parameterized.expand(link_tweets)
|
@parameterized.expand(link)
|
||||||
def test_links(self, tweet, links):
|
def test_link(self, tweet, links):
|
||||||
self.open_nitter(tweet)
|
self.open_nitter(tweet)
|
||||||
for link in links:
|
for link in links:
|
||||||
self.assert_text(link, '.main-tweet')
|
self.assert_text(link, '.main-tweet')
|
||||||
|
|
||||||
@parameterized.expand(invalid_tweets)
|
@parameterized.expand(username)
|
||||||
|
def test_username(self, tweet, usernames):
|
||||||
|
self.open_nitter(tweet)
|
||||||
|
for un in usernames:
|
||||||
|
link = self.find_link_text(f'@{un}')
|
||||||
|
self.assertIn(f'/{un}', link.get_property('href'))
|
||||||
|
|
||||||
|
@parameterized.expand(retweet)
|
||||||
|
def test_retweet(self, index, url, retweet_by, fullname, username, text):
|
||||||
|
self.open_nitter(url)
|
||||||
|
tweet = get_timeline_tweet(index)
|
||||||
|
self.assert_text(f'{retweet_by} retweeted', tweet.retweet)
|
||||||
|
self.assert_text(text, tweet.text)
|
||||||
|
self.assert_exact_text(fullname, tweet.fullname)
|
||||||
|
self.assert_exact_text(username, tweet.username)
|
||||||
|
|
||||||
|
@parameterized.expand(invalid)
|
||||||
def test_invalid_id(self, tweet):
|
def test_invalid_id(self, tweet):
|
||||||
self.open_nitter(tweet)
|
self.open_nitter(tweet)
|
||||||
self.assert_text('Tweet not found', '.error-panel')
|
self.assert_text('Tweet not found', '.error-panel')
|
||||||
|
|
Loading…
Reference in a new issue