Skip to content

Commit

Permalink
Merge PR #1068 into 16.0
Browse files Browse the repository at this point in the history
Signed-off-by jbaudoux
  • Loading branch information
OCA-git-bot committed Jan 8, 2025
2 parents acb5645 + 8e6280a commit d35a89c
Show file tree
Hide file tree
Showing 22 changed files with 146 additions and 127 deletions.
2 changes: 2 additions & 0 deletions base_wamas_ubl/lib/test_wamas2dict
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
#!/usr/bin/sh
/usr/bin/env python3 -m wamas.tests.test_wamas2dict
3 changes: 3 additions & 0 deletions base_wamas_ubl/lib/wamas/dict2wamas.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
from ast import literal_eval
from pprint import pformat

from freezegun import freeze_time

from . import const, utils

_logger = logging.getLogger("json2wamas")
Expand Down Expand Up @@ -60,6 +62,7 @@ def dict2wamas(dict_input, msg_type):
return wamas


@freeze_time("2024-02-11 22:14:22")
def main():
parser = argparse.ArgumentParser(
description="Converts JSON document into message.",
Expand Down
7 changes: 7 additions & 0 deletions base_wamas_ubl/lib/wamas/tests/test_dict2wamas.py
Original file line number Diff line number Diff line change
@@ -1,11 +1,16 @@
import ast
import unittest

from freezegun import freeze_time

from ..dict2wamas import dict2wamas
from ..utils import file_open, file_path


class TestDict2wamas(unittest.TestCase):

maxDiff = None

def _test(self, msg_type, filename):
with file_open(
file_path("tests/samples/dict2wamas_input%s.dict" % filename)
Expand All @@ -17,9 +22,11 @@ def _test(self, msg_type, filename):
expected_output = outfile.read()
self.assertEqual(output, expected_output)

@freeze_time("2024-02-11 22:14:22")
def test_LST(self):
self._test("Supplier", "")

@freeze_time("2024-02-11 22:15:32")
def test_KSTAUS(self):
self._test("CustomerDeliveryPreferences", "_2")

Expand Down
39 changes: 38 additions & 1 deletion base_wamas_ubl/lib/wamas/tests/test_ubl2wamas.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,16 @@
import unittest
from datetime import date, datetime

from ..utils import set_value_to_string
from freezegun import freeze_time

from ..ubl2wamas import ubl2wamas
from ..utils import file_open, file_path, set_value_to_string


class TestUbl2wamas(unittest.TestCase):

maxDiff = None

def test_helpers(self):
dict_data = {
"str": [
Expand Down Expand Up @@ -99,6 +105,37 @@ def test_helpers(self):
)
self.assertEqual(output_val, expected_output_val)

@freeze_time("2023-05-01")
def _convert_ubl2wamas(
self, input_filename, expected_output_filename, telegram_type
):
path = file_path("tests/samples/")
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
output = ubl2wamas(str_input, telegram_type)
expected_output = outputfile.read().strip("\n")
self.assertEqual(output, expected_output)

def test_convert_ubl2wamas_picking(self):
input_file = "UBL2WAMAS-SAMPLE_AUSK_AUSP-DESPATCH_ADVICE2.xml"
expected_output = "UBL2WAMAS-SAMPLE_AUSK_AUSP.wamas"
msg_type = "Picking"
self._convert_ubl2wamas(input_file, expected_output, msg_type)

def test_convert_ubl2wamas_reception(self):
input_file = "UBL2WAMAS-SAMPLE_WEAK_WEAP-DESPATCH_ADVICE.xml"
expected_output = "UBL2WAMAS-SAMPLE_WEAK_WEAP.wamas"
msg_type = "Reception"
self._convert_ubl2wamas(input_file, expected_output, msg_type)

def test_convert_ubl2wamas_return(self):
input_file = "UBL2WAMAS-SAMPLE_KRETK_KRETP-DESPATCH_ADVICE.xml"
expected_output = "UBL2WAMAS-SAMPLE_KRETK_KRETP.wamas"
msg_type = "Return"
self._convert_ubl2wamas(input_file, expected_output, msg_type)


if __name__ == "__main__":
unittest.main()
37 changes: 37 additions & 0 deletions base_wamas_ubl/lib/wamas/tests/test_wamas2dict.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Copyright 2023 Jacques-Etienne Baudoux (BCIM) <[email protected]>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

import unittest
from pprint import pformat

from ..utils import file_open, file_path
from ..wamas2ubl import wamas2dict


class TestWamas2dict(unittest.TestCase):

maxDiff = None

def _test(self, filename):
with file_open(
file_path("tests/samples/%s.wamas" % filename)
) as infile, file_open(
file_path("tests/samples/%s.dict" % filename)
) as outfile:
str_input = infile.read()
expected_output = outfile.read()
output_prettified = pformat(wamas2dict(str_input))
self.assertEqual(output_prettified, expected_output)

def test_normal(self):
self._test("line_WATEPQ_-_normal")

def test_non_ascii(self):
self._test("line_WATEPQ_-_non_ascii")

def test_length_off(self):
self._test("line_WATEKQ_-_length_off_by_one_01")


if __name__ == "__main__":
unittest.main()
58 changes: 34 additions & 24 deletions base_wamas_ubl/lib/wamas/tests/test_wamas2ubl.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,32 +2,42 @@
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

import unittest
from pprint import pformat

from ..utils import file_open, file_path
from ..wamas2ubl import wamas2dict


class TestWamas2dict(unittest.TestCase):
def _test(self, filename):
with file_open(
file_path("tests/samples/%s.wamas" % filename)
) as infile, file_open(
file_path("tests/samples/%s.dict" % filename)
) as outfile:
str_input = infile.read()
expected_output = outfile.read()
output_prettified = pformat(wamas2dict(str_input))
self.assertEqual(output_prettified, expected_output)
from freezegun import freeze_time

def test_normal(self):
self._test("line_WATEPQ_-_normal")

def test_non_ascii(self):
self._test("line_WATEPQ_-_non_ascii")

def test_length_off(self):
self._test("line_WATEKQ_-_length_off_by_one_01")
from ..utils import file_open, file_path
from ..wamas2ubl import wamas2ubl


class TestWamas2ubl(unittest.TestCase):

maxDiff = None

@freeze_time("2023-05-01")
def _convert_wamas2ubl(self, input_filename, expected_output_filename):
path = file_path("tests/samples/")
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
output = "\n".join(wamas2ubl(str_input))
expected_output = outputfile.read()
self.assertEqual(output, expected_output)

def test_convert_wamas2ubl_picking(self):
input_file = "WAMAS2UBL-SAMPLE_AUSKQ_WATEKQ_WATEPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_AUSKQ_WATEKQ_WATEPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)

def test_convert_wamas2ubl_reception(self):
input_file = "WAMAS2UBL-SAMPLE_WEAKQ_WEAPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_WEAKQ_WEAPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)

def test_convert_wamas2ubl_return(self):
input_file = "WAMAS2UBL-SAMPLE_KRETKQ_KRETPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_KRETKQ_KRETPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)


if __name__ == "__main__":
Expand Down
3 changes: 3 additions & 0 deletions base_wamas_ubl/lib/wamas/tests/test_wamas2wamas.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@


class TestWamas2wamas(unittest.TestCase):

maxDiff = None

def _test(self, filename):
with file_open(
file_path("tests/samples/wamas2wamas_input_%s.wamas" % filename)
Expand Down
2 changes: 1 addition & 1 deletion base_wamas_ubl/lib/wamas/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -408,7 +408,7 @@ def fw2dict(line, grammar, telegram_type):
dp = fdef["dp"]
val = float(b[:-dp] + "." + b[-dp:])
else:
val = escape(b.rstrip())
val = str(escape(b.rstrip()))
res[fname] = val
_logger.debug(pformat(res))
return res
Expand Down
15 changes: 15 additions & 0 deletions base_wamas_ubl/tests/test_base_wamas_ubl.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
# Copyright 2023 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

from ast import literal_eval
from base64 import b64decode, b64encode

from freezegun import freeze_time
Expand Down Expand Up @@ -153,3 +154,17 @@ def test_wamas_ubl_wiz_simulate(self):
"base_wamas_ubl/tests/samples/SIMULATEWAMAS-SAMPLE_OUTPUT-EXCEPTION.txt",
"fail",
)

@freeze_time("2023-12-21 04:12:51")
def test_get_wamas_type(self):
input_filename = "CHECKWAMAS-SAMPLE_INPUT.wamas"
expected_output_filename = "CHECKWAMAS-SAMPLE_OUTPUT.dict"
path = "base_wamas_ubl/tests/samples/"
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
dict_expected_output = literal_eval(outputfile.read())
wamas_type = self.base_wamas_ubl.get_wamas_type(str_input)
# Wamas Type
self.assertEqual(wamas_type, dict_expected_output["wamas_type"])
107 changes: 6 additions & 101 deletions base_wamas_ubl/tests/test_wamas_lib.py
Original file line number Diff line number Diff line change
@@ -1,104 +1,9 @@
# Copyright 2023 Jacques-Etienne Baudoux (BCIM) <[email protected]>
# Copyright 2023 Camptocamp SA
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).

from ast import literal_eval

from freezegun import freeze_time

from odoo.tests.common import TransactionCase
from odoo.tools import file_open

# FIXME: all those simple convertion tests should move to lib/wamas/tests and
# there should be a test that runs the lib tests


class TestWamasLib(TransactionCase):
@classmethod
def setUpClass(cls):
super().setUpClass()
cls.base_wamas_ubl = cls.env["base.wamas.ubl"]

@freeze_time("2023-05-01")
def _convert_wamas2ubl(self, input_filename, expected_output_filename):
path = "base_wamas_ubl/tests/samples/"
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
output = "\n".join(self.base_wamas_ubl.wamas2ubl(str_input))
expected_output = outputfile.read()
self.assertEqual(output, expected_output)

def test_convert_wamas2ubl_picking(self):
input_file = "WAMAS2UBL-SAMPLE_AUSKQ_WATEKQ_WATEPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_AUSKQ_WATEKQ_WATEPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)

def test_convert_wamas2ubl_reception(self):
input_file = "WAMAS2UBL-SAMPLE_WEAKQ_WEAPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_WEAKQ_WEAPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)

def test_convert_wamas2ubl_return(self):
input_file = "WAMAS2UBL-SAMPLE_KRETKQ_KRETPQ.wamas"
lst_expected_output = "WAMAS2UBL-SAMPLE_KRETKQ_KRETPQ-DESPATCH_ADVICE.xml"
self._convert_wamas2ubl(input_file, lst_expected_output)

@freeze_time("2023-05-01")
def _convert_ubl2wamas(
self, input_filename, expected_output_filename, telegram_type
):
path = "base_wamas_ubl/tests/samples/"
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
output = self.base_wamas_ubl.ubl2wamas(str_input, telegram_type)
expected_output = outputfile.read().strip("\n")
self.assertEqual(output, expected_output)

def test_convert_ubl2wamas_picking(self):
input_file = "UBL2WAMAS-SAMPLE_AUSK_AUSP-DESPATCH_ADVICE.xml"
expected_output = "UBL2WAMAS-SAMPLE_AUSK_AUSP.wamas"
msg_type = "Picking"
self._convert_ubl2wamas(input_file, expected_output, msg_type)

def test_convert_ubl2wamas_reception(self):
input_file = "UBL2WAMAS-SAMPLE_WEAK_WEAP-DESPATCH_ADVICE.xml"
expected_output = "UBL2WAMAS-SAMPLE_WEAK_WEAP.wamas"
msg_type = "Reception"
self._convert_ubl2wamas(input_file, expected_output, msg_type)

def test_convert_ubl2wamas_return(self):
input_file = "UBL2WAMAS-SAMPLE_KRETK_KRETP-DESPATCH_ADVICE.xml"
expected_output = "UBL2WAMAS-SAMPLE_KRETK_KRETP.wamas"
msg_type = "Return"
self._convert_ubl2wamas(input_file, expected_output, msg_type)

@freeze_time("2023-12-21 04:12:51")
def test_export_dict2wamas(self):
input_filename = "DICT2WAMAS-SAMPLE_INPUT.dict"
expected_output_filename = "DICT2WAMAS-SAMPLE_OUTPUT.wamas"
path = "base_wamas_ubl/tests/samples/"
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
dict_input = literal_eval(inputfile.read())
output = self.base_wamas_ubl.dict2wamas(dict_input, "Supplier")
expected_output = outputfile.read()
self.assertEqual(output, expected_output)

@freeze_time("2023-12-21 04:12:51")
def test_get_wamas_type(self):
input_filename = "CHECKWAMAS-SAMPLE_INPUT.wamas"
expected_output_filename = "CHECKWAMAS-SAMPLE_OUTPUT.dict"
path = "base_wamas_ubl/tests/samples/"
with file_open(path + input_filename) as inputfile, file_open(
path + expected_output_filename
) as outputfile:
str_input = inputfile.read()
dict_expected_output = literal_eval(outputfile.read())
wamas_type = self.base_wamas_ubl.get_wamas_type(str_input)
# Wamas Type
self.assertEqual(wamas_type, dict_expected_output["wamas_type"])
from ..lib.wamas.tests.test_dict2wamas import * # noqa: F401,F403
from ..lib.wamas.tests.test_ubl2wamas import * # noqa: F401,F403
from ..lib.wamas.tests.test_utils import * # noqa: F401,F403
from ..lib.wamas.tests.test_wamas2dict import * # noqa: F401,F403
from ..lib.wamas.tests.test_wamas2ubl import * # noqa: F401,F403
from ..lib.wamas.tests.test_wamas2wamas import * # noqa: F401,F403

0 comments on commit d35a89c

Please sign in to comment.