summaryrefslogtreecommitdiff
path: root/addons/project/tests/test_project_flow.py
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/project/tests/test_project_flow.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/project/tests/test_project_flow.py')
-rw-r--r--addons/project/tests/test_project_flow.py276
1 files changed, 276 insertions, 0 deletions
diff --git a/addons/project/tests/test_project_flow.py b/addons/project/tests/test_project_flow.py
new file mode 100644
index 00000000..b5d5e277
--- /dev/null
+++ b/addons/project/tests/test_project_flow.py
@@ -0,0 +1,276 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+import base64
+
+from .test_project_base import TestProjectCommon
+from odoo.tools import mute_logger
+from odoo.modules.module import get_resource_path
+
+
+EMAIL_TPL = """Return-Path: <whatever-2a840@postmaster.twitter.com>
+X-Original-To: {to}
+Delivered-To: {to}
+To: {to}
+cc: {cc}
+Received: by mail1.odoo.com (Postfix, from userid 10002)
+ id 5DF9ABFB2A; Fri, 10 Aug 2012 16:16:39 +0200 (CEST)
+Message-ID: {msg_id}
+Date: Tue, 29 Nov 2011 12:43:21 +0530
+From: {email_from}
+MIME-Version: 1.0
+Subject: {subject}
+Content-Type: text/plain; charset=ISO-8859-1; format=flowed
+
+Hello,
+
+This email should create a new entry in your module. Please check that it
+effectively works.
+
+Thanks,
+
+--
+Raoul Boitempoils
+Integrator at Agrolait"""
+
+
+class TestProjectFlow(TestProjectCommon):
+
+ def test_project_process_project_manager_duplicate(self):
+ pigs = self.project_pigs.with_user(self.user_projectmanager)
+ dogs = pigs.copy()
+ self.assertEqual(len(dogs.tasks), 2, 'project: duplicating a project must duplicate its tasks')
+
+ @mute_logger('odoo.addons.mail.mail_thread')
+ def test_task_process_without_stage(self):
+ # Do: incoming mail from an unknown partner on an alias creates a new task 'Frogs'
+ task = self.format_and_process(
+ EMAIL_TPL, to='project+pigs@mydomain.com, valid.lelitre@agrolait.com', cc='valid.other@gmail.com',
+ email_from='%s' % self.user_projectuser.email,
+ subject='Frogs', msg_id='<1198923581.41972151344608186760.JavaMail@agrolait.com>',
+ target_model='project.task')
+
+ # Test: one task created by mailgateway administrator
+ self.assertEqual(len(task), 1, 'project: message_process: a new project.task should have been created')
+ # Test: check partner in message followers
+ self.assertIn(self.partner_2, task.message_partner_ids, "Partner in message cc is not added as a task followers.")
+ # Test: messages
+ self.assertEqual(len(task.message_ids), 1,
+ 'project: message_process: newly created task should have 1 message: email')
+ self.assertEqual(task.message_ids[0].subtype_id, self.env.ref('project.mt_task_new'),
+ 'project: message_process: first message of new task should have Task Created subtype')
+ self.assertEqual(task.message_ids[0].author_id, self.user_projectuser.partner_id,
+ 'project: message_process: second message should be the one from Agrolait (partner failed)')
+ self.assertEqual(task.message_ids[0].subject, 'Frogs',
+ 'project: message_process: second message should be the one from Agrolait (subject failed)')
+ # Test: task content
+ self.assertEqual(task.name, 'Frogs', 'project_task: name should be the email subject')
+ self.assertEqual(task.project_id.id, self.project_pigs.id, 'project_task: incorrect project')
+ self.assertEqual(task.stage_id.sequence, False, "project_task: shouldn't have a stage, i.e. sequence=False")
+
+ @mute_logger('odoo.addons.mail.mail_thread')
+ def test_task_process_with_stages(self):
+ # Do: incoming mail from an unknown partner on an alias creates a new task 'Cats'
+ task = self.format_and_process(
+ EMAIL_TPL, to='project+goats@mydomain.com, valid.lelitre@agrolait.com', cc='valid.other@gmail.com',
+ email_from='%s' % self.user_projectuser.email,
+ subject='Cats', msg_id='<1198923581.41972151344608186760.JavaMail@agrolait.com>',
+ target_model='project.task')
+
+ # Test: one task created by mailgateway administrator
+ self.assertEqual(len(task), 1, 'project: message_process: a new project.task should have been created')
+ # Test: check partner in message followers
+ self.assertIn(self.partner_2, task.message_partner_ids, "Partner in message cc is not added as a task followers.")
+ # Test: messages
+ self.assertEqual(len(task.message_ids), 1,
+ 'project: message_process: newly created task should have 1 messages: email')
+ self.assertEqual(task.message_ids[0].subtype_id, self.env.ref('project.mt_task_new'),
+ 'project: message_process: first message of new task should have Task Created subtype')
+ self.assertEqual(task.message_ids[0].author_id, self.user_projectuser.partner_id,
+ 'project: message_process: first message should be the one from Agrolait (partner failed)')
+ self.assertEqual(task.message_ids[0].subject, 'Cats',
+ 'project: message_process: first message should be the one from Agrolait (subject failed)')
+ # Test: task content
+ self.assertEqual(task.name, 'Cats', 'project_task: name should be the email subject')
+ self.assertEqual(task.project_id.id, self.project_goats.id, 'project_task: incorrect project')
+ self.assertEqual(task.stage_id.sequence, 1, "project_task: should have a stage with sequence=1")
+
+ def test_subtask_process(self):
+ """
+ Check subtask mecanism and change it from project.
+
+ For this test, 2 projects are used:
+ - the 'pigs' project which has a partner_id
+ - the 'goats' project where the partner_id is removed at the beginning of the tests and then restored.
+
+ 2 parent tasks are also used to be able to switch the parent task of a sub-task:
+ - 'parent_task' linked to the partner_2
+ - 'another_parent_task' linked to the partner_3
+ """
+
+ Task = self.env['project.task'].with_context({'tracking_disable': True})
+
+ parent_task = Task.create({
+ 'name': 'Mother Task',
+ 'user_id': self.user_projectuser.id,
+ 'project_id': self.project_pigs.id,
+ 'partner_id': self.partner_2.id,
+ 'planned_hours': 12,
+ })
+
+ another_parent_task = Task.create({
+ 'name': 'Another Mother Task',
+ 'user_id': self.user_projectuser.id,
+ 'project_id': self.project_pigs.id,
+ 'partner_id': self.partner_3.id,
+ 'planned_hours': 0,
+ })
+
+ # remove the partner_id of the 'goats' project
+ goats_partner_id = self.project_goats.partner_id
+
+ self.project_goats.write({
+ 'partner_id': False
+ })
+
+ # the child task 1 is linked to a project without partner_id (goats project)
+ child_task_1 = Task.create({
+ 'name': 'Task Child with project',
+ 'parent_id': parent_task.id,
+ 'project_id': self.project_goats.id,
+ 'planned_hours': 3,
+ })
+
+ # the child task 2 is linked to a project with a partner_id (pigs project)
+ child_task_2 = Task.create({
+ 'name': 'Task Child without project',
+ 'parent_id': parent_task.id,
+ 'project_id': self.project_pigs.id,
+ 'planned_hours': 5,
+ })
+
+ self.assertEqual(
+ child_task_1.partner_id, child_task_1.parent_id.partner_id,
+ "When no project partner_id has been set, a subtask should have the same partner as its parent")
+
+ self.assertEqual(
+ child_task_2.partner_id, child_task_2.project_id.partner_id,
+ "When a project partner_id has been set, a subtask should have the same partner as its project")
+
+ self.assertEqual(
+ parent_task.subtask_count, 2,
+ "Parent task should have 2 children")
+
+ self.assertEqual(
+ parent_task.subtask_planned_hours, 8,
+ "Planned hours of subtask should impact parent task")
+
+ # change the parent of a subtask without a project partner_id
+ child_task_1.write({
+ 'parent_id': another_parent_task.id
+ })
+
+ self.assertEqual(
+ child_task_1.partner_id, parent_task.partner_id,
+ "When changing the parent task of a subtask with no project partner_id, the partner_id should remain the same.")
+
+ # change the parent of a subtask with a project partner_id
+ child_task_2.write({
+ 'parent_id': another_parent_task.id
+ })
+
+ self.assertEqual(
+ child_task_2.partner_id, child_task_2.project_id.partner_id,
+ "When changing the parent task of a subtask with a project, the partner_id should remain the same.")
+
+ # set a project with partner_id to a subtask without project partner_id
+ child_task_1.write({
+ 'project_id': self.project_pigs.id
+ })
+
+ self.assertEqual(
+ child_task_1.partner_id, self.project_pigs.partner_id,
+ "When the project changes, the subtask should have the same partner id as the new project.")
+
+ # restore the partner_id of the 'goats' project
+ self.project_goats.write({
+ 'partner_id': goats_partner_id
+ })
+
+ # set a project with partner_id to a subtask with a project partner_id
+ child_task_2.write({
+ 'project_id': self.project_goats.id
+ })
+
+ self.assertEqual(
+ child_task_2.partner_id, self.project_goats.partner_id,
+ "When the project changes, the subtask should have the same partner id as the new project.")
+
+ def test_rating(self):
+ """Check if rating works correctly even when task is changed from project A to project B"""
+ Task = self.env['project.task'].with_context({'tracking_disable': True})
+ first_task = Task.create({
+ 'name': 'first task',
+ 'user_id': self.user_projectuser.id,
+ 'project_id': self.project_pigs.id,
+ 'partner_id': self.partner_2.id,
+ })
+
+ self.assertEqual(first_task.rating_count, 0, "Task should have no rating associated with it")
+
+ rating_good = self.env['rating.rating'].create({
+ 'res_model_id': self.env['ir.model']._get('project.task').id,
+ 'res_id': first_task.id,
+ 'parent_res_model_id': self.env['ir.model']._get('project.project').id,
+ 'parent_res_id': self.project_pigs.id,
+ 'rated_partner_id': self.partner_2.id,
+ 'partner_id': self.partner_2.id,
+ 'rating': 5,
+ 'consumed': False,
+ })
+
+ rating_bad = self.env['rating.rating'].create({
+ 'res_model_id': self.env['ir.model']._get('project.task').id,
+ 'res_id': first_task.id,
+ 'parent_res_model_id': self.env['ir.model']._get('project.project').id,
+ 'parent_res_id': self.project_pigs.id,
+ 'rated_partner_id': self.partner_2.id,
+ 'partner_id': self.partner_2.id,
+ 'rating': 3,
+ 'consumed': True,
+ })
+
+ # We need to invalidate cache since it is not done automatically by the ORM
+ # Our One2Many is linked to a res_id (int) for which the orm doesn't create an inverse
+ first_task.invalidate_cache()
+
+ self.assertEqual(rating_good.rating_text, 'satisfied')
+ self.assertEqual(rating_bad.rating_text, 'not_satisfied')
+ self.assertEqual(first_task.rating_count, 1, "Task should have only one rating associated, since one is not consumed")
+ self.assertEqual(rating_good.parent_res_id, self.project_pigs.id)
+
+ self.assertEqual(self.project_goats.rating_percentage_satisfaction, -1)
+ self.assertEqual(self.project_pigs.rating_percentage_satisfaction, 0) # There is a rating but not a "great" on, just an "okay".
+
+ # Consuming rating_good
+ first_task.rating_apply(5, rating_good.access_token)
+
+ # We need to invalidate cache since it is not done automatically by the ORM
+ # Our One2Many is linked to a res_id (int) for which the orm doesn't create an inverse
+ first_task.invalidate_cache()
+
+ self.assertEqual(first_task.rating_count, 2, "Task should have two ratings associated with it")
+ self.assertEqual(rating_good.parent_res_id, self.project_pigs.id)
+ self.assertEqual(self.project_goats.rating_percentage_satisfaction, -1)
+ self.assertEqual(self.project_pigs.rating_percentage_satisfaction, 50)
+
+ # We change the task from project_pigs to project_goats, ratings should be associated with the new project
+ first_task.project_id = self.project_goats.id
+
+ # We need to invalidate cache since it is not done automatically by the ORM
+ # Our One2Many is linked to a res_id (int) for which the orm doesn't create an inverse
+ first_task.invalidate_cache()
+
+ self.assertEqual(rating_good.parent_res_id, self.project_goats.id)
+ self.assertEqual(self.project_goats.rating_percentage_satisfaction, 50)
+ self.assertEqual(self.project_pigs.rating_percentage_satisfaction, -1)