summaryrefslogtreecommitdiff
path: root/addons/website_forum/tests
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/website_forum/tests
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/website_forum/tests')
-rw-r--r--addons/website_forum/tests/__init__.py5
-rw-r--r--addons/website_forum/tests/common.py96
-rw-r--r--addons/website_forum/tests/test_forum.py438
-rw-r--r--addons/website_forum/tests/test_forum_process.py17
4 files changed, 556 insertions, 0 deletions
diff --git a/addons/website_forum/tests/__init__.py b/addons/website_forum/tests/__init__.py
new file mode 100644
index 00000000..9ad68e5f
--- /dev/null
+++ b/addons/website_forum/tests/__init__.py
@@ -0,0 +1,5 @@
+# -*- coding: utf-8 -*-
+
+from . import common
+from . import test_forum
+from . import test_forum_process
diff --git a/addons/website_forum/tests/common.py b/addons/website_forum/tests/common.py
new file mode 100644
index 00000000..75b6237b
--- /dev/null
+++ b/addons/website_forum/tests/common.py
@@ -0,0 +1,96 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo.tests import common
+
+KARMA = {
+ 'ask': 5, 'ans': 10,
+ 'com_own': 5, 'com_all': 10,
+ 'com_conv_all': 50,
+ 'upv': 5, 'dwv': 10,
+ 'edit_own': 10, 'edit_all': 20,
+ 'close_own': 10, 'close_all': 20,
+ 'unlink_own': 10, 'unlink_all': 20,
+ 'post': 100, 'flag': 500, 'moderate': 1000,
+ 'gen_que_new': 1, 'gen_que_upv': 5, 'gen_que_dwv': -10,
+ 'gen_ans_upv': 10, 'gen_ans_dwv': -20, 'gen_ans_flag': -45,
+ 'tag_create': 30,
+}
+
+
+class TestForumCommon(common.SavepointCase):
+
+ @classmethod
+ def setUpClass(cls):
+ super(TestForumCommon, cls).setUpClass()
+
+ Forum = cls.env['forum.forum']
+ Post = cls.env['forum.post']
+
+ # Test users
+ TestUsersEnv = cls.env['res.users'].with_context({'no_reset_password': True})
+ group_employee_id = cls.env.ref('base.group_user').id
+ group_portal_id = cls.env.ref('base.group_portal').id
+ group_public_id = cls.env.ref('base.group_public').id
+ cls.user_employee = TestUsersEnv.create({
+ 'name': 'Armande Employee',
+ 'login': 'Armande',
+ 'email': 'armande.employee@example.com',
+ 'karma': 0,
+ 'groups_id': [(6, 0, [group_employee_id])]
+ })
+ cls.user_portal = TestUsersEnv.create({
+ 'name': 'Beatrice Portal',
+ 'login': 'Beatrice',
+ 'email': 'beatrice.employee@example.com',
+ 'karma': 0,
+ 'groups_id': [(6, 0, [group_portal_id])]
+ })
+ cls.user_public = TestUsersEnv.create({
+ 'name': 'Cedric Public',
+ 'login': 'Cedric',
+ 'email': 'cedric.employee@example.com',
+ 'karma': 0,
+ 'groups_id': [(6, 0, [group_public_id])]
+ })
+
+ # Test forum
+ cls.forum = Forum.create({
+ 'name': 'TestForum',
+ 'karma_ask': KARMA['ask'],
+ 'karma_answer': KARMA['ans'],
+ 'karma_comment_own': KARMA['com_own'],
+ 'karma_comment_all': KARMA['com_all'],
+ 'karma_answer_accept_own': 9999,
+ 'karma_answer_accept_all': 9999,
+ 'karma_upvote': KARMA['upv'],
+ 'karma_downvote': KARMA['dwv'],
+ 'karma_edit_own': KARMA['edit_own'],
+ 'karma_edit_all': KARMA['edit_all'],
+ 'karma_close_own': KARMA['close_own'],
+ 'karma_close_all': KARMA['close_all'],
+ 'karma_unlink_own': KARMA['unlink_own'],
+ 'karma_unlink_all': KARMA['unlink_all'],
+ 'karma_post': KARMA['post'],
+ 'karma_comment_convert_all': KARMA['com_conv_all'],
+ 'karma_gen_question_new': KARMA['gen_que_new'],
+ 'karma_gen_question_upvote': KARMA['gen_que_upv'],
+ 'karma_gen_question_downvote': KARMA['gen_que_dwv'],
+ 'karma_gen_answer_upvote': KARMA['gen_ans_upv'],
+ 'karma_gen_answer_downvote': KARMA['gen_ans_dwv'],
+ 'karma_gen_answer_accept': 9999,
+ 'karma_gen_answer_accepted': 9999,
+ 'karma_gen_answer_flagged': KARMA['gen_ans_flag'],
+ })
+ cls.post = Post.create({
+ 'name': 'TestQuestion',
+ 'content': 'I am not a bird.',
+ 'forum_id': cls.forum.id,
+ 'tag_ids': [(0, 0, {'name': 'Tag2', 'forum_id': cls.forum.id})]
+ })
+ cls.answer = Post.create({
+ 'name': 'TestAnswer',
+ 'content': 'I am an anteater.',
+ 'forum_id': cls.forum.id,
+ 'parent_id': cls.post.id,
+ })
diff --git a/addons/website_forum/tests/test_forum.py b/addons/website_forum/tests/test_forum.py
new file mode 100644
index 00000000..b9d3bcdb
--- /dev/null
+++ b/addons/website_forum/tests/test_forum.py
@@ -0,0 +1,438 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from .common import KARMA, TestForumCommon
+from odoo.exceptions import UserError, AccessError
+from odoo.tools import mute_logger
+from psycopg2 import IntegrityError
+
+
+class TestForum(TestForumCommon):
+
+ def test_crud_rights(self):
+ Post = self.env['forum.post']
+ Vote = self.env['forum.post.vote']
+ self.user_portal.karma = 500
+ self.user_employee.karma = 500
+
+ # create some posts
+ self.admin_post = self.post
+ self.portal_post = Post.with_user(self.user_portal).create({
+ 'name': 'Post from Portal User',
+ 'content': 'I am not a bird.',
+ 'forum_id': self.forum.id,
+ })
+ self.employee_post = Post.with_user(self.user_employee).create({
+ 'name': 'Post from Employee User',
+ 'content': 'I am not a bird.',
+ 'forum_id': self.forum.id,
+ })
+
+ # vote on some posts
+ self.employee_vote_on_admin_post = Vote.with_user(self.user_employee).create({
+ 'post_id': self.admin_post.id,
+ 'vote': '1',
+ })
+ self.portal_vote_on_admin_post = Vote.with_user(self.user_portal).create({
+ 'post_id': self.admin_post.id,
+ 'vote': '1',
+ })
+ self.admin_vote_on_portal_post = Vote.create({
+ 'post_id': self.portal_post.id,
+ 'vote': '1',
+ })
+ self.admin_vote_on_employee_post = Vote.create({
+ 'post_id': self.employee_post.id,
+ 'vote': '1',
+ })
+
+ # One should not be able to modify someone else's vote
+ with self.assertRaises(UserError):
+ self.admin_vote_on_portal_post.with_user(self.user_employee).write({
+ 'vote': '-1',
+ })
+ with self.assertRaises(UserError):
+ self.admin_vote_on_employee_post.with_user(self.user_portal).write({
+ 'vote': '-1',
+ })
+
+ # One should not be able to give his vote to someone else
+ self.employee_vote_on_admin_post.with_user(self.user_employee).write({
+ 'user_id': 1,
+ })
+ self.assertEqual(self.employee_vote_on_admin_post.user_id, self.user_employee, 'User employee should not be able to give its vote ownership to someone else')
+ # One should not be able to change his vote's post to a post of his own (would be self voting)
+ with self.assertRaises(UserError):
+ self.employee_vote_on_admin_post.with_user(self.user_employee).write({
+ 'post_id': self.employee_post.id,
+ })
+
+ # One should not be able to give his vote to someone else
+ self.portal_vote_on_admin_post.with_user(self.user_portal).write({
+ 'user_id': 1,
+ })
+ self.assertEqual(self.portal_vote_on_admin_post.user_id, self.user_portal, 'User portal should not be able to give its vote ownership to someone else')
+ # One should not be able to change his vote's post to a post of his own (would be self voting)
+ with self.assertRaises(UserError):
+ self.portal_vote_on_admin_post.with_user(self.user_portal).write({
+ 'post_id': self.portal_post.id,
+ })
+
+ # One should not be able to vote for its own post
+ with self.assertRaises(UserError):
+ Vote.with_user(self.user_employee).create({
+ 'post_id': self.employee_post.id,
+ 'vote': '1',
+ })
+ # One should not be able to vote for its own post
+ with self.assertRaises(UserError):
+ Vote.with_user(self.user_portal).create({
+ 'post_id': self.portal_post.id,
+ 'vote': '1',
+ })
+
+ with mute_logger('odoo.sql_db'):
+ with self.assertRaises(IntegrityError):
+ with self.cr.savepoint():
+ # One should not be able to vote more than once on a same post
+ Vote.with_user(self.user_employee).create({
+ 'post_id': self.admin_post.id,
+ 'vote': '1',
+ })
+ with self.assertRaises(IntegrityError):
+ with self.cr.savepoint():
+ # One should not be able to vote more than once on a same post
+ Vote.with_user(self.user_employee).create({
+ 'post_id': self.admin_post.id,
+ 'vote': '1',
+ })
+
+ # One should not be able to create a vote for someone else
+ new_employee_vote = Vote.with_user(self.user_employee).create({
+ 'post_id': self.portal_post.id,
+ 'user_id': 1,
+ 'vote': '1',
+ })
+ self.assertEqual(new_employee_vote.user_id, self.user_employee, 'Creating a vote for someone else should not be allowed. It should create it for yourself instead')
+ # One should not be able to create a vote for someone else
+ new_portal_vote = Vote.with_user(self.user_portal).create({
+ 'post_id': self.employee_post.id,
+ 'user_id': 1,
+ 'vote': '1',
+ })
+ self.assertEqual(new_portal_vote.user_id, self.user_portal, 'Creating a vote for someone else should not be allowed. It should create it for yourself instead')
+
+ @mute_logger('odoo.addons.base.models.ir_model', 'odoo.models')
+ def test_ask(self):
+ Post = self.env['forum.post']
+
+ # Public user asks a question: not allowed
+ with self.assertRaises(AccessError):
+ Post.with_user(self.user_public).create({
+ 'name': " Question ?",
+ 'forum_id': self.forum.id,
+ })
+
+ # Portal user asks a question with tags: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ Post.with_user(self.user_portal).create({
+ 'name': " Q_0",
+ 'forum_id': self.forum.id,
+ 'tag_ids': [(0, 0, {'name': 'Tag0', 'forum_id': self.forum.id})]
+ })
+
+ # Portal user asks a question with tags: ok if enough karma
+ self.user_portal.karma = KARMA['tag_create']
+ Post.with_user(self.user_portal).create({
+ 'name': " Q0",
+ 'forum_id': self.forum.id,
+ 'tag_ids': [(0, 0, {'name': 'Tag1', 'forum_id': self.forum.id})]
+ })
+ self.assertEqual(self.user_portal.karma, KARMA['tag_create'], 'website_forum: wrong karma generation when asking question')
+
+ self.user_portal.karma = KARMA['post']
+ Post.with_user(self.user_portal).create({
+ 'name': " Q0",
+ 'forum_id': self.forum.id,
+ 'tag_ids': [(0, 0, {'name': 'Tag42', 'forum_id': self.forum.id})]
+ })
+ self.assertEqual(self.user_portal.karma, KARMA['post'] + KARMA['gen_que_new'], 'website_forum: wrong karma generation when asking question')
+
+ @mute_logger('odoo.addons.base.models.ir_model', 'odoo.models')
+ def test_answer(self):
+ Post = self.env['forum.post']
+
+ # Answers its own question: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ Post.with_user(self.user_employee).create({
+ 'name': " A0",
+ 'forum_id': self.forum.id,
+ 'parent_id': self.post.id,
+ })
+
+ # Answers on question: ok if enough karma
+ self.user_employee.karma = KARMA['ans']
+ Post.with_user(self.user_employee).create({
+ 'name': " A0",
+ 'forum_id': self.forum.id,
+ 'parent_id': self.post.id,
+ })
+ self.assertEqual(self.user_employee.karma, KARMA['ans'], 'website_forum: wrong karma generation when answering question')
+
+ @mute_logger('odoo.addons.base.models.ir_model', 'odoo.models')
+ def test_vote_crash(self):
+ Post = self.env['forum.post']
+ self.user_employee.karma = KARMA['ans']
+ emp_answer = Post.with_user(self.user_employee).create({
+ 'name': 'TestAnswer',
+ 'forum_id': self.forum.id,
+ 'parent_id': self.post.id})
+
+ # upvote its own post
+ with self.assertRaises(UserError):
+ emp_answer.vote(upvote=True)
+
+ # not enough karma
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).vote(upvote=True)
+
+ def test_vote(self):
+ self.post.create_uid.karma = KARMA['ask']
+ self.user_portal.karma = KARMA['upv']
+ self.post.with_user(self.user_portal).vote(upvote=True)
+ self.assertEqual(self.post.create_uid.karma, KARMA['ask'] + KARMA['gen_que_upv'], 'website_forum: wrong karma generation of upvoted question author')
+
+ @mute_logger('odoo.addons.base.models.ir_model', 'odoo.models')
+ def test_downvote_crash(self):
+ Post = self.env['forum.post']
+ self.user_employee.karma = KARMA['ans']
+ emp_answer = Post.with_user(self.user_employee).create({
+ 'name': 'TestAnswer',
+ 'forum_id': self.forum.id,
+ 'parent_id': self.post.id})
+
+ # downvote its own post
+ with self.assertRaises(UserError):
+ emp_answer.vote(upvote=False)
+
+ # not enough karma
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).vote(upvote=False)
+
+ def test_downvote(self):
+ self.post.create_uid.karma = 50
+ self.user_portal.karma = KARMA['dwv']
+ self.post.with_user(self.user_portal).vote(upvote=False)
+ self.assertEqual(self.post.create_uid.karma, 50 + KARMA['gen_que_dwv'], 'website_forum: wrong karma generation of downvoted question author')
+
+ def test_comment_crash(self):
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).message_post(body='Should crash', message_type='comment')
+
+ def test_comment(self):
+ self.post.with_user(self.user_employee).message_post(body='Test0', message_type='notification')
+ self.user_employee.karma = KARMA['com_all']
+ self.post.with_user(self.user_employee).message_post(body='Test1', message_type='comment')
+ self.assertEqual(len(self.post.message_ids), 4, 'website_forum: wrong behavior of message_post')
+
+ def test_flag_a_post(self):
+ Post = self.env['forum.post']
+ self.user_portal.karma = KARMA['ask']
+ post = Post.with_user(self.user_portal).create({
+ 'name': "Q0",
+ 'forum_id': self.forum.id,
+ })
+
+ # portal user flags a post: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ post.with_user(self.user_portal).flag()
+
+ # portal user flags a post: ok if enough karma
+ self.user_portal.karma = KARMA['flag']
+ post.state = 'active'
+ post.with_user(self.user_portal).flag()
+ self.assertEqual(post.state, 'flagged', 'website_forum: wrong state when flagging a post')
+
+ def test_validate_a_post(self):
+ Post = self.env['forum.post']
+ self.user_portal.karma = KARMA['ask']
+ post = Post.with_user(self.user_portal).create({
+ 'name': "Q0",
+ 'forum_id': self.forum.id,
+ })
+
+ # portal user validate a post: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ post.with_user(self.user_portal).validate()
+
+ # portal user validate a pending post
+ self.user_portal.karma = KARMA['moderate']
+ post.state = 'pending'
+ init_karma = post.create_uid.karma
+ post.with_user(self.user_portal).validate()
+ self.assertEqual(post.state, 'active', 'website_forum: wrong state when validate a post after pending')
+ self.assertEqual(post.create_uid.karma, init_karma + KARMA['gen_que_new'], 'website_forum: wrong karma when validate a post after pending')
+
+ # portal user validate a flagged post: ok if enough karma
+ self.user_portal.karma = KARMA['moderate']
+ post.state = 'flagged'
+ post.with_user(self.user_portal).validate()
+ self.assertEqual(post.state, 'active', 'website_forum: wrong state when validate a post after flagged')
+
+ # portal user validate an offensive post: ok if enough karma
+ self.user_portal.karma = KARMA['moderate']
+ post.state = 'offensive'
+ init_karma = post.create_uid.karma
+ post.with_user(self.user_portal).validate()
+ self.assertEqual(post.state, 'active', 'website_forum: wrong state when validate a post after offensive')
+
+ def test_refuse_a_post(self):
+ Post = self.env['forum.post']
+ self.user_portal.karma = KARMA['ask']
+ post = Post.with_user(self.user_portal).create({
+ 'name': "Q0",
+ 'forum_id': self.forum.id,
+ })
+
+ # portal user validate a post: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ post.with_user(self.user_portal).refuse()
+
+ # portal user validate a pending post
+ self.user_portal.karma = KARMA['moderate']
+ post.state = 'pending'
+ init_karma = post.create_uid.karma
+ post.with_user(self.user_portal).refuse()
+ self.assertEqual(post.moderator_id, self.user_portal, 'website_forum: wrong moderator_id when refusing')
+ self.assertEqual(post.create_uid.karma, init_karma, 'website_forum: wrong karma when refusing a post')
+
+ def test_mark_a_post_as_offensive(self):
+ Post = self.env['forum.post']
+ self.user_portal.karma = KARMA['ask']
+ post = Post.with_user(self.user_portal).create({
+ 'name': "Q0",
+ 'forum_id': self.forum.id,
+ })
+
+ # portal user mark a post as offensive: not allowed, unsufficient karma
+ with self.assertRaises(AccessError):
+ post.with_user(self.user_portal).mark_as_offensive(12)
+
+ # portal user mark a post as offensive
+ self.user_portal.karma = KARMA['moderate']
+ post.state = 'flagged'
+ init_karma = post.create_uid.karma
+ post.with_user(self.user_portal).mark_as_offensive(12)
+ self.assertEqual(post.state, 'offensive', 'website_forum: wrong state when marking a post as offensive')
+ self.assertEqual(post.create_uid.karma, init_karma + KARMA['gen_ans_flag'], 'website_forum: wrong karma when marking a post as offensive')
+
+ def test_convert_answer_to_comment_crash(self):
+ Post = self.env['forum.post']
+
+ # converting a question does nothing
+ new_msg = self.post.with_user(self.user_portal).convert_answer_to_comment()
+ self.assertEqual(new_msg.id, False, 'website_forum: question to comment conversion failed')
+ self.assertEqual(Post.search([('name', '=', 'TestQuestion')])[0].forum_id.name, 'TestForum', 'website_forum: question to comment conversion failed')
+
+ with self.assertRaises(AccessError):
+ self.answer.with_user(self.user_portal).convert_answer_to_comment()
+
+ def test_convert_answer_to_comment(self):
+ self.user_portal.karma = KARMA['com_conv_all']
+ post_author = self.answer.create_uid.partner_id
+ new_msg = self.answer.with_user(self.user_portal).convert_answer_to_comment()
+ self.assertEqual(len(new_msg), 1, 'website_forum: wrong answer to comment conversion')
+ self.assertEqual(new_msg.author_id, post_author, 'website_forum: wrong answer to comment conversion')
+ self.assertIn('I am an anteater', new_msg.body, 'website_forum: wrong answer to comment conversion')
+
+ def test_edit_post_crash(self):
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).write({'name': 'I am not your father.'})
+
+ def test_edit_post(self):
+ self.post.create_uid.karma = KARMA['edit_own']
+ self.post.write({'name': 'Actually I am your dog.'})
+ self.user_portal.karma = KARMA['edit_all']
+ self.post.with_user(self.user_portal).write({'name': 'Actually I am your cat.'})
+
+ def test_close_post_crash(self):
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).close(None)
+
+ def test_close_post_own(self):
+ self.post.create_uid.karma = KARMA['close_own']
+ self.post.close(None)
+
+ def test_close_post_all(self):
+ self.user_portal.karma = KARMA['close_all']
+ self.post.with_user(self.user_portal).close(None)
+
+ def test_deactivate_post_crash(self):
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).write({'active': False})
+
+ def test_deactivate_post_own(self):
+ self.post.create_uid.karma = KARMA['unlink_own']
+ self.post.write({'active': False})
+
+ def test_deactivate_post_all(self):
+ self.user_portal.karma = KARMA['unlink_all']
+ self.post.with_user(self.user_portal).write({'active': False})
+
+ def test_unlink_post_crash(self):
+ with self.assertRaises(AccessError):
+ self.post.with_user(self.user_portal).unlink()
+
+ def test_unlink_post_own(self):
+ self.post.create_uid.karma = KARMA['unlink_own']
+ self.post.unlink()
+
+ def test_unlink_post_all(self):
+ self.user_portal.karma = KARMA['unlink_all']
+ self.post.with_user(self.user_portal).unlink()
+
+ def test_forum_mode_questions(self):
+ Forum = self.env['forum.forum']
+ forum_questions = Forum.create({
+ 'name': 'Questions Forum',
+ 'mode': 'questions',
+ 'active': True
+ })
+ Post = self.env['forum.post']
+ questions_post = Post.create({
+ 'name': 'My First Post',
+ 'forum_id': forum_questions.id,
+ 'parent_id': self.post.id,
+ })
+ answer_to_questions_post = Post.create({
+ 'name': 'This is an answer',
+ 'forum_id': forum_questions.id,
+ 'parent_id': questions_post.id,
+ })
+ self.assertEqual(
+ not questions_post.uid_has_answered or questions_post.forum_id.mode == 'discussions', False)
+ self.assertEqual(
+ questions_post.uid_has_answered and questions_post.forum_id.mode == 'questions', True)
+
+ def test_forum_mode_discussions(self):
+ Forum = self.env['forum.forum']
+ forum_discussions = Forum.create({
+ 'name': 'Discussions Forum',
+ 'mode': 'discussions',
+ 'active': True
+ })
+ Post = self.env['forum.post']
+ discussions_post = Post.create({
+ 'name': 'My First Post',
+ 'forum_id': forum_discussions.id,
+ 'parent_id': self.post.id,
+ })
+ answer_to_discussions_post = Post.create({
+ 'name': 'This is an answer',
+ 'forum_id': forum_discussions.id,
+ 'parent_id': discussions_post.id,
+ })
+ self.assertEqual(
+ not discussions_post.uid_has_answered or discussions_post.forum_id.mode == 'discussions', True)
+ self.assertEqual(
+ discussions_post.uid_has_answered and discussions_post.forum_id.mode == 'questions', False)
diff --git a/addons/website_forum/tests/test_forum_process.py b/addons/website_forum/tests/test_forum_process.py
new file mode 100644
index 00000000..42e314d0
--- /dev/null
+++ b/addons/website_forum/tests/test_forum_process.py
@@ -0,0 +1,17 @@
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo.addons.base.tests.common import HttpCaseWithUserDemo
+from odoo.tests import tagged
+
+
+@tagged('post_install', '-at_install')
+class TestUi(HttpCaseWithUserDemo):
+
+ def test_01_admin_forum_tour(self):
+ self.start_tour("/", 'question', login="admin", step_delay=100)
+
+ def test_02_demo_question(self):
+ forum = self.env.ref('website_forum.forum_help')
+ demo = self.user_demo
+ demo.karma = forum.karma_post + 1
+ self.start_tour("/", 'forum_question', login="demo")