diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/hr_expense/tests/test_expenses_mail_import.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/hr_expense/tests/test_expenses_mail_import.py')
| -rw-r--r-- | addons/hr_expense/tests/test_expenses_mail_import.py | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/addons/hr_expense/tests/test_expenses_mail_import.py b/addons/hr_expense/tests/test_expenses_mail_import.py new file mode 100644 index 00000000..9f6db49a --- /dev/null +++ b/addons/hr_expense/tests/test_expenses_mail_import.py @@ -0,0 +1,153 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. +from odoo.addons.hr_expense.tests.common import TestExpenseCommon +from odoo.tests import tagged + + +@tagged('-at_install', 'post_install') +class TestExpensesMailImport(TestExpenseCommon): + + @classmethod + def setUpClass(cls, chart_template_ref=None): + super().setUpClass(chart_template_ref=chart_template_ref) + + cls.product_a.default_code = 'product_a' + cls.product_b.default_code = 'product_b' + + def test_import_expense_from_email(self): + message_parsed = { + 'message_id': "the-world-is-a-ghetto", + 'subject': '%s %s' % (self.product_a.default_code, self.product_a.standard_price), + 'email_from': self.expense_user_employee.email, + 'to': 'catchall@yourcompany.com', + 'body': "Don't you know, that for me, and for you", + 'attachments': [], + } + + expense = self.env['hr.expense'].message_new(message_parsed) + + self.assertRecordValues(expense, [{ + 'product_id': self.product_a.id, + 'total_amount': 920.0, + 'employee_id': self.expense_employee.id, + }]) + + def test_import_expense_from_email_no_product(self): + message_parsed = { + 'message_id': "the-world-is-a-ghetto", + 'subject': 'no product code 800', + 'email_from': self.expense_user_employee.email, + 'to': 'catchall@yourcompany.com', + 'body': "Don't you know, that for me, and for you", + 'attachments': [], + } + + expense = self.env['hr.expense'].message_new(message_parsed) + + self.assertRecordValues(expense, [{ + 'product_id': False, + 'total_amount': 800.0, + 'employee_id': self.expense_employee.id, + }]) + + def test_import_expense_from_mail_parsing_subjects(self): + + def assertParsedValues(subject, currencies, exp_description, exp_amount, exp_product): + product, amount, currency_id, description = self.env['hr.expense']\ + .with_user(self.expense_user_employee)\ + ._parse_expense_subject(subject, currencies) + + self.assertEqual(product, exp_product) + self.assertAlmostEqual(amount, exp_amount) + self.assertEqual(description, exp_description) + + # Without Multi currency access + assertParsedValues( + "product_a bar $1205.91 electro wizard", + self.company_data['currency'], + "bar electro wizard", + 1205.91, + self.product_a, + ) + + # subject having other currency then company currency, it should ignore other currency then company currency + assertParsedValues( + "foo bar %s1406.91 royal giant" % self.currency_data['currency'].symbol, + self.company_data['currency'], + "foo bar %s royal giant" % self.currency_data['currency'].symbol, + 1406.91, + self.env['product.product'], + ) + + # With Multi currency access + self.expense_user_employee.groups_id |= self.env.ref('base.group_multi_currency') + + assertParsedValues( + "product_a foo bar $2205.92 elite barbarians", + self.company_data['currency'], + "foo bar elite barbarians", + 2205.92, + self.product_a, + ) + + # subject having other currency then company currency, it should accept other currency because multi currency is activated + assertParsedValues( + "product_a %s2510.90 chhota bheem" % self.currency_data['currency'].symbol, + self.company_data['currency'] + self.currency_data['currency'], + "chhota bheem", + 2510.90, + self.product_a, + ) + + # subject without product and currency, should take company currency and default product + assertParsedValues( + "foo bar 109.96 spear goblins", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar spear goblins", + 109.96, + self.env['product.product'], + ) + + # subject with currency symbol at end + assertParsedValues( + "product_a foo bar 2910.94$ inferno dragon", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar inferno dragon", + 2910.94, + self.product_a, + ) + + # subject with no amount and product + assertParsedValues( + "foo bar mega knight", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar mega knight", + 0.0, + self.env['product.product'], + ) + + # price with a comma + assertParsedValues( + "foo bar 291,56$ mega knight", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar mega knight", + 291.56, + self.env['product.product'], + ) + + # price without decimals + assertParsedValues( + "foo bar 291$ mega knight", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar mega knight", + 291.0, + self.env['product.product'], + ) + + assertParsedValues( + "product_a foo bar 291.5$ mega knight", + self.company_data['currency'] + self.currency_data['currency'], + "foo bar mega knight", + 291.5, + self.product_a, + ) |
