You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
100 lines
3.7 KiB
100 lines
3.7 KiB
# Copyright 2020 Coop IT Easy SCRL fs
|
|
# Robin Keunen <robin@coopiteasy.be>
|
|
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
|
|
|
|
from psycopg2 import IntegrityError
|
|
|
|
import odoo
|
|
from odoo.fields import Date
|
|
from odoo.tests import TransactionCase
|
|
|
|
|
|
class TestExternalIdMixin(TransactionCase):
|
|
def test_res_partner_api_external_id(self):
|
|
partner = self.env["res.partner"].create({"name": "Test Partner"})
|
|
self.assertFalse(partner._api_external_id)
|
|
self.assertFalse(partner.external_id_sequence_id)
|
|
|
|
external_id = partner.get_api_external_id()
|
|
self.assertTrue(bool(partner._api_external_id))
|
|
self.assertTrue(bool(partner.external_id_sequence_id))
|
|
|
|
self.assertEquals(external_id, partner.get_api_external_id())
|
|
|
|
def test_subscription_request_api_external_id(self):
|
|
share_type = self.browse_ref(
|
|
"easy_my_coop.product_template_share_type_2_demo"
|
|
).product_variant_id
|
|
sr = self.env["subscription.request"].create(
|
|
{
|
|
"name": "test create request",
|
|
"email": "test@demo.net",
|
|
"address": "schaerbeekstraat",
|
|
"zip_code": "1111",
|
|
"city": "Brussels",
|
|
"country_id": self.ref("base.be"),
|
|
"date": Date.today(),
|
|
"source": "manual",
|
|
"ordered_parts": 3,
|
|
"share_product_id": share_type.id,
|
|
"lang": "en_US",
|
|
}
|
|
)
|
|
self.assertFalse(sr._api_external_id)
|
|
self.assertFalse(sr.external_id_sequence_id)
|
|
|
|
external_id = sr.get_api_external_id()
|
|
self.assertTrue(bool(sr._api_external_id))
|
|
self.assertTrue(bool(sr.external_id_sequence_id))
|
|
|
|
self.assertEquals(external_id, sr.get_api_external_id())
|
|
|
|
def test_account_journal_api_external_id(self):
|
|
bank = self.env["res.partner.bank"].create(
|
|
{
|
|
"acc_number": "test",
|
|
"partner_id": self.env.user.company_id.partner_id.id,
|
|
}
|
|
)
|
|
journal = self.env["account.journal"].create(
|
|
{
|
|
"name": "test journal",
|
|
"code": "123",
|
|
"type": "bank",
|
|
"company_id": self.env.ref("base.main_company").id,
|
|
"bank_account_id": bank.id,
|
|
}
|
|
)
|
|
self.assertFalse(journal._api_external_id)
|
|
self.assertFalse(journal.external_id_sequence_id)
|
|
|
|
external_id = journal.get_api_external_id()
|
|
self.assertTrue(bool(journal._api_external_id))
|
|
self.assertTrue(bool(journal.external_id_sequence_id))
|
|
|
|
self.assertEquals(external_id, journal.get_api_external_id())
|
|
|
|
def test_account_invoice_api_external_id(self):
|
|
invoice = self.env["account.invoice"].create({"name": "create passes"})
|
|
self.assertFalse(invoice._api_external_id)
|
|
self.assertFalse(invoice.external_id_sequence_id)
|
|
|
|
external_id = invoice.get_api_external_id()
|
|
self.assertTrue(bool(invoice._api_external_id))
|
|
self.assertTrue(bool(invoice.external_id_sequence_id))
|
|
|
|
self.assertEquals(external_id, invoice.get_api_external_id())
|
|
|
|
@odoo.tools.mute_logger("odoo.sql_db")
|
|
def test_duplicate_api_external_id_raises(self):
|
|
invoice_1 = self.env["account.invoice"].create(
|
|
{"name": "create passes"}
|
|
)
|
|
external_id = invoice_1.get_api_external_id()
|
|
self.assertTrue(bool(invoice_1._api_external_id))
|
|
|
|
invoice_2 = self.env["account.invoice"].create(
|
|
{"name": "create passes"}
|
|
)
|
|
with self.assertRaises(IntegrityError):
|
|
invoice_2._api_external_id = external_id
|