From 95a8d1b8fa6e1709874749976d8bc3b8936eb669 Mon Sep 17 00:00:00 2001 From: Simone Orsi Date: Fri, 20 Dec 2024 11:35:09 +0100 Subject: [PATCH 1/8] Add edi_purchase_ubl_output_oca --- edi_purchase_ubl_output_oca/README.rst | 1 + edi_purchase_ubl_output_oca/__init__.py | 1 + edi_purchase_ubl_output_oca/__manifest__.py | 18 +++++++++++++ .../components/__init__.py | 1 + .../components/generate.py | 27 +++++++++++++++++++ .../demo/edi_exchange_type.xml | 20 ++++++++++++++ .../readme/CONFIGURATION.rst | 7 +++++ .../readme/CONTRIBUTORS.rst | 1 + .../readme/DESCRIPTION.rst | 5 ++++ 9 files changed, 81 insertions(+) create mode 100644 edi_purchase_ubl_output_oca/README.rst create mode 100644 edi_purchase_ubl_output_oca/__init__.py create mode 100644 edi_purchase_ubl_output_oca/__manifest__.py create mode 100644 edi_purchase_ubl_output_oca/components/__init__.py create mode 100644 edi_purchase_ubl_output_oca/components/generate.py create mode 100644 edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml create mode 100644 edi_purchase_ubl_output_oca/readme/CONFIGURATION.rst create mode 100644 edi_purchase_ubl_output_oca/readme/CONTRIBUTORS.rst create mode 100644 edi_purchase_ubl_output_oca/readme/DESCRIPTION.rst diff --git a/edi_purchase_ubl_output_oca/README.rst b/edi_purchase_ubl_output_oca/README.rst new file mode 100644 index 000000000..a74415d00 --- /dev/null +++ b/edi_purchase_ubl_output_oca/README.rst @@ -0,0 +1 @@ +wait for the bot diff --git a/edi_purchase_ubl_output_oca/__init__.py b/edi_purchase_ubl_output_oca/__init__.py new file mode 100644 index 000000000..1377f57f5 --- /dev/null +++ b/edi_purchase_ubl_output_oca/__init__.py @@ -0,0 +1 @@ +from . import components diff --git a/edi_purchase_ubl_output_oca/__manifest__.py b/edi_purchase_ubl_output_oca/__manifest__.py new file mode 100644 index 000000000..0b2a232c2 --- /dev/null +++ b/edi_purchase_ubl_output_oca/__manifest__.py @@ -0,0 +1,18 @@ +# Copyright 2021 Camptocamp SA +# @author: Simone Orsi +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "EDI UBL Purchase", + "summary": """Handle outbound exchanges for purchases.""", + "version": "14.0.1.0.0", + "development_status": "Alpha", + "license": "AGPL-3", + "website": "https://github.com/OCA/edi", + "author": "Camptocamp, Odoo Community Association (OCA)", + "maintainers": ["simahawk"], + "depends": ["edi_purchase_oca", "edi_ubl_oca", "purchase_order_ubl"], + "demo": [ + "demo/edi_exchange_type.xml", + ], +} diff --git a/edi_purchase_ubl_output_oca/components/__init__.py b/edi_purchase_ubl_output_oca/components/__init__.py new file mode 100644 index 000000000..f839b0d3b --- /dev/null +++ b/edi_purchase_ubl_output_oca/components/__init__.py @@ -0,0 +1 @@ +from . import generate diff --git a/edi_purchase_ubl_output_oca/components/generate.py b/edi_purchase_ubl_output_oca/components/generate.py new file mode 100644 index 000000000..557344312 --- /dev/null +++ b/edi_purchase_ubl_output_oca/components/generate.py @@ -0,0 +1,27 @@ +# Copyright 2021 Camptocamp SA +# @author: Simone Orsi +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + + +from odoo.addons.component.core import Component + + +class EDIExchangePOGenerate(Component): + """Generate purchase orders.""" + + _name = "edi.output.ubl.purchase.order" + _inherit = "edi.component.output.mixin" + _usage = "output.generate.purchase.order" + + def generate(self): + return self._generate_ubl_xml() + + # TODO: add tests + def _generate_ubl_xml(self): + order = self.record + doc_type = order.get_ubl_purchase_order_doc_type() + if not doc_type: + raise NotImplementedError("TODO: handle no doc type") + version = order.get_ubl_version() + xml_string = order.generate_ubl_xml_string(doc_type, version=version) + return xml_string diff --git a/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml b/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml new file mode 100644 index 000000000..5c0428ba7 --- /dev/null +++ b/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml @@ -0,0 +1,20 @@ + + + + + Demo UBL PO out + demo_UBL_PO_out + output + {record_name}-{type.code}-{dt} + xml + + +components: + generate: + usage: output.generate.purchase.order + + + diff --git a/edi_purchase_ubl_output_oca/readme/CONFIGURATION.rst b/edi_purchase_ubl_output_oca/readme/CONFIGURATION.rst new file mode 100644 index 000000000..df94d54c5 --- /dev/null +++ b/edi_purchase_ubl_output_oca/readme/CONFIGURATION.rst @@ -0,0 +1,7 @@ +On your exchange type configured for UBL outbound exchanges use this conf in `advanced_settings_edit`:: + + components: + generate: + usage: output.generate.purchase.order + +That's it. diff --git a/edi_purchase_ubl_output_oca/readme/CONTRIBUTORS.rst b/edi_purchase_ubl_output_oca/readme/CONTRIBUTORS.rst new file mode 100644 index 000000000..f1c71bce1 --- /dev/null +++ b/edi_purchase_ubl_output_oca/readme/CONTRIBUTORS.rst @@ -0,0 +1 @@ +* Simone Orsi diff --git a/edi_purchase_ubl_output_oca/readme/DESCRIPTION.rst b/edi_purchase_ubl_output_oca/readme/DESCRIPTION.rst new file mode 100644 index 000000000..41f35c7a4 --- /dev/null +++ b/edi_purchase_ubl_output_oca/readme/DESCRIPTION.rst @@ -0,0 +1,5 @@ +Handle purchase exchanges with the EDI framework. + +This module is mostly a glue module for `purchase_order_ubl` with `edi_oca`. + +Allows you to generate and send purchase orders as UBL XML files. From 0e79c193e516d66d809af64bf7f6dc1066509d59 Mon Sep 17 00:00:00 2001 From: oca-ci Date: Wed, 11 Jun 2025 13:27:16 +0000 Subject: [PATCH 2/8] [UPD] Update edi_purchase_ubl_output_oca.pot --- .../i18n/edi_purchase_ubl_output_oca.pot | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 edi_purchase_ubl_output_oca/i18n/edi_purchase_ubl_output_oca.pot diff --git a/edi_purchase_ubl_output_oca/i18n/edi_purchase_ubl_output_oca.pot b/edi_purchase_ubl_output_oca/i18n/edi_purchase_ubl_output_oca.pot new file mode 100644 index 000000000..4d8b20f91 --- /dev/null +++ b/edi_purchase_ubl_output_oca/i18n/edi_purchase_ubl_output_oca.pot @@ -0,0 +1,13 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" From 00628d5e42ade8c56fd24396056373b89cb60962 Mon Sep 17 00:00:00 2001 From: OCA-git-bot Date: Wed, 11 Jun 2025 13:36:23 +0000 Subject: [PATCH 3/8] [BOT] post-merge updates --- edi_purchase_ubl_output_oca/README.rst | 98 +++- edi_purchase_ubl_output_oca/__manifest__.py | 2 +- .../static/description/icon.png | Bin 0 -> 10254 bytes .../static/description/index.html | 439 ++++++++++++++++++ 4 files changed, 537 insertions(+), 2 deletions(-) create mode 100644 edi_purchase_ubl_output_oca/static/description/icon.png create mode 100644 edi_purchase_ubl_output_oca/static/description/index.html diff --git a/edi_purchase_ubl_output_oca/README.rst b/edi_purchase_ubl_output_oca/README.rst index a74415d00..022885c57 100644 --- a/edi_purchase_ubl_output_oca/README.rst +++ b/edi_purchase_ubl_output_oca/README.rst @@ -1 +1,97 @@ -wait for the bot +.. image:: https://odoo-community.org/readme-banner-image + :target: https://odoo-community.org/get-involved?utm_source=readme + :alt: Odoo Community Association + +================ +EDI UBL Purchase +================ + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:64740d2084509ea5c625aeb34e7e20f2a11ffa3a8e3cb2e13c107092a4b438b2 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png + :target: https://odoo-community.org/page/development-status + :alt: Alpha +.. |badge2| image:: https://img.shields.io/badge/license-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fedi-lightgray.png?logo=github + :target: https://github.com/OCA/edi/tree/14.0/edi_purchase_ubl_output_oca + :alt: OCA/edi +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/edi-14-0/edi-14-0-edi_purchase_ubl_output_oca + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/edi&target_branch=14.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +Handle purchase exchanges with the EDI framework. + +This module is mostly a glue module for `purchase_order_ubl` with `edi_oca`. + +Allows you to generate and send purchase orders as UBL XML files. + +.. IMPORTANT:: + This is an alpha version, the data model and design can change at any time without warning. + Only for development or testing purpose, do not use in production. + `More details on development status `_ + +**Table of contents** + +.. contents:: + :local: + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +~~~~~~~ + +* Camptocamp + +Contributors +~~~~~~~~~~~~ + +* Simone Orsi + +Maintainers +~~~~~~~~~~~ + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +.. |maintainer-simahawk| image:: https://github.com/simahawk.png?size=40px + :target: https://github.com/simahawk + :alt: simahawk + +Current `maintainer `__: + +|maintainer-simahawk| + +This module is part of the `OCA/edi `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/edi_purchase_ubl_output_oca/__manifest__.py b/edi_purchase_ubl_output_oca/__manifest__.py index 0b2a232c2..d9cac3e5b 100644 --- a/edi_purchase_ubl_output_oca/__manifest__.py +++ b/edi_purchase_ubl_output_oca/__manifest__.py @@ -5,7 +5,7 @@ { "name": "EDI UBL Purchase", "summary": """Handle outbound exchanges for purchases.""", - "version": "14.0.1.0.0", + "version": "14.0.1.1.0", "development_status": "Alpha", "license": "AGPL-3", "website": "https://github.com/OCA/edi", diff --git a/edi_purchase_ubl_output_oca/static/description/icon.png b/edi_purchase_ubl_output_oca/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..1dcc49c24f364e9adf0afbc6fc0bac6dbecdeb11 GIT binary patch literal 10254 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 + + + + +README.rst + + + +
+ + + +Odoo Community Association + +
+

EDI UBL Purchase

+ +

Alpha License: AGPL-3 OCA/edi Translate me on Weblate Try me on Runboat

+

Handle purchase exchanges with the EDI framework.

+

This module is mostly a glue module for purchase_order_ubl with edi_oca.

+

Allows you to generate and send purchase orders as UBL XML files.

+
+

Important

+

This is an alpha version, the data model and design can change at any time without warning. +Only for development or testing purpose, do not use in production. +More details on development status

+
+

Table of contents

+ +
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Authors

+
    +
  • Camptocamp
  • +
+
+ +
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

Current maintainer:

+

simahawk

+

This module is part of the OCA/edi project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+
+ + From 9d83bd3bd11763dd30a43fbc09b3d71e9e39ba22 Mon Sep 17 00:00:00 2001 From: mymage Date: Tue, 22 Jul 2025 14:31:59 +0000 Subject: [PATCH 4/8] Added translation using Weblate (Italian) --- edi_purchase_ubl_output_oca/i18n/it.po | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 edi_purchase_ubl_output_oca/i18n/it.po diff --git a/edi_purchase_ubl_output_oca/i18n/it.po b/edi_purchase_ubl_output_oca/i18n/it.po new file mode 100644 index 000000000..9ce4346f6 --- /dev/null +++ b/edi_purchase_ubl_output_oca/i18n/it.po @@ -0,0 +1,14 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: Automatically generated\n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" From a6460c6ca965794e405ca75671a0b177209c44af Mon Sep 17 00:00:00 2001 From: Simone Orsi Date: Thu, 14 May 2026 15:13:10 +0200 Subject: [PATCH 5/8] [IMP] edi_purchase_ubl_output_oca: pre-commit auto fixes --- edi_purchase_ubl_output_oca/__manifest__.py | 2 +- edi_purchase_ubl_output_oca/pyproject.toml | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) create mode 100644 edi_purchase_ubl_output_oca/pyproject.toml diff --git a/edi_purchase_ubl_output_oca/__manifest__.py b/edi_purchase_ubl_output_oca/__manifest__.py index d9cac3e5b..af0946dd8 100644 --- a/edi_purchase_ubl_output_oca/__manifest__.py +++ b/edi_purchase_ubl_output_oca/__manifest__.py @@ -8,7 +8,7 @@ "version": "14.0.1.1.0", "development_status": "Alpha", "license": "AGPL-3", - "website": "https://github.com/OCA/edi", + "website": "https://github.com/OCA/edi-framework", "author": "Camptocamp, Odoo Community Association (OCA)", "maintainers": ["simahawk"], "depends": ["edi_purchase_oca", "edi_ubl_oca", "purchase_order_ubl"], diff --git a/edi_purchase_ubl_output_oca/pyproject.toml b/edi_purchase_ubl_output_oca/pyproject.toml new file mode 100644 index 000000000..4231d0ccc --- /dev/null +++ b/edi_purchase_ubl_output_oca/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" From 8757cbf3584dfdc138a33f333e39c52abe9b08e3 Mon Sep 17 00:00:00 2001 From: Simone Orsi Date: Thu, 14 May 2026 15:19:42 +0200 Subject: [PATCH 6/8] [MIG] edi_purchase_ubl_output_oca: migrate to v18 --- edi_purchase_ubl_output_oca/__init__.py | 2 +- edi_purchase_ubl_output_oca/__manifest__.py | 2 +- .../demo/edi_exchange_type.xml | 9 ++------- .../{components => models}/__init__.py | 0 .../{components => models}/generate.py | 19 +++++++++---------- 5 files changed, 13 insertions(+), 19 deletions(-) rename edi_purchase_ubl_output_oca/{components => models}/__init__.py (100%) rename edi_purchase_ubl_output_oca/{components => models}/generate.py (59%) diff --git a/edi_purchase_ubl_output_oca/__init__.py b/edi_purchase_ubl_output_oca/__init__.py index 1377f57f5..0650744f6 100644 --- a/edi_purchase_ubl_output_oca/__init__.py +++ b/edi_purchase_ubl_output_oca/__init__.py @@ -1 +1 @@ -from . import components +from . import models diff --git a/edi_purchase_ubl_output_oca/__manifest__.py b/edi_purchase_ubl_output_oca/__manifest__.py index af0946dd8..c9fcbbc7e 100644 --- a/edi_purchase_ubl_output_oca/__manifest__.py +++ b/edi_purchase_ubl_output_oca/__manifest__.py @@ -5,7 +5,7 @@ { "name": "EDI UBL Purchase", "summary": """Handle outbound exchanges for purchases.""", - "version": "14.0.1.1.0", + "version": "18.0.1.0.0", "development_status": "Alpha", "license": "AGPL-3", "website": "https://github.com/OCA/edi-framework", diff --git a/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml b/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml index 5c0428ba7..8d8cca6d1 100644 --- a/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml +++ b/edi_purchase_ubl_output_oca/demo/edi_exchange_type.xml @@ -8,13 +8,8 @@ {record_name}-{type.code}-{dt} xml - -components: - generate: - usage: output.generate.purchase.order - diff --git a/edi_purchase_ubl_output_oca/components/__init__.py b/edi_purchase_ubl_output_oca/models/__init__.py similarity index 100% rename from edi_purchase_ubl_output_oca/components/__init__.py rename to edi_purchase_ubl_output_oca/models/__init__.py diff --git a/edi_purchase_ubl_output_oca/components/generate.py b/edi_purchase_ubl_output_oca/models/generate.py similarity index 59% rename from edi_purchase_ubl_output_oca/components/generate.py rename to edi_purchase_ubl_output_oca/models/generate.py index 557344312..8ef69669c 100644 --- a/edi_purchase_ubl_output_oca/components/generate.py +++ b/edi_purchase_ubl_output_oca/models/generate.py @@ -2,23 +2,22 @@ # @author: Simone Orsi # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo import models -from odoo.addons.component.core import Component - -class EDIExchangePOGenerate(Component): +class EDIExchangePOGenerate(models.AbstractModel): """Generate purchase orders.""" + _description = "UBL output generator for purchase orders" + _name = "edi.output.ubl.purchase.order" - _inherit = "edi.component.output.mixin" - _usage = "output.generate.purchase.order" + _inherit = "edi.oca.handler.generate" - def generate(self): - return self._generate_ubl_xml() + def generate(self, exchange_record): + return self._generate_ubl_xml(exchange_record) - # TODO: add tests - def _generate_ubl_xml(self): - order = self.record + def _generate_ubl_xml(self, exchange_record): + order = exchange_record.record doc_type = order.get_ubl_purchase_order_doc_type() if not doc_type: raise NotImplementedError("TODO: handle no doc type") From 2abb951272c999b8609a6600a770396bc48cce43 Mon Sep 17 00:00:00 2001 From: Simone Orsi Date: Thu, 14 May 2026 16:28:10 +0200 Subject: [PATCH 7/8] [COV] edi_purchase_ubl_output_oca: add test cov --- edi_purchase_ubl_output_oca/tests/__init__.py | 1 + .../tests/test_generate.py | 98 +++++++++++++++++++ 2 files changed, 99 insertions(+) create mode 100644 edi_purchase_ubl_output_oca/tests/__init__.py create mode 100644 edi_purchase_ubl_output_oca/tests/test_generate.py diff --git a/edi_purchase_ubl_output_oca/tests/__init__.py b/edi_purchase_ubl_output_oca/tests/__init__.py new file mode 100644 index 000000000..427d09a22 --- /dev/null +++ b/edi_purchase_ubl_output_oca/tests/__init__.py @@ -0,0 +1 @@ +from . import test_generate diff --git a/edi_purchase_ubl_output_oca/tests/test_generate.py b/edi_purchase_ubl_output_oca/tests/test_generate.py new file mode 100644 index 000000000..e96497eb3 --- /dev/null +++ b/edi_purchase_ubl_output_oca/tests/test_generate.py @@ -0,0 +1,98 @@ +# Copyright 2026 Camptocamp SA +# @author Simone Orsi +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo.tests.common import TransactionCase + +from odoo.addons.purchase_order_ubl.tests.common import PurchaseOrderUblMixin + + +class TestPurchaseUBLOutputGenerate(PurchaseOrderUblMixin, TransactionCase): + """Ensure ``edi.output.ubl.purchase.order`` produces a valid UBL XML file.""" + + @classmethod + def setUpClass(cls): + super().setUpClass() + cls.env = cls.env( + context=dict( + cls.env.context, tracking_disable=True, edi__skip_quick_exec=True + ) + ) + cls._setup_purchase_ubl_records() + cls.backend_type = cls.env.ref("edi_ubl_oca.edi_backend_type_ubl") + cls.backend = cls.env["edi.backend"].create( + { + "name": "UBL purchase test backend", + "backend_type_id": cls.backend_type.id, + } + ) + generator_model = cls.env["ir.model"]._get("edi.output.ubl.purchase.order") + cls.exc_type = cls.env["edi.exchange.type"].create( + { + "name": "Test UBL PO out", + "code": "test_ubl_po_out", + "direction": "output", + "exchange_file_ext": "xml", + "exchange_filename_pattern": "{record.id}-{type.code}-{dt}", + "backend_id": cls.backend.id, + "backend_type_id": cls.backend_type.id, + "generate_model_id": generator_model.id, + } + ) + + def _create_exchange_record(self): + return self.backend.create_record( + self.exc_type.code, + {"model": self.order._name, "res_id": self.order.id}, + ) + + def _generate_xml(self, version): + record = self._create_exchange_record() + record.with_context(ubl_version=version).action_exchange_generate() + self.assertTrue(record.exchange_file) + return record._get_file_content() + + def test_generate_order_confirmed(self): + self.order.button_confirm() + self.assertEqual(self.order.state, "purchase") + for version in ("2.1", "2.2"): + with self.subTest(version=version): + xml_string = self._generate_xml(version) + self._assert_valid_ubl_xml(xml_string, "Order", version) + + def test_generate_rfq(self): + self.assertIn(self.order.state, self.order.get_rfq_states()) + for version in ("2.1", "2.2"): + with self.subTest(version=version): + xml_string = self._generate_xml(version) + self._assert_valid_ubl_xml(xml_string, "RequestForQuotation", version) + + def test_generate_skip_taxes_via_advanced_settings(self): + """``advanced_settings_edit`` must propagate ``env_ctx`` to generate. + + Setting ``ubl_add_item__skip_taxes: true`` on the ``generate`` + component env_ctx must result in no ``ClassifiedTaxCategory`` + nodes in the produced UBL XML. + """ + self.exc_type.advanced_settings_edit = ( + "components:\n" + " generate:\n" + " env_ctx:\n" + " ubl_add_item__skip_taxes: true\n" + ) + self.order.button_confirm() + xml_string = self._generate_xml("2.1") + parsed = self._assert_valid_ubl_xml(xml_string, "Order", "2.1") + tax_nodes = self._classified_tax_categories(parsed) + self.assertFalse( + tax_nodes, + "ClassifiedTaxCategory must be skipped when " + "ubl_add_item__skip_taxes is set via advanced_settings_edit", + ) + + def test_generate_taxes_included_by_default(self): + """Without any env_ctx, ClassifiedTaxCategory must be present.""" + self.order.button_confirm() + xml_string = self._generate_xml("2.1") + parsed = self._assert_valid_ubl_xml(xml_string, "Order", "2.1") + self.assertTrue(self._classified_tax_categories(parsed)) From 39ecea2112ed470882b7e92b206855764111e0c7 Mon Sep 17 00:00:00 2001 From: Simone Orsi Date: Thu, 14 May 2026 16:36:21 +0200 Subject: [PATCH 8/8] Add TMP test req --- test-requirements.txt | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/test-requirements.txt b/test-requirements.txt index a8133e4b5..fd9181bb0 100644 --- a/test-requirements.txt +++ b/test-requirements.txt @@ -1,2 +1,6 @@ odoo-test-helper xmlunittest + +odoo-addon-edi_core_oca @ git+https://github.com/OCA/edi-framework@refs/pull/275/head#subdirectory=edi_core_oca +odoo-addon-edi_purchase_oca @ git+https://github.com/OCA/edi-framework@refs/pull/276/head#subdirectory=edi_purchase_oca +odoo-addon-purchase_order_ubl @ git+https://github.com/OCA/edi@refs/pull/1342/head#subdirectory=purchase_order_ubl