def test_get_random_story(client, database, templates, story_actions): example = Story() example.text = 'very not recent story (months/years ago)' example.likes = 0 example.author_id = 1 example.date = dt.datetime(2019, 9, 5) example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'not recent story (yesterday)' example.date = dt.datetime.now() - dt.timedelta(days=1) example.likes = 0 example.author_id = 2 example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'drafted story' example.date = dt.datetime.now() - dt.timedelta(days=1) example.likes = 0 example.author_id = 1 example.is_draft = True example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'deleted story' example.date = dt.datetime.now() - dt.timedelta(days=1) example.likes = 0 example.author_id = 1 example.is_draft = False example.deleted = True example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit() # story found reply = story_actions.get_random_recent_story() assert reply.status_code == 200 template_context = templates[-1] id = template_context['story'].id message = template_context['message'] assert id == 1 or id == 2 assert message == 'no stories today. Here is a random one:'
def test_getuser(client, auth, database, templates): reply = auth.login() assert reply.status_code == 302 reply = client.get('/users/2') assert reply.status_code == 200 user = templates[-1]['user'] stories = templates[-1]['stories'] assert user == 'test1' assert stories == [] example = Story() example.text = 'First story of test1 user :)' example.author_id = 2 example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit() reply = client.get('/users/2') assert reply.status_code == 200 user = templates[-1]['user'] stories = templates[-1]['stories'] assert user == 'test1' assert len(stories) == 1 assert stories[0].id == example.id
def test_story_with_unmarked_dislike(client, auth, database, templates, story_actions): # example story and unmarked reaction s = Story() s.text = 'Trial story of example admin user :)' s.likes = 42 s.dislikes = 0 s.author_id = 1 s.dice_set = ['dice1', 'dice2'] s.is_draft = False s.deleted = False database.session.add(s) r = Reaction() r.reactor_id = 1 r.author = s r.reaction_val = -1 r.marked = False database.session.add(r) database.session.commit() # get the story auth.login() reply = story_actions.get_story(1) template_capture = templates[-1] assert reply.status_code == 200 assert template_capture['story'].likes == 42 # check that the unmarked dislike is counted assert template_capture['story'].dislikes == 1 database.session.commit()
def init_database(database): example = Story() example.text = 'lorem ipsum dolor sit amet' example.likes = 42 example.author_id = 1 example.date = dt.datetime(year=2018, month=12, day=1) example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'bird drink coffee baloon' example.likes = 42 example.author_id = 1 example.date = dt.datetime(year=2019, month=1, day=1) example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'lorem Coffee dolor sit amet' example.likes = 42 example.author_id = 1 example.date = dt.datetime(year=2019, month=3, day=12) example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) example = Story() example.text = 'bird cofFee baloon amet' example.likes = 42 example.author_id = 1 example.date = dt.datetime(year=2017, month=10, day=1) example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit()
def test_get_by_interest(client, auth, database, templates, story_actions): auth.login() example1 = Story() example1.theme = 'halloween' example1.text = 'Halloween story of test1 user :)' example1.author_id = 2 example1.is_draft = False example1.deleted = False example1.dice_set = ['a', 'b', 'c'] database.session.add(example1) database.session.commit() example2 = Story() example2.theme = 'xmas' example2.text = 'Xmas story of test2 user :)' example2.author_id = 3 example2.is_draft = False example2.deleted = False example2.dice_set = ['a', 'b', 'c'] database.session.add(example2) database.session.commit() example3 = Story() example3.theme = 'xmas' example3.theme = 'Old xmas story of test3 user :)' example3.date = dt.datetime.now() - dt.timedelta(days=6) example3.author_id = 4 example3.is_draft = False example3.deleted = False example3.dice_set = ['a', 'b', 'c'] database.session.add(example3) database.session.commit() reply = story_actions.get_all_stories(theme='xmas') assert reply.status_code == 200 assert templates[-1]['stories'].all() == [example2]
def test_story_digest_format(): u = User() u.username = '******' u.email = '*****@*****.**' u.firstname = 'Firstname' u.lastname = 'Lastname' date = dt.datetime.now() s = Story() s.author = u s.text = 'Lorem ipsum dolor sit amet' s.date = date s.likes = 42 s.dislikes = 69 s.dice_set = ['lorem', 'ipsum', 'dolor', 'sit', 'amet'] s.deleted = False s.is_draft = False lines = digests.story_digest(s).split('\n') assert lines[0] == 'author: Firstname Lastname (Username)' assert lines[1] == 'roll: lorem, ipsum, dolor, sit, amet' assert lines[2] == f'date: {date}' assert lines[3] == 'story: Lorem ipsum dolor sit amet' assert lines[4] == 'likes: 42 -- dislikes: 69'
def test_getusers(client, database, auth, templates): reply = auth.login('Admin', 'admin') assert reply.status_code == 302 reply = client.get('/users') template_capture = templates[-1]['result'] users = [(r[0], r[1]) for r in template_capture] assert users == [('Admin', None), ('test1', None), ('test2', None), ('test3', None)] example = Story() example.text = 'First story of admin user :)' example.author_id = 1 example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit() reply = client.get('/users') template_capture = templates[-1]['result'] users = [(r[0], r[1]) for r in template_capture] assert users == [('Admin', 'First story of admin user :)'), ('test1', None), ('test2', None), ('test3', None)] client.get('/logout') client.post('/signup', data={'email': '*****@*****.**', 'username': '******', 'password': '******'}) reply = client.get('/users') template_capture = templates[-1]['result'] users = [(r[0], r[1]) for r in template_capture] assert users == [('Admin', 'First story of admin user :)'), ('test1', None), ('test2', None), ('test3', None), ('prova', None)] example = Story() example.text = 'First story of prova user :)' example.author_id = 5 example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit() reply = client.get('/users') template_capture = templates[-1]['result'] users = [(r[0], r[1]) for r in template_capture] assert users == [('Admin', 'First story of admin user :)'), ('test1', None), ('test2', None), ('test3', None), ('prova', 'First story of prova user :)')] example = Story() example.text = 'Second story of admin user :)' example.author_id = 1 example.is_draft = False example.deleted = False example.dice_set = ['a', 'b', 'c'] database.session.add(example) database.session.commit() reply = client.get('/users') template_capture = templates[-1]['result'] users = [(r[0], r[1]) for r in template_capture] assert users == [('Admin', 'Second story of admin user :)'), ('test1', None), ('test2', None), ('test3', None), ('prova', 'First story of prova user :)')]