Docker command: python3 odoo/odoo-bin --addons-path kmitl,stock-logistics-warehouse,stock-logistics-request,product-attribute,social,account-analytic,partner-contact,operating-unit,agreement,server-backend,account-reconcile,mis-builder,reporting-engine,odoo/addons,odoo/odoo/addons,account-financial-reporting,project,server-tools,server-ux,hr,account-financial-tools,web,account-invoicing,purchase-workflow,server-brand,l10n-thailand,odoo-modules --workers 2 --gevent-port 8070 --max-cron-threads 1 -d 10270-16-0-without_demo --proxy-mode --db-filter %d.*$ --smtp 172.17.0.1 --without-demo=true ================================================= Adding readonly volume '/data/build/kmitl' pointing to /home/runbot/odoo/runbot/runbot/static/sources/kmitl/3de7d2530c05b73f965e003f6623058f8e0600a3 Adding readonly volume '/data/build/stock-logistics-warehouse' pointing to /home/runbot/odoo/runbot/runbot/static/sources/stock-logistics-warehouse/4ded282901dbe451243face1dc503e9ed1b620a9 Adding readonly volume '/data/build/stock-logistics-request' pointing to /home/runbot/odoo/runbot/runbot/static/sources/stock-logistics-request/fa8a67256aee66a5bd67b1b18d23c14f1b7b9813 Adding readonly volume '/data/build/product-attribute' pointing to /home/runbot/odoo/runbot/runbot/static/sources/product-attribute/38ea6888224751633abae5815935e3a545ae1256 Adding readonly volume '/data/build/social' pointing to /home/runbot/odoo/runbot/runbot/static/sources/social/6c3434b688ebe352c732a21a1d407dc3a0a36bec Adding readonly volume '/data/build/account-analytic' pointing to /home/runbot/odoo/runbot/runbot/static/sources/account-analytic/fec6e3417836f7ad13ebd4d27283e261bc07d73a Adding readonly volume '/data/build/partner-contact' pointing to /home/runbot/odoo/runbot/runbot/static/sources/partner-contact/7acbeb8d0c21198d69a70ba1b1452a78e2a7aa55 Adding readonly volume '/data/build/operating-unit' pointing to /home/runbot/odoo/runbot/runbot/static/sources/operating-unit/dd59492d9e04ec4e642f47fbd50171ee0ffb7cf1 Adding readonly volume '/data/build/agreement' pointing to /home/runbot/odoo/runbot/runbot/static/sources/agreement/800e753cb5b92e131c5e36187a108ea4ca53327e Adding readonly volume '/data/build/server-backend' pointing to /home/runbot/odoo/runbot/runbot/static/sources/server-backend/ccf608782f610e261b1b5f72e8424c2dab99240e Adding readonly volume '/data/build/account-reconcile' pointing to /home/runbot/odoo/runbot/runbot/static/sources/account-reconcile/c031db9d53d140afdf1991a5523ee1ee092fb4b5 Adding readonly volume '/data/build/mis-builder' pointing to /home/runbot/odoo/runbot/runbot/static/sources/mis-builder/82d391759055ce801b41a2f01b1b3ab376772648 Adding readonly volume '/data/build/reporting-engine' pointing to /home/runbot/odoo/runbot/runbot/static/sources/reporting-engine/4cafaadb095d80094848d2798efb1c304861bff6 Adding readonly volume '/data/build/odoo' pointing to /home/runbot/odoo/runbot/runbot/static/sources/odoo/6491e0054d0437fb77913921e1fd3cd42894d883 Adding readonly volume '/data/build/account-financial-reporting' pointing to /home/runbot/odoo/runbot/runbot/static/sources/account-financial-reporting/948901d96ccb79b4826b408a1ca7cede4c537e6d Adding readonly volume '/data/build/project' pointing to /home/runbot/odoo/runbot/runbot/static/sources/project/7a5c615cba09f592cd08dbf4651b99cda015affe Adding readonly volume '/data/build/server-tools' pointing to /home/runbot/odoo/runbot/runbot/static/sources/server-tools/3abe25d79aab954027f4c5a8ba687c36270bab14 Adding readonly volume '/data/build/server-ux' pointing to /home/runbot/odoo/runbot/runbot/static/sources/server-ux/23e96d195dd78187789f42264a206350e470b01c Adding readonly volume '/data/build/hr' pointing to /home/runbot/odoo/runbot/runbot/static/sources/hr/3af635cbe54e9c75ef90cd63b98ed4455052d6b9 Adding readonly volume '/data/build/account-financial-tools' pointing to /home/runbot/odoo/runbot/runbot/static/sources/account-financial-tools/c3b3e7dd5e286fff8aac66ad80786e0dbec8138c Adding readonly volume '/data/build/web' pointing to /home/runbot/odoo/runbot/runbot/static/sources/web/fb9be06e9da8d720c834788c1b9f41acb51c600e Adding readonly volume '/data/build/account-invoicing' pointing to /home/runbot/odoo/runbot/runbot/static/sources/account-invoicing/7207e6e26a87963ceb058e74180001ba9c9b703c Adding readonly volume '/data/build/purchase-workflow' pointing to /home/runbot/odoo/runbot/runbot/static/sources/purchase-workflow/ecf70d6c2eb670c11b39ca20541306962f7ef39d Adding readonly volume '/data/build/server-brand' pointing to /home/runbot/odoo/runbot/runbot/static/sources/server-brand/2bc45d771dd696bd99a18c2219fa835288372372 Adding readonly volume '/data/build/l10n-thailand' pointing to /home/runbot/odoo/runbot/runbot/static/sources/l10n-thailand/0b7b078e68b0147a4f1a335839f99b7360110448 Adding readonly volume '/data/build/odoo-modules' pointing to /home/runbot/odoo/runbot/runbot/static/sources/odoo-modules/7652967336542a595e1847fa8dceb6a6a23d81c3 Adding readonly volume '/home/runbot/.odoorc' pointing to /home/runbot/odoo/runbot/runbot/static/build/10270-16-0/.odoorc WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting openupgradelib (from -r stock-logistics-warehouse/requirements.txt (line 2)) Downloading openupgradelib-3.12.0-py2.py3-none-any.whl.metadata (10 kB) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from openupgradelib->-r stock-logistics-warehouse/requirements.txt (line 2)) (5.2.1) Collecting cssselect (from openupgradelib->-r stock-logistics-warehouse/requirements.txt (line 2)) Downloading cssselect-1.4.0-py3-none-any.whl.metadata (2.4 kB) Downloading openupgradelib-3.12.0-py2.py3-none-any.whl (85 kB) Downloading cssselect-1.4.0-py3-none-any.whl (18 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: cssselect, openupgradelib Successfully installed cssselect-1.4.0 openupgradelib-3.12.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: freezegun in /usr/lib/python3/dist-packages (from -r product-attribute/requirements.txt (line 2)) (1.2.1) Requirement already satisfied: openupgradelib in /home/runbot/.local/lib/python3.12/site-packages (from -r product-attribute/requirements.txt (line 3)) (3.12.0) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from openupgradelib->-r product-attribute/requirements.txt (line 3)) (5.2.1) Requirement already satisfied: cssselect in /home/runbot/.local/lib/python3.12/site-packages (from openupgradelib->-r product-attribute/requirements.txt (line 3)) (1.4.0) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting cairosvg (from -r social/requirements.txt (line 2)) Downloading cairosvg-2.9.0-py3-none-any.whl.metadata (2.7 kB) Collecting cryptography<37 (from -r social/requirements.txt (line 3)) Downloading cryptography-36.0.2-cp36-abi3-manylinux_2_24_x86_64.whl.metadata (5.4 kB) Collecting extract_msg (from -r social/requirements.txt (line 4)) Downloading extract_msg-0.55.0-py3-none-any.whl.metadata (15 kB) Collecting lottie (from -r social/requirements.txt (line 5)) Downloading lottie-0.7.2.tar.gz (172 kB) Preparing metadata (setup.py): started Preparing metadata (setup.py): finished with status 'done' Requirement already satisfied: odoo_test_helper in /usr/local/lib/python3.12/dist-packages (from -r social/requirements.txt (line 6)) (2.1.3) Collecting premailer (from -r social/requirements.txt (line 7)) Downloading premailer-3.10.0-py2.py3-none-any.whl.metadata (15 kB) Collecting python-telegram-bot (from -r social/requirements.txt (line 8)) Downloading python_telegram_bot-22.7-py3-none-any.whl.metadata (17 kB) Requirement already satisfied: requests_toolbelt in /usr/lib/python3/dist-packages (from -r social/requirements.txt (line 9)) (1.0.0) Collecting cairocffi (from cairosvg->-r social/requirements.txt (line 2)) Downloading cairocffi-1.7.1-py3-none-any.whl.metadata (3.3 kB) Collecting cssselect2 (from cairosvg->-r social/requirements.txt (line 2)) Downloading cssselect2-0.9.0-py3-none-any.whl.metadata (2.9 kB) Requirement already satisfied: defusedxml in /usr/lib/python3/dist-packages (from cairosvg->-r social/requirements.txt (line 2)) (0.7.1) Requirement already satisfied: pillow in /usr/lib/python3/dist-packages (from cairosvg->-r social/requirements.txt (line 2)) (10.2.0) Collecting tinycss2 (from cairosvg->-r social/requirements.txt (line 2)) Downloading tinycss2-1.5.1-py3-none-any.whl.metadata (3.0 kB) Requirement already satisfied: cffi>=1.12 in /usr/local/lib/python3.12/dist-packages (from cryptography<37->-r social/requirements.txt (line 3)) (2.0.0) Collecting olefile==0.47 (from extract_msg->-r social/requirements.txt (line 4)) Downloading olefile-0.47-py2.py3-none-any.whl.metadata (9.7 kB) Collecting tzlocal<6,>=4.2 (from extract_msg->-r social/requirements.txt (line 4)) Downloading tzlocal-5.3.1-py3-none-any.whl.metadata (7.6 kB) Collecting compressed-rtf<2,>=1.0.6 (from extract_msg->-r social/requirements.txt (line 4)) Downloading compressed_rtf-1.0.7-py3-none-any.whl.metadata (2.4 kB) Collecting ebcdic<2,>=1.1.1 (from extract_msg->-r social/requirements.txt (line 4)) Downloading ebcdic-1.1.1-py2.py3-none-any.whl.metadata (8.9 kB) Requirement already satisfied: beautifulsoup4<4.14,>=4.11.1 in /usr/lib/python3/dist-packages (from extract_msg->-r social/requirements.txt (line 4)) (4.12.3) Collecting RTFDE<0.2,>=0.1.1 (from extract_msg->-r social/requirements.txt (line 4)) Downloading rtfde-0.1.2.2-py3-none-any.whl.metadata (4.1 kB) Collecting red-black-tree-mod<=1.23,>=1.20 (from extract_msg->-r social/requirements.txt (line 4)) Downloading red-black-tree-mod-1.22.tar.gz (34 kB) Preparing metadata (setup.py): started Preparing metadata (setup.py): finished with status 'done' Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from premailer->-r social/requirements.txt (line 7)) (5.2.1) Requirement already satisfied: cssselect in /home/runbot/.local/lib/python3.12/site-packages (from premailer->-r social/requirements.txt (line 7)) (1.4.0) Collecting cssutils (from premailer->-r social/requirements.txt (line 7)) Downloading cssutils-2.11.1-py3-none-any.whl.metadata (8.7 kB) Requirement already satisfied: requests in /usr/lib/python3/dist-packages (from premailer->-r social/requirements.txt (line 7)) (2.31.0) Collecting cachetools (from premailer->-r social/requirements.txt (line 7)) Downloading cachetools-7.0.5-py3-none-any.whl.metadata (5.6 kB) Collecting httpx<0.29,>=0.27 (from python-telegram-bot->-r social/requirements.txt (line 8)) Downloading httpx-0.28.1-py3-none-any.whl.metadata (7.1 kB) Requirement already satisfied: soupsieve>1.2 in /usr/lib/python3/dist-packages (from beautifulsoup4<4.14,>=4.11.1->extract_msg->-r social/requirements.txt (line 4)) (2.5) Requirement already satisfied: pycparser in /usr/local/lib/python3.12/dist-packages (from cffi>=1.12->cryptography<37->-r social/requirements.txt (line 3)) (3.0) Collecting anyio (from httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) Downloading anyio-4.13.0-py3-none-any.whl.metadata (4.5 kB) Requirement already satisfied: certifi in /usr/lib/python3/dist-packages (from httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) (2023.11.17) Collecting httpcore==1.* (from httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) Downloading httpcore-1.0.9-py3-none-any.whl.metadata (21 kB) Requirement already satisfied: idna in /usr/lib/python3/dist-packages (from httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) (3.6) Collecting h11>=0.16 (from httpcore==1.*->httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) Downloading h11-0.16.0-py3-none-any.whl.metadata (8.3 kB) Collecting lark~=1.3.0 (from RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading lark-1.3.1-py3-none-any.whl.metadata (1.8 kB) Collecting oletools>=0.56 (from RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading oletools-0.60.2-py2.py3-none-any.whl.metadata (16 kB) Collecting webencodings (from cssselect2->cairosvg->-r social/requirements.txt (line 2)) Downloading webencodings-0.5.1-py2.py3-none-any.whl.metadata (2.1 kB) Collecting more-itertools (from cssutils->premailer->-r social/requirements.txt (line 7)) Downloading more_itertools-11.0.1-py3-none-any.whl.metadata (41 kB) Collecting pyparsing<4,>=2.1.0 (from oletools>=0.56->RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading pyparsing-3.3.2-py3-none-any.whl.metadata (5.8 kB) Collecting easygui (from oletools>=0.56->RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading easygui-0.98.3-py2.py3-none-any.whl.metadata (8.4 kB) Collecting colorclass (from oletools>=0.56->RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading colorclass-2.2.2-py2.py3-none-any.whl.metadata (5.2 kB) Collecting pcodedmp>=1.2.5 (from oletools>=0.56->RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading pcodedmp-1.2.6-py2.py3-none-any.whl.metadata (11 kB) Collecting msoffcrypto-tool (from oletools>=0.56->RTFDE<0.2,>=0.1.1->extract_msg->-r social/requirements.txt (line 4)) Downloading msoffcrypto_tool-6.0.0-py3-none-any.whl.metadata (10 kB) Requirement already satisfied: typing_extensions>=4.5 in /usr/lib/python3/dist-packages (from anyio->httpx<0.29,>=0.27->python-telegram-bot->-r social/requirements.txt (line 8)) (4.10.0) INFO: pip is looking at multiple versions of msoffcrypto-tool to determine which version is compatible with other requirements. This could take a while. Downloading msoffcrypto_tool-5.4.2-py3-none-any.whl.metadata (10 kB) Downloading msoffcrypto_tool-5.4.1-py3-none-any.whl.metadata (10 kB) Downloading cairosvg-2.9.0-py3-none-any.whl (45 kB) Downloading cryptography-36.0.2-cp36-abi3-manylinux_2_24_x86_64.whl (3.6 MB) Downloading extract_msg-0.55.0-py3-none-any.whl (336 kB) Downloading olefile-0.47-py2.py3-none-any.whl (114 kB) Downloading premailer-3.10.0-py2.py3-none-any.whl (19 kB) Downloading python_telegram_bot-22.7-py3-none-any.whl (745 kB) Downloading compressed_rtf-1.0.7-py3-none-any.whl (8.0 kB) Downloading ebcdic-1.1.1-py2.py3-none-any.whl (128 kB) Downloading httpx-0.28.1-py3-none-any.whl (73 kB) Downloading httpcore-1.0.9-py3-none-any.whl (78 kB) Downloading rtfde-0.1.2.2-py3-none-any.whl (36 kB) Downloading tzlocal-5.3.1-py3-none-any.whl (18 kB) Downloading cachetools-7.0.5-py3-none-any.whl (13 kB) Downloading cairocffi-1.7.1-py3-none-any.whl (75 kB) Downloading cssselect2-0.9.0-py3-none-any.whl (15 kB) Downloading cssutils-2.11.1-py3-none-any.whl (385 kB) Downloading tinycss2-1.5.1-py3-none-any.whl (28 kB) Downloading lark-1.3.1-py3-none-any.whl (113 kB) Downloading oletools-0.60.2-py2.py3-none-any.whl (989 kB) Downloading webencodings-0.5.1-py2.py3-none-any.whl (11 kB) Downloading anyio-4.13.0-py3-none-any.whl (114 kB) Downloading more_itertools-11.0.1-py3-none-any.whl (72 kB) Downloading h11-0.16.0-py3-none-any.whl (37 kB) Downloading pcodedmp-1.2.6-py2.py3-none-any.whl (30 kB) Downloading pyparsing-3.3.2-py3-none-any.whl (122 kB) Downloading colorclass-2.2.2-py2.py3-none-any.whl (18 kB) Downloading easygui-0.98.3-py2.py3-none-any.whl (92 kB) Downloading msoffcrypto_tool-5.4.1-py3-none-any.whl (48 kB) Building wheels for collected packages: lottie, red-black-tree-mod Building wheel for lottie (setup.py): started Building wheel for lottie (setup.py): finished with status 'done' Created wheel for lottie: filename=lottie-0.7.2-py3-none-any.whl size=195365 sha256=dfea826c7e5d4bd243bdae4e303d3bfe7423b2898a7773b3fac16fc515448fd6 Stored in directory: /home/runbot/.cache/pip/wheels/c9/fc/0e/ecc37b4895c5f63209dc42797ad4c1a53c89e34351217e56df Building wheel for red-black-tree-mod (setup.py): started Building wheel for red-black-tree-mod (setup.py): finished with status 'done' Created wheel for red-black-tree-mod: filename=red_black_tree_mod-1.22-py3-none-any.whl size=19237 sha256=a137e1bd0906514b5d742b976348024b344934245df87d92d1c0ffd831bd0357 Stored in directory: /home/runbot/.cache/pip/wheels/f6/0b/c7/2c437dd86730e451859662ab2edf7b0ab1541dcf14f7fb3fd1 Successfully built lottie red-black-tree-mod WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: webencodings, red-black-tree-mod, ebcdic, easygui, compressed-rtf, tzlocal, tinycss2, pyparsing, olefile, more-itertools, lottie, lark, h11, colorclass, cachetools, anyio, httpcore, cssutils, cssselect2, cryptography, cairocffi, premailer, msoffcrypto-tool, httpx, cairosvg, python-telegram-bot, pcodedmp, oletools, RTFDE, extract_msg ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts. pyopenssl 24.1.0 requires cryptography<43,>=41.0.5, but you have cryptography 36.0.2 which is incompatible. Successfully installed RTFDE-0.1.2.2 anyio-4.13.0 cachetools-7.0.5 cairocffi-1.7.1 cairosvg-2.9.0 colorclass-2.2.2 compressed-rtf-1.0.7 cryptography-36.0.2 cssselect2-0.9.0 cssutils-2.11.1 easygui-0.98.3 ebcdic-1.1.1 extract_msg-0.55.0 h11-0.16.0 httpcore-1.0.9 httpx-0.28.1 lark-1.3.1 lottie-0.7.2 more-itertools-11.0.1 msoffcrypto-tool-5.4.1 olefile-0.47 oletools-0.60.2 pcodedmp-1.2.6 premailer-3.10.0 pyparsing-3.3.2 python-telegram-bot-22.7 red-black-tree-mod-1.22 tinycss2-1.5.1 tzlocal-5.3.1 webencodings-0.5.1 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting email-validator (from -r partner-contact/requirements.txt (line 2)) Downloading email_validator-2.3.0-py3-none-any.whl.metadata (26 kB) Requirement already satisfied: phonenumbers in /usr/lib/python3/dist-packages (from -r partner-contact/requirements.txt (line 3)) (8.12.57) Collecting dnspython>=2.0.0 (from email-validator->-r partner-contact/requirements.txt (line 2)) Downloading dnspython-2.8.0-py3-none-any.whl.metadata (5.7 kB) Requirement already satisfied: idna>=2.0.0 in /usr/lib/python3/dist-packages (from email-validator->-r partner-contact/requirements.txt (line 2)) (3.6) Downloading email_validator-2.3.0-py3-none-any.whl (35 kB) Downloading dnspython-2.8.0-py3-none-any.whl (331 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: dnspython, email-validator Successfully installed dnspython-2.8.0 email-validator-2.3.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Ignoring pymssql: markers 'python_version <= "3.10"' don't match your environment Collecting mysqlclient (from -r server-backend/requirements.txt (line 2)) Downloading mysqlclient-2.2.8.tar.gz (92 kB) Installing build dependencies: started Installing build dependencies: finished with status 'done' Getting requirements to build wheel: started Getting requirements to build wheel: finished with status 'done' Preparing metadata (pyproject.toml): started Preparing metadata (pyproject.toml): finished with status 'done' Collecting pymssql<=2.3.7 (from -r server-backend/requirements.txt (line 4)) Downloading pymssql-2.3.7-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.metadata (4.1 kB) Collecting sqlalchemy (from -r server-backend/requirements.txt (line 5)) Downloading sqlalchemy-2.0.49-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl.metadata (9.5 kB) Requirement already satisfied: greenlet>=1 in /usr/lib/python3/dist-packages (from sqlalchemy->-r server-backend/requirements.txt (line 5)) (3.0.3) Requirement already satisfied: typing-extensions>=4.6.0 in /usr/lib/python3/dist-packages (from sqlalchemy->-r server-backend/requirements.txt (line 5)) (4.10.0) Downloading pymssql-2.3.7-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (2.8 MB) Downloading sqlalchemy-2.0.49-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (3.4 MB) Building wheels for collected packages: mysqlclient Building wheel for mysqlclient (pyproject.toml): started Building wheel for mysqlclient (pyproject.toml): finished with status 'done' Created wheel for mysqlclient: filename=mysqlclient-2.2.8-cp312-cp312-linux_x86_64.whl size=129529 sha256=a5bcfbfbbf70e6f4d05472cbd00b73186d2ed844fe381413f57845230bb7db62 Stored in directory: /home/runbot/.cache/pip/wheels/b0/62/00/46e65ad9151c1266f0f03ea020a5a8ea1cbc6e4ebf3329e276 Successfully built mysqlclient WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: sqlalchemy, pymssql, mysqlclient Successfully installed mysqlclient-2.2.8 pymssql-2.3.7 sqlalchemy-2.0.49 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: xlrd in /usr/lib/python3/dist-packages (from -r account-reconcile/requirements.txt (line 2)) (2.0.1) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: cryptography in /home/runbot/.local/lib/python3.12/site-packages (from -r reporting-engine/requirements.txt (line 2)) (36.0.2) Collecting endesive (from -r reporting-engine/requirements.txt (line 3)) Downloading endesive-2.19.3-py3-none-any.whl.metadata (5.5 kB) Requirement already satisfied: mock in /usr/lib/python3/dist-packages (from -r reporting-engine/requirements.txt (line 4)) (5.1.0) Requirement already satisfied: openpyxl in /usr/lib/python3/dist-packages (from -r reporting-engine/requirements.txt (line 5)) (3.1.2) Collecting py3o.formats (from -r reporting-engine/requirements.txt (line 6)) Downloading py3o.formats-0.3.zip (7.3 kB) Preparing metadata (setup.py): started Preparing metadata (setup.py): finished with status 'done' Collecting py3o.template (from -r reporting-engine/requirements.txt (line 7)) Downloading py3o.template-0.10.0-py3-none-any.whl.metadata (12 kB) Requirement already satisfied: cffi>=1.12 in /usr/local/lib/python3.12/dist-packages (from cryptography->-r reporting-engine/requirements.txt (line 2)) (2.0.0) Requirement already satisfied: asn1crypto in /usr/lib/python3/dist-packages (from endesive->-r reporting-engine/requirements.txt (line 3)) (1.5.1) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from endesive->-r reporting-engine/requirements.txt (line 3)) (5.2.1) Collecting pykcs11 (from endesive->-r reporting-engine/requirements.txt (line 3)) Downloading pykcs11-1.5.18.tar.gz (105 kB) Installing build dependencies: started Installing build dependencies: finished with status 'done' Getting requirements to build wheel: started Getting requirements to build wheel: finished with status 'done' Preparing metadata (pyproject.toml): started Preparing metadata (pyproject.toml): finished with status 'done' Requirement already satisfied: Pillow in /usr/lib/python3/dist-packages (from endesive->-r reporting-engine/requirements.txt (line 3)) (10.2.0) Requirement already satisfied: requests in /usr/lib/python3/dist-packages (from endesive->-r reporting-engine/requirements.txt (line 3)) (2.31.0) Collecting paramiko (from endesive->-r reporting-engine/requirements.txt (line 3)) Downloading paramiko-4.0.0-py3-none-any.whl.metadata (3.9 kB) Requirement already satisfied: setuptools in /usr/lib/python3/dist-packages (from py3o.formats->-r reporting-engine/requirements.txt (line 6)) (68.1.2) Requirement already satisfied: babel in /usr/lib/python3/dist-packages (from py3o.template->-r reporting-engine/requirements.txt (line 7)) (2.10.3) Collecting genshi>=0.7 (from py3o.template->-r reporting-engine/requirements.txt (line 7)) Downloading genshi-0.7.10-py3-none-any.whl.metadata (1.4 kB) Collecting pyjon.utils>0.6 (from py3o.template->-r reporting-engine/requirements.txt (line 7)) Downloading pyjon.utils-0.7-py3-none-any.whl.metadata (671 bytes) Requirement already satisfied: six>=1.9 in /usr/lib/python3/dist-packages (from py3o.template->-r reporting-engine/requirements.txt (line 7)) (1.16.0) Requirement already satisfied: pycparser in /usr/local/lib/python3.12/dist-packages (from cffi>=1.12->cryptography->-r reporting-engine/requirements.txt (line 2)) (3.0) Collecting bcrypt>=3.2 (from paramiko->endesive->-r reporting-engine/requirements.txt (line 3)) Downloading bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl.metadata (10 kB) Collecting invoke>=2.0 (from paramiko->endesive->-r reporting-engine/requirements.txt (line 3)) Downloading invoke-3.0.3-py3-none-any.whl.metadata (3.2 kB) Collecting pynacl>=1.5 (from paramiko->endesive->-r reporting-engine/requirements.txt (line 3)) Downloading pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl.metadata (10.0 kB) Downloading endesive-2.19.3-py3-none-any.whl (349 kB) Downloading py3o.template-0.10.0-py3-none-any.whl (614 kB) Downloading genshi-0.7.10-py3-none-any.whl (179 kB) Downloading pyjon.utils-0.7-py3-none-any.whl (6.5 kB) Downloading paramiko-4.0.0-py3-none-any.whl (223 kB) Downloading bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl (278 kB) Downloading invoke-3.0.3-py3-none-any.whl (160 kB) Downloading pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl (1.4 MB) Building wheels for collected packages: py3o.formats, pykcs11 Building wheel for py3o.formats (setup.py): started Building wheel for py3o.formats (setup.py): finished with status 'done' Created wheel for py3o.formats: filename=py3o.formats-0.3-py3-none-any.whl size=4290 sha256=cdcd7348bde4f6024cb6bdba539f857dac517e025c3a7a9e66596ec85e1cee2d Stored in directory: /home/runbot/.cache/pip/wheels/db/86/fc/1342fa3882442513e6cb3171c4f57e04eb94cf7a578e5a9d41 Building wheel for pykcs11 (pyproject.toml): started Building wheel for pykcs11 (pyproject.toml): finished with status 'done' Created wheel for pykcs11: filename=pykcs11-1.5.18-cp312-cp312-linux_x86_64.whl size=1252842 sha256=39876a2cade202942a74d82c4ed27bd0156bbb45906f64f9ec3492b42ec483f4 Stored in directory: /home/runbot/.cache/pip/wheels/93/5e/95/1910093196363e40d2cabff58d4385988b24eb9f55049ba194 Successfully built py3o.formats pykcs11 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: pykcs11, genshi, pyjon.utils, py3o.formats, invoke, bcrypt, pynacl, py3o.template, paramiko, endesive Successfully installed bcrypt-5.0.0 endesive-2.19.3 genshi-0.7.10 invoke-3.0.3 paramiko-4.0.0 py3o.formats-0.3 py3o.template-0.10.0 pyjon.utils-0.7 pykcs11-1.5.18 pynacl-1.6.2 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Ignoring cryptography: markers 'python_version < "3.12"' don't match your environment Ignoring freezegun: markers 'python_version < "3.8"' don't match your environment Ignoring gevent: markers 'sys_platform != "win32" and python_version == "3.7"' don't match your environment Ignoring gevent: markers 'sys_platform != "win32" and python_version > "3.7" and python_version <= "3.9"' don't match your environment Ignoring gevent: markers 'sys_platform != "win32" and python_version > "3.9" and python_version <= "3.10"' don't match your environment Ignoring gevent: markers 'sys_platform != "win32" and python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring greenlet: markers 'sys_platform != "win32" and python_version == "3.7"' don't match your environment Ignoring greenlet: markers 'sys_platform != "win32" and python_version > "3.7" and python_version <= "3.9"' don't match your environment Ignoring greenlet: markers 'sys_platform != "win32" and python_version > "3.9" and python_version <= "3.10"' don't match your environment Ignoring greenlet: markers 'sys_platform != "win32" and python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring Jinja2: markers 'python_version <= "3.10"' don't match your environment Ignoring libsass: markers 'python_version < "3.12"' don't match your environment Ignoring lxml: markers 'python_version <= "3.10"' don't match your environment Ignoring lxml: markers 'python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring MarkupSafe: markers 'python_version <= "3.10"' don't match your environment Ignoring MarkupSafe: markers 'python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring ofxparse: markers 'python_version <= "3.9"' don't match your environment Ignoring Pillow: markers 'python_version <= "3.10"' don't match your environment Ignoring Pillow: markers 'python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring psutil: markers 'python_version <= "3.10"' don't match your environment Ignoring psutil: markers 'python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring psycopg2: markers 'sys_platform != "win32" and python_version < "3.8"' don't match your environment Ignoring psycopg2: markers 'sys_platform != "win32" and python_version >= "3.8" and python_version < "3.10"' don't match your environment Ignoring psycopg2: markers 'sys_platform == "win32" and python_version < "3.10"' don't match your environment Ignoring psycopg2: markers 'python_version == "3.10"' don't match your environment Ignoring psycopg2: markers 'python_version >= "3.11" and python_version < "3.12"' don't match your environment Ignoring pyopenssl: markers 'python_version < "3.12"' don't match your environment Ignoring PyPDF2: markers 'python_version <= "3.10"' don't match your environment Ignoring pypiwin32: markers 'sys_platform == "win32"' don't match your environment Ignoring python-ldap: markers 'sys_platform != "win32" and python_version < "3.12"' don't match your environment Ignoring pyusb: markers 'python_version <= "3.10"' don't match your environment Ignoring reportlab: markers 'python_version <= "3.10"' don't match your environment Ignoring reportlab: markers 'python_version > "3.10" and python_version < "3.12"' don't match your environment Ignoring requests: markers 'python_version < "3.12"' don't match your environment Ignoring rl-renderPM: markers 'sys_platform == "win32" and python_version >= "3.12"' don't match your environment Ignoring urllib3: markers 'python_version < "3.12"' don't match your environment Ignoring Werkzeug: markers 'python_version <= "3.9"' don't match your environment Ignoring xlrd: markers 'python_version < "3.8"' don't match your environment Collecting Babel==2.9.1 (from -r odoo/requirements.txt (line 3)) Downloading Babel-2.9.1-py2.py3-none-any.whl.metadata (1.2 kB) Collecting chardet==4.0.0 (from -r odoo/requirements.txt (line 4)) Downloading chardet-4.0.0-py2.py3-none-any.whl.metadata (3.5 kB) Collecting cryptography==42.0.8 (from -r odoo/requirements.txt (line 6)) Downloading cryptography-42.0.8-cp39-abi3-manylinux_2_28_x86_64.whl.metadata (5.3 kB) Collecting decorator==4.4.2 (from -r odoo/requirements.txt (line 7)) Downloading decorator-4.4.2-py2.py3-none-any.whl.metadata (4.2 kB) Collecting docutils==0.16 (from -r odoo/requirements.txt (line 8)) Downloading docutils-0.16-py2.py3-none-any.whl.metadata (2.7 kB) Requirement already satisfied: ebaysdk==2.1.5 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 9)) (2.1.5) Collecting freezegun==0.3.15 (from -r odoo/requirements.txt (line 11)) Downloading freezegun-0.3.15-py2.py3-none-any.whl.metadata (8.5 kB) Requirement already satisfied: gevent==24.2.1 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 16)) (24.2.1) Requirement already satisfied: greenlet==3.0.3 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 21)) (3.0.3) Collecting idna==2.10 (from -r odoo/requirements.txt (line 22)) Downloading idna-2.10-py2.py3-none-any.whl.metadata (9.1 kB) Requirement already satisfied: Jinja2==3.1.2 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 24)) (3.1.2) Requirement already satisfied: libsass==0.22.0 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 26)) (0.22.0) Requirement already satisfied: lxml==5.2.1 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 29)) (5.2.1) Requirement already satisfied: lxml-html-clean in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 30)) (0.1.1) Requirement already satisfied: MarkupSafe==2.1.5 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 33)) (2.1.5) Collecting num2words==0.5.9 (from -r odoo/requirements.txt (line 34)) Downloading num2words-0.5.9-py3-none-any.whl.metadata (8.3 kB) Requirement already satisfied: ofxparse==0.21 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 36)) (0.21) Requirement already satisfied: passlib==1.7.4 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 37)) (1.7.4) Requirement already satisfied: Pillow==10.2.0 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 40)) (10.2.0) Collecting polib==1.1.0 (from -r odoo/requirements.txt (line 41)) Downloading polib-1.1.0-py2.py3-none-any.whl.metadata (13 kB) Requirement already satisfied: psutil==5.9.8 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 44)) (5.9.8) Requirement already satisfied: psycopg2==2.9.9 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 50)) (2.9.9) Collecting pydot==1.4.2 (from -r odoo/requirements.txt (line 51)) Downloading pydot-1.4.2-py2.py3-none-any.whl.metadata (8.0 kB) Requirement already satisfied: pyopenssl==24.1.0 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 53)) (24.1.0) Requirement already satisfied: PyPDF2==2.12.1 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 55)) (2.12.1) Requirement already satisfied: pyserial==3.5 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 57)) (3.5) Collecting python-dateutil==2.8.1 (from -r odoo/requirements.txt (line 58)) Downloading python_dateutil-2.8.1-py2.py3-none-any.whl.metadata (8.0 kB) Requirement already satisfied: python-ldap==3.4.4 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 60)) (3.4.4) Collecting python-stdnum==1.16 (from -r odoo/requirements.txt (line 61)) Downloading python_stdnum-1.16-py2.py3-none-any.whl.metadata (16 kB) Requirement already satisfied: pytz in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 62)) (2025.2) Requirement already satisfied: pyusb==1.2.1 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 64)) (1.2.1) Collecting qrcode==6.1 (from -r odoo/requirements.txt (line 65)) Downloading qrcode-6.1-py2.py3-none-any.whl.metadata (11 kB) Requirement already satisfied: reportlab==4.1.0 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 68)) (4.1.0) Requirement already satisfied: requests==2.31.0 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 70)) (2.31.0) Requirement already satisfied: urllib3==2.0.7 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 73)) (2.0.7) Requirement already satisfied: vobject==0.9.6.1 in /usr/lib/python3/dist-packages (from -r odoo/requirements.txt (line 74)) (0.9.6.1) Collecting Werkzeug==2.0.2 (from -r odoo/requirements.txt (line 76)) Downloading Werkzeug-2.0.2-py3-none-any.whl.metadata (4.5 kB) Collecting xlrd==1.2.0 (from -r odoo/requirements.txt (line 78)) Downloading xlrd-1.2.0-py2.py3-none-any.whl.metadata (1.3 kB) Collecting XlsxWriter==1.1.2 (from -r odoo/requirements.txt (line 79)) Downloading XlsxWriter-1.1.2-py2.py3-none-any.whl.metadata (2.6 kB) Requirement already satisfied: xlwt==1.3.0 in /usr/local/lib/python3.12/dist-packages (from -r odoo/requirements.txt (line 80)) (1.3.0) Collecting zeep==4.0.0 (from -r odoo/requirements.txt (line 81)) Downloading zeep-4.0.0-py2.py3-none-any.whl.metadata (3.3 kB) Requirement already satisfied: cffi>=1.12 in /usr/local/lib/python3.12/dist-packages (from cryptography==42.0.8->-r odoo/requirements.txt (line 6)) (2.0.0) Requirement already satisfied: six in /usr/lib/python3/dist-packages (from freezegun==0.3.15->-r odoo/requirements.txt (line 11)) (1.16.0) Requirement already satisfied: docopt>=0.6.2 in /usr/lib/python3/dist-packages (from num2words==0.5.9->-r odoo/requirements.txt (line 34)) (0.6.2) Requirement already satisfied: pyparsing>=2.1.4 in /home/runbot/.local/lib/python3.12/site-packages (from pydot==1.4.2->-r odoo/requirements.txt (line 51)) (3.3.2) Requirement already satisfied: pyasn1>=0.3.7 in /usr/local/lib/python3.12/dist-packages (from python-ldap==3.4.4->-r odoo/requirements.txt (line 60)) (0.6.2) Requirement already satisfied: pyasn1_modules>=0.1.5 in /usr/local/lib/python3.12/dist-packages (from python-ldap==3.4.4->-r odoo/requirements.txt (line 60)) (0.4.2) Collecting appdirs>=1.4.0 (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) Downloading appdirs-1.4.4-py2.py3-none-any.whl.metadata (9.0 kB) Requirement already satisfied: attrs>=17.2.0 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (23.2.0) Requirement already satisfied: cached-property>=1.3.0 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (1.5.2) Requirement already satisfied: defusedxml>=0.4.1 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (0.7.1) Requirement already satisfied: isodate>=0.5.4 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (0.6.1) Requirement already satisfied: requests-toolbelt>=0.7.1 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (1.0.0) Requirement already satisfied: requests-file>=1.5.1 in /usr/lib/python3/dist-packages (from zeep==4.0.0->-r odoo/requirements.txt (line 81)) (1.5.1) Requirement already satisfied: pycparser in /usr/local/lib/python3.12/dist-packages (from cffi>=1.12->cryptography==42.0.8->-r odoo/requirements.txt (line 6)) (3.0) Downloading Babel-2.9.1-py2.py3-none-any.whl (8.8 MB) Downloading chardet-4.0.0-py2.py3-none-any.whl (178 kB) Downloading cryptography-42.0.8-cp39-abi3-manylinux_2_28_x86_64.whl (3.9 MB) Downloading decorator-4.4.2-py2.py3-none-any.whl (9.2 kB) Downloading docutils-0.16-py2.py3-none-any.whl (548 kB) Downloading freezegun-0.3.15-py2.py3-none-any.whl (14 kB) Downloading idna-2.10-py2.py3-none-any.whl (58 kB) Downloading num2words-0.5.9-py3-none-any.whl (99 kB) Downloading polib-1.1.0-py2.py3-none-any.whl (25 kB) Downloading pydot-1.4.2-py2.py3-none-any.whl (21 kB) Downloading python_dateutil-2.8.1-py2.py3-none-any.whl (227 kB) Downloading python_stdnum-1.16-py2.py3-none-any.whl (910 kB) Downloading qrcode-6.1-py2.py3-none-any.whl (31 kB) Downloading Werkzeug-2.0.2-py3-none-any.whl (288 kB) Downloading xlrd-1.2.0-py2.py3-none-any.whl (103 kB) Downloading XlsxWriter-1.1.2-py2.py3-none-any.whl (142 kB) Downloading zeep-4.0.0-py2.py3-none-any.whl (100 kB) Downloading appdirs-1.4.4-py2.py3-none-any.whl (9.6 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: XlsxWriter, python-stdnum, polib, appdirs, zeep, xlrd, Werkzeug, qrcode, python-dateutil, pydot, num2words, idna, docutils, decorator, chardet, Babel, freezegun, cryptography Attempting uninstall: cryptography Found existing installation: cryptography 36.0.2 Uninstalling cryptography-36.0.2: Successfully uninstalled cryptography-36.0.2 Successfully installed Babel-2.9.1 Werkzeug-2.0.2 XlsxWriter-1.1.2 appdirs-1.4.4 chardet-4.0.0 cryptography-42.0.8 decorator-4.4.2 docutils-0.16 freezegun-0.3.15 idna-2.10 num2words-0.5.9 polib-1.1.0 pydot-1.4.2 python-dateutil-2.8.1 python-stdnum-1.16 qrcode-6.1 xlrd-1.2.0 zeep-4.0.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting acme (from -r server-tools/requirements.txt (line 2)) Downloading acme-5.5.0-py3-none-any.whl.metadata (1.3 kB) Collecting astor (from -r server-tools/requirements.txt (line 3)) Downloading astor-0.8.1-py2.py3-none-any.whl.metadata (4.2 kB) Requirement already satisfied: cryptography in /home/runbot/.local/lib/python3.12/site-packages (from -r server-tools/requirements.txt (line 4)) (42.0.8) Collecting dataclasses (from -r server-tools/requirements.txt (line 5)) Downloading dataclasses-0.6-py3-none-any.whl.metadata (3.0 kB) Requirement already satisfied: dnspython in /home/runbot/.local/lib/python3.12/site-packages (from -r server-tools/requirements.txt (line 6)) (2.8.0) Collecting josepy (from -r server-tools/requirements.txt (line 7)) Downloading josepy-2.2.0-py3-none-any.whl.metadata (1.7 kB) Collecting mako (from -r server-tools/requirements.txt (line 8)) Downloading mako-1.3.10-py3-none-any.whl.metadata (2.9 kB) Requirement already satisfied: odoo_test_helper in /usr/local/lib/python3.12/dist-packages (from -r server-tools/requirements.txt (line 9)) (2.1.3) Collecting odoorpc (from -r server-tools/requirements.txt (line 10)) Downloading OdooRPC-0.10.1-py2.py3-none-any.whl.metadata (4.8 kB) Requirement already satisfied: openpyxl in /usr/lib/python3/dist-packages (from -r server-tools/requirements.txt (line 11)) (3.1.2) Requirement already satisfied: openupgradelib in /home/runbot/.local/lib/python3.12/site-packages (from -r server-tools/requirements.txt (line 12)) (3.12.0) Collecting pygount==1.4.0 (from -r server-tools/requirements.txt (line 13)) Downloading pygount-1.4.0-py3-none-any.whl.metadata (5.2 kB) Collecting pysftp (from -r server-tools/requirements.txt (line 14)) Downloading pysftp-0.2.9.tar.gz (25 kB) Preparing metadata (setup.py): started Preparing metadata (setup.py): finished with status 'done' Collecting sentry_sdk<=1.9.0 (from -r server-tools/requirements.txt (line 15)) Downloading sentry_sdk-1.9.0-py2.py3-none-any.whl.metadata (7.8 kB) Collecting unidecode (from -r server-tools/requirements.txt (line 16)) Downloading Unidecode-1.4.0-py3-none-any.whl.metadata (13 kB) Collecting unittest-xml-reporting (from -r server-tools/requirements.txt (line 17)) Downloading unittest_xml_reporting-4.0.0-py2.py3-none-any.whl.metadata (11 kB) Requirement already satisfied: chardet<5,>=4 in /home/runbot/.local/lib/python3.12/site-packages (from pygount==1.4.0->-r server-tools/requirements.txt (line 13)) (4.0.0) Requirement already satisfied: pygments<3,>=2 in /usr/lib/python3/dist-packages (from pygount==1.4.0->-r server-tools/requirements.txt (line 13)) (2.17.2) Collecting rich<13,>=9 (from pygount==1.4.0->-r server-tools/requirements.txt (line 13)) Downloading rich-12.6.0-py3-none-any.whl.metadata (18 kB) Collecting cryptography (from -r server-tools/requirements.txt (line 4)) Downloading cryptography-46.0.7-cp311-abi3-manylinux_2_34_x86_64.whl.metadata (5.7 kB) Collecting PyOpenSSL>=25.0.0 (from acme->-r server-tools/requirements.txt (line 2)) Downloading pyopenssl-26.0.0-py3-none-any.whl.metadata (18 kB) Collecting pyrfc3339 (from acme->-r server-tools/requirements.txt (line 2)) Downloading pyrfc3339-2.1.0-py3-none-any.whl.metadata (2.8 kB) Requirement already satisfied: requests>=2.25.1 in /usr/lib/python3/dist-packages (from acme->-r server-tools/requirements.txt (line 2)) (2.31.0) Requirement already satisfied: cffi>=2.0.0 in /usr/local/lib/python3.12/dist-packages (from cryptography->-r server-tools/requirements.txt (line 4)) (2.0.0) Requirement already satisfied: MarkupSafe>=0.9.2 in /usr/lib/python3/dist-packages (from mako->-r server-tools/requirements.txt (line 8)) (2.1.5) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from openupgradelib->-r server-tools/requirements.txt (line 12)) (5.2.1) Requirement already satisfied: cssselect in /home/runbot/.local/lib/python3.12/site-packages (from openupgradelib->-r server-tools/requirements.txt (line 12)) (1.4.0) Requirement already satisfied: paramiko>=1.17 in /home/runbot/.local/lib/python3.12/site-packages (from pysftp->-r server-tools/requirements.txt (line 14)) (4.0.0) Requirement already satisfied: urllib3>=1.10.0 in /usr/lib/python3/dist-packages (from sentry_sdk<=1.9.0->-r server-tools/requirements.txt (line 15)) (2.0.7) Requirement already satisfied: certifi in /usr/lib/python3/dist-packages (from sentry_sdk<=1.9.0->-r server-tools/requirements.txt (line 15)) (2023.11.17) Requirement already satisfied: pycparser in /usr/local/lib/python3.12/dist-packages (from cffi>=2.0.0->cryptography->-r server-tools/requirements.txt (line 4)) (3.0) Requirement already satisfied: bcrypt>=3.2 in /home/runbot/.local/lib/python3.12/site-packages (from paramiko>=1.17->pysftp->-r server-tools/requirements.txt (line 14)) (5.0.0) Requirement already satisfied: invoke>=2.0 in /home/runbot/.local/lib/python3.12/site-packages (from paramiko>=1.17->pysftp->-r server-tools/requirements.txt (line 14)) (3.0.3) Requirement already satisfied: pynacl>=1.5 in /home/runbot/.local/lib/python3.12/site-packages (from paramiko>=1.17->pysftp->-r server-tools/requirements.txt (line 14)) (1.6.2) Requirement already satisfied: typing-extensions>=4.9 in /usr/lib/python3/dist-packages (from PyOpenSSL>=25.0.0->acme->-r server-tools/requirements.txt (line 2)) (4.10.0) Collecting commonmark<0.10.0,>=0.9.0 (from rich<13,>=9->pygount==1.4.0->-r server-tools/requirements.txt (line 13)) Downloading commonmark-0.9.1-py2.py3-none-any.whl.metadata (5.7 kB) Downloading pygount-1.4.0-py3-none-any.whl (26 kB) Downloading acme-5.5.0-py3-none-any.whl (94 kB) Downloading astor-0.8.1-py2.py3-none-any.whl (27 kB) Downloading cryptography-46.0.7-cp311-abi3-manylinux_2_34_x86_64.whl (4.5 MB) Downloading dataclasses-0.6-py3-none-any.whl (14 kB) Downloading josepy-2.2.0-py3-none-any.whl (29 kB) Downloading mako-1.3.10-py3-none-any.whl (78 kB) Downloading OdooRPC-0.10.1-py2.py3-none-any.whl (38 kB) Downloading sentry_sdk-1.9.0-py2.py3-none-any.whl (156 kB) Downloading Unidecode-1.4.0-py3-none-any.whl (235 kB) Downloading unittest_xml_reporting-4.0.0-py2.py3-none-any.whl (20 kB) Downloading pyopenssl-26.0.0-py3-none-any.whl (57 kB) Downloading rich-12.6.0-py3-none-any.whl (237 kB) Downloading pyrfc3339-2.1.0-py3-none-any.whl (6.8 kB) Downloading commonmark-0.9.1-py2.py3-none-any.whl (51 kB) Building wheels for collected packages: pysftp Building wheel for pysftp (setup.py): started Building wheel for pysftp (setup.py): finished with status 'done' Created wheel for pysftp: filename=pysftp-0.2.9-py3-none-any.whl size=15496 sha256=9827e4af1967890ff8367cd074a06c0884f70f17963e2a88eed619bced648d25 Stored in directory: /home/runbot/.cache/pip/wheels/0f/3c/e0/360d2b9ba2f5aac8b8159c156eb862001f0806e15f18cb7aac Successfully built pysftp WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: odoorpc, dataclasses, commonmark, unittest-xml-reporting, unidecode, sentry_sdk, rich, pyrfc3339, mako, astor, pygount, cryptography, PyOpenSSL, josepy, pysftp, acme Attempting uninstall: cryptography Found existing installation: cryptography 42.0.8 Uninstalling cryptography-42.0.8: Successfully uninstalled cryptography-42.0.8 ERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts. ocrmypdf 15.2.0+dfsg1 requires deprecation>=2.1.0, but you have deprecation 2.0.7 which is incompatible. ocrmypdf 15.2.0+dfsg1 requires rich>=13, but you have rich 12.6.0 which is incompatible. Successfully installed PyOpenSSL-26.0.0 acme-5.5.0 astor-0.8.1 commonmark-0.9.1 cryptography-46.0.7 dataclasses-0.6 josepy-2.2.0 mako-1.3.10 odoorpc-0.10.1 pygount-1.4.0 pyrfc3339-2.1.0 pysftp-0.2.9 rich-12.6.0 sentry_sdk-1.9.0 unidecode-1.4.0 unittest-xml-reporting-4.0.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting pdf2image (from -r server-ux/requirements.txt (line 2)) Downloading pdf2image-1.17.0-py3-none-any.whl.metadata (6.2 kB) Collecting pyrfc6266 (from -r server-ux/requirements.txt (line 3)) Downloading pyrfc6266-1.0.2-py3-none-any.whl.metadata (1.5 kB) Collecting pyzbar (from -r server-ux/requirements.txt (line 4)) Downloading pyzbar-0.1.9-py2.py3-none-any.whl.metadata (10 kB) Collecting responses (from -r server-ux/requirements.txt (line 5)) Downloading responses-0.26.0-py3-none-any.whl.metadata (48 kB) Requirement already satisfied: pillow in /usr/lib/python3/dist-packages (from pdf2image->-r server-ux/requirements.txt (line 2)) (10.2.0) Collecting pyparsing~=3.0.7 (from pyrfc6266->-r server-ux/requirements.txt (line 3)) Downloading pyparsing-3.0.9-py3-none-any.whl.metadata (4.2 kB) Requirement already satisfied: requests<3.0,>=2.30.0 in /usr/lib/python3/dist-packages (from responses->-r server-ux/requirements.txt (line 5)) (2.31.0) Requirement already satisfied: urllib3<3.0,>=1.25.10 in /usr/lib/python3/dist-packages (from responses->-r server-ux/requirements.txt (line 5)) (2.0.7) Collecting pyyaml (from responses->-r server-ux/requirements.txt (line 5)) Downloading pyyaml-6.0.3-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl.metadata (2.4 kB) Downloading pdf2image-1.17.0-py3-none-any.whl (11 kB) Downloading pyrfc6266-1.0.2-py3-none-any.whl (4.7 kB) Downloading pyzbar-0.1.9-py2.py3-none-any.whl (32 kB) Downloading responses-0.26.0-py3-none-any.whl (35 kB) Downloading pyparsing-3.0.9-py3-none-any.whl (98 kB) Downloading pyyaml-6.0.3-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (807 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: pyzbar, pyyaml, pyparsing, pdf2image, responses, pyrfc6266 Attempting uninstall: pyparsing Found existing installation: pyparsing 3.3.2 Uninstalling pyparsing-3.3.2: Successfully uninstalled pyparsing-3.3.2 Successfully installed pdf2image-1.17.0 pyparsing-3.0.9 pyrfc6266-1.0.2 pyyaml-6.0.3 pyzbar-0.1.9 responses-0.26.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: python-dateutil in /home/runbot/.local/lib/python3.12/site-packages (from -r hr/requirements.txt (line 2)) (2.8.1) Requirement already satisfied: six>=1.5 in /usr/lib/python3/dist-packages (from python-dateutil->-r hr/requirements.txt (line 2)) (1.16.0) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: freezegun in /home/runbot/.local/lib/python3.12/site-packages (from -r account-financial-tools/requirements.txt (line 2)) (0.3.15) Collecting numpy-financial<=1.0.0 (from -r account-financial-tools/requirements.txt (line 3)) Downloading numpy_financial-1.0.0-py3-none-any.whl.metadata (2.2 kB) Collecting numpy>=1.15 (from -r account-financial-tools/requirements.txt (line 4)) Downloading numpy-2.4.4-cp312-cp312-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl.metadata (6.6 kB) Requirement already satisfied: python-dateutil in /home/runbot/.local/lib/python3.12/site-packages (from -r account-financial-tools/requirements.txt (line 5)) (2.8.1) Requirement already satisfied: six in /usr/lib/python3/dist-packages (from freezegun->-r account-financial-tools/requirements.txt (line 2)) (1.16.0) Downloading numpy_financial-1.0.0-py3-none-any.whl (14 kB) Downloading numpy-2.4.4-cp312-cp312-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl (16.6 MB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: numpy, numpy-financial Successfully installed numpy-2.4.4 numpy-financial-1.0.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: beautifulsoup4 in /usr/lib/python3/dist-packages (from -r web/requirements.txt (line 2)) (4.12.3) Collecting bokeh==3.1.1 (from -r web/requirements.txt (line 3)) Downloading bokeh-3.1.1-py3-none-any.whl.metadata (12 kB) Collecting mpld3==0.5.9 (from -r web/requirements.txt (line 4)) Downloading mpld3-0.5.9-py3-none-any.whl.metadata (5.1 kB) Collecting plotly==5.13.1 (from -r web/requirements.txt (line 5)) Downloading plotly-5.13.1-py2.py3-none-any.whl.metadata (7.0 kB) Requirement already satisfied: Jinja2>=2.9 in /usr/lib/python3/dist-packages (from bokeh==3.1.1->-r web/requirements.txt (line 3)) (3.1.2) Collecting contourpy>=1 (from bokeh==3.1.1->-r web/requirements.txt (line 3)) Downloading contourpy-1.3.3-cp312-cp312-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl.metadata (5.5 kB) Requirement already satisfied: numpy>=1.16 in /home/runbot/.local/lib/python3.12/site-packages (from bokeh==3.1.1->-r web/requirements.txt (line 3)) (2.4.4) Requirement already satisfied: packaging>=16.8 in /usr/lib/python3/dist-packages (from bokeh==3.1.1->-r web/requirements.txt (line 3)) (24.0) Collecting pandas>=1.2 (from bokeh==3.1.1->-r web/requirements.txt (line 3)) Downloading pandas-3.0.2-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl.metadata (79 kB) Requirement already satisfied: pillow>=7.1.0 in /usr/lib/python3/dist-packages (from bokeh==3.1.1->-r web/requirements.txt (line 3)) (10.2.0) Requirement already satisfied: PyYAML>=3.10 in /home/runbot/.local/lib/python3.12/site-packages (from bokeh==3.1.1->-r web/requirements.txt (line 3)) (6.0.3) Collecting tornado>=5.1 (from bokeh==3.1.1->-r web/requirements.txt (line 3)) Downloading tornado-6.5.5-cp39-abi3-manylinux1_x86_64.manylinux_2_28_x86_64.manylinux_2_5_x86_64.whl.metadata (2.8 kB) Collecting xyzservices>=2021.09.1 (from bokeh==3.1.1->-r web/requirements.txt (line 3)) Downloading xyzservices-2026.3.0-py3-none-any.whl.metadata (4.1 kB) Collecting matplotlib (from mpld3==0.5.9->-r web/requirements.txt (line 4)) Downloading matplotlib-3.10.8-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.metadata (52 kB) Collecting tenacity>=6.2.0 (from plotly==5.13.1->-r web/requirements.txt (line 5)) Downloading tenacity-9.1.4-py3-none-any.whl.metadata (1.2 kB) Requirement already satisfied: soupsieve>1.2 in /usr/lib/python3/dist-packages (from beautifulsoup4->-r web/requirements.txt (line 2)) (2.5) Collecting python-dateutil>=2.8.2 (from pandas>=1.2->bokeh==3.1.1->-r web/requirements.txt (line 3)) Downloading python_dateutil-2.9.0.post0-py2.py3-none-any.whl.metadata (8.4 kB) Collecting cycler>=0.10 (from matplotlib->mpld3==0.5.9->-r web/requirements.txt (line 4)) Downloading cycler-0.12.1-py3-none-any.whl.metadata (3.8 kB) Collecting fonttools>=4.22.0 (from matplotlib->mpld3==0.5.9->-r web/requirements.txt (line 4)) Downloading fonttools-4.62.1-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.metadata (117 kB) Collecting kiwisolver>=1.3.1 (from matplotlib->mpld3==0.5.9->-r web/requirements.txt (line 4)) Downloading kiwisolver-1.5.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.metadata (5.1 kB) Requirement already satisfied: pyparsing>=3 in /home/runbot/.local/lib/python3.12/site-packages (from matplotlib->mpld3==0.5.9->-r web/requirements.txt (line 4)) (3.0.9) Requirement already satisfied: six>=1.5 in /usr/lib/python3/dist-packages (from python-dateutil>=2.8.2->pandas>=1.2->bokeh==3.1.1->-r web/requirements.txt (line 3)) (1.16.0) Downloading bokeh-3.1.1-py3-none-any.whl (8.3 MB) Downloading mpld3-0.5.9-py3-none-any.whl (201 kB) Downloading plotly-5.13.1-py2.py3-none-any.whl (15.2 MB) Downloading contourpy-1.3.3-cp312-cp312-manylinux_2_27_x86_64.manylinux_2_28_x86_64.whl (362 kB) Downloading pandas-3.0.2-cp312-cp312-manylinux_2_24_x86_64.manylinux_2_28_x86_64.whl (10.9 MB) Downloading tenacity-9.1.4-py3-none-any.whl (28 kB) Downloading tornado-6.5.5-cp39-abi3-manylinux1_x86_64.manylinux_2_28_x86_64.manylinux_2_5_x86_64.whl (447 kB) Downloading xyzservices-2026.3.0-py3-none-any.whl (94 kB) Downloading matplotlib-3.10.8-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (8.7 MB) Downloading cycler-0.12.1-py3-none-any.whl (8.3 kB) Downloading fonttools-4.62.1-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (5.0 MB) Downloading kiwisolver-1.5.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (1.5 MB) Downloading python_dateutil-2.9.0.post0-py2.py3-none-any.whl (229 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: xyzservices, tornado, tenacity, python-dateutil, kiwisolver, fonttools, cycler, contourpy, plotly, pandas, matplotlib, mpld3, bokeh Attempting uninstall: python-dateutil Found existing installation: python-dateutil 2.8.1 Uninstalling python-dateutil-2.8.1: Successfully uninstalled python-dateutil-2.8.1 Successfully installed bokeh-3.1.1 contourpy-1.3.3 cycler-0.12.1 fonttools-4.62.1 kiwisolver-1.5.0 matplotlib-3.10.8 mpld3-0.5.9 pandas-3.0.2 plotly-5.13.1 python-dateutil-2.9.0.post0 tenacity-9.1.4 tornado-6.5.5 xyzservices-2026.3.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Collecting google-cloud-documentai (from -r account-invoicing/requirements.txt (line 2)) Downloading google_cloud_documentai-3.14.0-py3-none-any.whl.metadata (9.6 kB) Requirement already satisfied: openupgradelib in /home/runbot/.local/lib/python3.12/site-packages (from -r account-invoicing/requirements.txt (line 3)) (3.12.0) Collecting google-api-core<3.0.0,>=2.11.0 (from google-api-core[grpc]<3.0.0,>=2.11.0->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading google_api_core-2.30.2-py3-none-any.whl.metadata (3.1 kB) Collecting google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1 (from google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading google_auth-2.49.1-py3-none-any.whl.metadata (6.2 kB) Collecting grpcio<2.0.0,>=1.33.2 (from google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading grpcio-1.80.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.metadata (3.8 kB) Collecting proto-plus<2.0.0,>=1.22.3 (from google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading proto_plus-1.27.2-py3-none-any.whl.metadata (2.2 kB) Collecting protobuf<8.0.0,>=4.25.8 (from google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading protobuf-7.34.1-cp310-abi3-manylinux2014_x86_64.whl.metadata (595 bytes) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from openupgradelib->-r account-invoicing/requirements.txt (line 3)) (5.2.1) Requirement already satisfied: cssselect in /home/runbot/.local/lib/python3.12/site-packages (from openupgradelib->-r account-invoicing/requirements.txt (line 3)) (1.4.0) Collecting googleapis-common-protos<2.0.0,>=1.63.2 (from google-api-core<3.0.0,>=2.11.0->google-api-core[grpc]<3.0.0,>=2.11.0->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading googleapis_common_protos-1.74.0-py3-none-any.whl.metadata (9.2 kB) Requirement already satisfied: requests<3.0.0,>=2.20.0 in /usr/lib/python3/dist-packages (from google-api-core<3.0.0,>=2.11.0->google-api-core[grpc]<3.0.0,>=2.11.0->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (2.31.0) Collecting grpcio-status<2.0.0,>=1.33.2 (from google-api-core[grpc]<3.0.0,>=2.11.0->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading grpcio_status-1.80.0-py3-none-any.whl.metadata (1.3 kB) Requirement already satisfied: pyasn1-modules>=0.2.1 in /usr/local/lib/python3.12/dist-packages (from google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (0.4.2) Requirement already satisfied: cryptography>=38.0.3 in /home/runbot/.local/lib/python3.12/site-packages (from google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (46.0.7) Collecting typing-extensions~=4.12 (from grpcio<2.0.0,>=1.33.2->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading typing_extensions-4.15.0-py3-none-any.whl.metadata (3.3 kB) Requirement already satisfied: cffi>=2.0.0 in /usr/local/lib/python3.12/dist-packages (from cryptography>=38.0.3->google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (2.0.0) Collecting protobuf<8.0.0,>=4.25.8 (from google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) Downloading protobuf-6.33.6-cp39-abi3-manylinux2014_x86_64.whl.metadata (593 bytes) Requirement already satisfied: pyasn1<0.7.0,>=0.6.1 in /usr/local/lib/python3.12/dist-packages (from pyasn1-modules>=0.2.1->google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (0.6.2) Requirement already satisfied: pycparser in /usr/local/lib/python3.12/dist-packages (from cffi>=2.0.0->cryptography>=38.0.3->google-auth!=2.24.0,!=2.25.0,<3.0.0,>=2.14.1->google-cloud-documentai->-r account-invoicing/requirements.txt (line 2)) (3.0) Downloading google_cloud_documentai-3.14.0-py3-none-any.whl (311 kB) Downloading google_api_core-2.30.2-py3-none-any.whl (173 kB) Downloading google_auth-2.49.1-py3-none-any.whl (240 kB) Downloading grpcio-1.80.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (6.8 MB) Downloading proto_plus-1.27.2-py3-none-any.whl (50 kB) Downloading googleapis_common_protos-1.74.0-py3-none-any.whl (300 kB) Downloading grpcio_status-1.80.0-py3-none-any.whl (14 kB) Downloading protobuf-6.33.6-cp39-abi3-manylinux2014_x86_64.whl (323 kB) Downloading typing_extensions-4.15.0-py3-none-any.whl (44 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: typing-extensions, protobuf, proto-plus, grpcio, googleapis-common-protos, grpcio-status, google-auth, google-api-core, google-cloud-documentai Successfully installed google-api-core-2.30.2 google-auth-2.49.1 google-cloud-documentai-3.14.0 googleapis-common-protos-1.74.0 grpcio-1.80.0 grpcio-status-1.80.0 proto-plus-1.27.2 protobuf-6.33.6 typing-extensions-4.15.0 WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: openupgradelib in /home/runbot/.local/lib/python3.12/site-packages (from -r purchase-workflow/requirements.txt (line 2)) (3.12.0) Requirement already satisfied: lxml in /usr/lib/python3/dist-packages (from openupgradelib->-r purchase-workflow/requirements.txt (line 2)) (5.2.1) Requirement already satisfied: cssselect in /home/runbot/.local/lib/python3.12/site-packages (from openupgradelib->-r purchase-workflow/requirements.txt (line 2)) (1.4.0) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Requirement already satisfied: num2words in /home/runbot/.local/lib/python3.12/site-packages (from -r l10n-thailand/requirements.txt (line 2)) (0.5.9) Collecting promptpay (from -r l10n-thailand/requirements.txt (line 3)) Downloading promptpay-1.1.9-py3-none-any.whl.metadata (3.6 kB) Requirement already satisfied: docopt>=0.6.2 in /usr/lib/python3/dist-packages (from num2words->-r l10n-thailand/requirements.txt (line 2)) (0.6.2) Requirement already satisfied: qrcode in /home/runbot/.local/lib/python3.12/site-packages (from promptpay->-r l10n-thailand/requirements.txt (line 3)) (6.1) Collecting libscrc (from promptpay->-r l10n-thailand/requirements.txt (line 3)) Downloading libscrc-1.8.1-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.whl.metadata (16 kB) Requirement already satisfied: Pillow in /usr/lib/python3/dist-packages (from promptpay->-r l10n-thailand/requirements.txt (line 3)) (10.2.0) Requirement already satisfied: wheel in /usr/lib/python3/dist-packages (from libscrc->promptpay->-r l10n-thailand/requirements.txt (line 3)) (0.42.0) Requirement already satisfied: six in /usr/lib/python3/dist-packages (from qrcode->promptpay->-r l10n-thailand/requirements.txt (line 3)) (1.16.0) Downloading promptpay-1.1.9-py3-none-any.whl (5.8 kB) Downloading libscrc-1.8.1-cp312-cp312-manylinux_2_5_x86_64.manylinux1_x86_64.whl (189 kB) WARNING: Skipping /usr/lib/python3.12/dist-packages/charset_normalizer-3.3.2.dist-info due to invalid metadata entry 'name' Installing collected packages: libscrc, promptpay Successfully installed libscrc-1.8.1 promptpay-1.1.9 2026-04-08 04:14:27,134 381 INFO ? odoo: Odoo version 16.0 2026-04-08 04:14:27,134 381 INFO ? odoo: Using configuration file at /home/runbot/.odoorc 2026-04-08 04:14:27,134 381 INFO ? odoo: addons paths: ['/data/build/odoo/odoo/addons', '/data/build/datadir/addons/16.0', '/data/build/kmitl', '/data/build/stock-logistics-warehouse', '/data/build/stock-logistics-request', '/data/build/product-attribute', '/data/build/social', '/data/build/account-analytic', '/data/build/partner-contact', '/data/build/operating-unit', '/data/build/agreement', '/data/build/server-backend', '/data/build/account-reconcile', '/data/build/mis-builder', '/data/build/reporting-engine', '/data/build/odoo/addons', '/data/build/account-financial-reporting', '/data/build/project', '/data/build/server-tools', '/data/build/server-ux', '/data/build/hr', '/data/build/account-financial-tools', '/data/build/web', '/data/build/account-invoicing', '/data/build/purchase-workflow', '/data/build/server-brand', '/data/build/l10n-thailand', '/data/build/odoo-modules'] 2026-04-08 04:14:27,135 381 INFO ? odoo: database: runbot@default:default Warn: Can't find .pfb for face 'Courier' 2026-04-08 04:14:27,802 381 INFO ? odoo.addons.base.models.ir_actions_report: Will use the Wkhtmltopdf binary at /usr/local/bin/wkhtmltopdf 2026-04-08 04:14:28,116 381 INFO ? odoo.service.server: HTTP service (werkzeug) running on 0.0.0.0:8069 2026-04-08 04:14:28,139 381 INFO 10270-16-0-without_demo odoo.modules.loading: loading 1 modules... 2026-04-08 04:14:28,154 381 INFO 10270-16-0-without_demo odoo.modules.loading: 1 modules loaded in 0.01s, 0 queries (+0 extra) 2026-04-08 04:14:28,192 381 WARNING 10270-16-0-without_demo odoo.modules.module: Missing `license` key in manifest for 'agx_construction', defaulting to LGPL-3 2026-04-08 04:14:28,263 381 WARNING 10270-16-0-without_demo odoo.modules.module: Missing `license` key in manifest for 'agx_approval', defaulting to LGPL-3 2026-04-08 04:14:28,348 381 INFO 10270-16-0-without_demo odoo.modules.loading: loading 321 modules... 2026-04-08 04:14:31,404 381 INFO 10270-16-0-without_demo odoo.modules.loading: 321 modules loaded in 3.06s, 0 queries (+0 extra) 2026-04-08 04:14:31,864 381 INFO 10270-16-0-without_demo odoo.modules.loading: Modules loaded. 2026-04-08 04:14:31,882 381 INFO 10270-16-0-without_demo odoo.modules.registry: Registry loaded in 3.766s 2026-04-08 04:14:31,883 381 INFO 10270-16-0-without_demo odoo.sql_db: ConnectionPool(used=0/count=0/max=64): Closed 2 connections 2026-04-08 04:14:31,891 404 INFO 10270-16-0-without_demo odoo.service.server: Worker WorkerHTTP (404) alive 2026-04-08 04:14:31,898 406 INFO 10270-16-0-without_demo odoo.service.server: Worker WorkerHTTP (406) alive 2026-04-08 04:14:31,908 409 INFO 10270-16-0-without_demo odoo.service.server: Worker WorkerCron (409) alive 2026-04-08 04:14:33,412 407 INFO ? odoo: Odoo version 16.0 2026-04-08 04:14:33,412 407 INFO ? odoo: Using configuration file at /home/runbot/.odoorc 2026-04-08 04:14:33,412 407 INFO ? odoo: addons paths: ['/data/build/odoo/odoo/addons', '/data/build/datadir/addons/16.0', '/data/build/kmitl', '/data/build/stock-logistics-warehouse', '/data/build/stock-logistics-request', '/data/build/product-attribute', '/data/build/social', '/data/build/account-analytic', '/data/build/partner-contact', '/data/build/operating-unit', '/data/build/agreement', '/data/build/server-backend', '/data/build/account-reconcile', '/data/build/mis-builder', '/data/build/reporting-engine', '/data/build/odoo/addons', '/data/build/account-financial-reporting', '/data/build/project', '/data/build/server-tools', '/data/build/server-ux', '/data/build/hr', '/data/build/account-financial-tools', '/data/build/web', '/data/build/account-invoicing', '/data/build/purchase-workflow', '/data/build/server-brand', '/data/build/l10n-thailand', '/data/build/odoo-modules'] 2026-04-08 04:14:33,413 407 INFO ? odoo: database: runbot@default:default Warn: Can't find .pfb for face 'Courier' 2026-04-08 04:14:34,166 407 INFO ? odoo.addons.base.models.ir_actions_report: Will use the Wkhtmltopdf binary at /usr/local/bin/wkhtmltopdf 2026-04-08 04:14:34,490 407 INFO ? odoo.service.server: Evented Service (longpolling) running on 0.0.0.0:8070 2026-04-08 04:15:41,210 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `purchase_order_fines_late_daily`. 2026-04-08 04:15:41,225 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `purchase_order_fines_late_daily` done. 2026-04-08 04:15:41,245 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Send Tier Review Reminder`. 2026-04-08 04:15:41,254 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Send Tier Review Reminder` done. 2026-04-08 04:15:41,262 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 04:15:41,268 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 04:15:41,276 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Recompute Contract Expire Days`. 2026-04-08 04:15:41,353 409 WARNING 10270-16-0-without_demo py.warnings: /data/build/odoo/odoo/fields.py:809: UserWarning: Field 'purchase.order.wa_ids' in dependency of purchase.order.pending_wa_count should be searchable. This is necessary to determine which records to recompute when work.acceptance.state is modified. You should either make the field searchable, or simplify the field dependency. File "/usr/lib/python3.12/threading.py", line 1030, in _bootstrap self._bootstrap_inner() File "/usr/lib/python3.12/threading.py", line 1073, in _bootstrap_inner self.run() File "/usr/lib/python3.12/threading.py", line 1010, in run self._target(*self._args, **self._kwargs) File "/data/build/odoo/odoo/service/server.py", line 1129, in _runloop self.process_work() File "/data/build/odoo/odoo/service/server.py", line 1228, in process_work base.models.ir_cron.ir_cron._process_jobs(db_name) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 135, in _process_jobs registry[cls._name]._process_job(db, cron_cr, job) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 350, in _process_job ir_cron._callback(job['cron_name'], job['ir_actions_server_id'], job['id']) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) File "ir.actions.server(749,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 34, in action_recompute_expire records._compute_days_to_expire() File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 47, in _compute_days_to_expire record.days_to_expire = (record.work_end - today).days File "/data/build/odoo/odoo/fields.py", line 1337, in __set__ records.write({self.name: write_value}) File "/data/build/odoo/addons/purchase_stock/models/purchase.py", line 95, in write res = super(PurchaseOrder, self).write(vals) File "/data/build/odoo/addons/purchase_requisition/models/purchase.py", line 158, in write result = super(PurchaseOrder, self).write(vals) File "/data/build/purchase-workflow/purchase_exception/models/purchase.py", line 41, in write result = super().write(vals) File "/data/build/odoo/addons/purchase/models/purchase.py", line 235, in write res = super().write(vals) File "/data/build/odoo/addons/mail/models/mail_thread.py", line 315, in write result = super(MailThread, self).write(values) File "/data/build/odoo/addons/mail/models/mail_activity_mixin.py", line 241, in write return super(MailActivityMixin, self).write(vals) File "/data/build/kmitl/account_analytic_kmitl/models/analytic_mixin.py", line 82, in write res = super().write(vals) File "/data/build/odoo/addons/analytic/models/analytic_mixin.py", line 82, in write return super().write(vals) File "/data/build/odoo/odoo/models.py", line 3766, in write if self.pool.is_modifying_relations(field): File "/data/build/odoo/odoo/modules/registry.py", line 458, in is_modifying_relations result = field in self._field_triggers and ( File "/data/build/odoo/odoo/tools/func.py", line 28, in __get__ value = self.fget(obj) File "/data/build/odoo/odoo/modules/registry.py", line 439, in _field_triggers dependencies = list(field.resolve_depends(self)) File "/data/build/odoo/odoo/fields.py", line 809, in resolve_depends warnings.warn( 2026-04-08 04:15:41,364 409 WARNING 10270-16-0-without_demo py.warnings: /data/build/odoo/odoo/fields.py:809: UserWarning: Field 'purchase.order.wa_ids' in dependency of purchase.order.pending_wa_count should be searchable. This is necessary to determine which records to recompute when work.acceptance.is_disbursed is modified. You should either make the field searchable, or simplify the field dependency. File "/usr/lib/python3.12/threading.py", line 1030, in _bootstrap self._bootstrap_inner() File "/usr/lib/python3.12/threading.py", line 1073, in _bootstrap_inner self.run() File "/usr/lib/python3.12/threading.py", line 1010, in run self._target(*self._args, **self._kwargs) File "/data/build/odoo/odoo/service/server.py", line 1129, in _runloop self.process_work() File "/data/build/odoo/odoo/service/server.py", line 1228, in process_work base.models.ir_cron.ir_cron._process_jobs(db_name) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 135, in _process_jobs registry[cls._name]._process_job(db, cron_cr, job) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 350, in _process_job ir_cron._callback(job['cron_name'], job['ir_actions_server_id'], job['id']) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) File "ir.actions.server(749,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 34, in action_recompute_expire records._compute_days_to_expire() File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 47, in _compute_days_to_expire record.days_to_expire = (record.work_end - today).days File "/data/build/odoo/odoo/fields.py", line 1337, in __set__ records.write({self.name: write_value}) File "/data/build/odoo/addons/purchase_stock/models/purchase.py", line 95, in write res = super(PurchaseOrder, self).write(vals) File "/data/build/odoo/addons/purchase_requisition/models/purchase.py", line 158, in write result = super(PurchaseOrder, self).write(vals) File "/data/build/purchase-workflow/purchase_exception/models/purchase.py", line 41, in write result = super().write(vals) File "/data/build/odoo/addons/purchase/models/purchase.py", line 235, in write res = super().write(vals) File "/data/build/odoo/addons/mail/models/mail_thread.py", line 315, in write result = super(MailThread, self).write(values) File "/data/build/odoo/addons/mail/models/mail_activity_mixin.py", line 241, in write return super(MailActivityMixin, self).write(vals) File "/data/build/kmitl/account_analytic_kmitl/models/analytic_mixin.py", line 82, in write res = super().write(vals) File "/data/build/odoo/addons/analytic/models/analytic_mixin.py", line 82, in write return super().write(vals) File "/data/build/odoo/odoo/models.py", line 3766, in write if self.pool.is_modifying_relations(field): File "/data/build/odoo/odoo/modules/registry.py", line 458, in is_modifying_relations result = field in self._field_triggers and ( File "/data/build/odoo/odoo/tools/func.py", line 28, in __get__ value = self.fget(obj) File "/data/build/odoo/odoo/modules/registry.py", line 439, in _field_triggers dependencies = list(field.resolve_depends(self)) File "/data/build/odoo/odoo/fields.py", line 809, in resolve_depends warnings.warn( 2026-04-08 04:15:41,366 409 WARNING 10270-16-0-without_demo py.warnings: /data/build/odoo/odoo/fields.py:809: UserWarning: Field 'purchase.order.wa_ids' in dependency of purchase.order.wa_fines_total should be searchable. This is necessary to determine which records to recompute when work.acceptance.state is modified. You should either make the field searchable, or simplify the field dependency. File "/usr/lib/python3.12/threading.py", line 1030, in _bootstrap self._bootstrap_inner() File "/usr/lib/python3.12/threading.py", line 1073, in _bootstrap_inner self.run() File "/usr/lib/python3.12/threading.py", line 1010, in run self._target(*self._args, **self._kwargs) File "/data/build/odoo/odoo/service/server.py", line 1129, in _runloop self.process_work() File "/data/build/odoo/odoo/service/server.py", line 1228, in process_work base.models.ir_cron.ir_cron._process_jobs(db_name) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 135, in _process_jobs registry[cls._name]._process_job(db, cron_cr, job) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 350, in _process_job ir_cron._callback(job['cron_name'], job['ir_actions_server_id'], job['id']) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) File "ir.actions.server(749,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 34, in action_recompute_expire records._compute_days_to_expire() File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 47, in _compute_days_to_expire record.days_to_expire = (record.work_end - today).days File "/data/build/odoo/odoo/fields.py", line 1337, in __set__ records.write({self.name: write_value}) File "/data/build/odoo/addons/purchase_stock/models/purchase.py", line 95, in write res = super(PurchaseOrder, self).write(vals) File "/data/build/odoo/addons/purchase_requisition/models/purchase.py", line 158, in write result = super(PurchaseOrder, self).write(vals) File "/data/build/purchase-workflow/purchase_exception/models/purchase.py", line 41, in write result = super().write(vals) File "/data/build/odoo/addons/purchase/models/purchase.py", line 235, in write res = super().write(vals) File "/data/build/odoo/addons/mail/models/mail_thread.py", line 315, in write result = super(MailThread, self).write(values) File "/data/build/odoo/addons/mail/models/mail_activity_mixin.py", line 241, in write return super(MailActivityMixin, self).write(vals) File "/data/build/kmitl/account_analytic_kmitl/models/analytic_mixin.py", line 82, in write res = super().write(vals) File "/data/build/odoo/addons/analytic/models/analytic_mixin.py", line 82, in write return super().write(vals) File "/data/build/odoo/odoo/models.py", line 3766, in write if self.pool.is_modifying_relations(field): File "/data/build/odoo/odoo/modules/registry.py", line 458, in is_modifying_relations result = field in self._field_triggers and ( File "/data/build/odoo/odoo/tools/func.py", line 28, in __get__ value = self.fget(obj) File "/data/build/odoo/odoo/modules/registry.py", line 439, in _field_triggers dependencies = list(field.resolve_depends(self)) File "/data/build/odoo/odoo/fields.py", line 809, in resolve_depends warnings.warn( 2026-04-08 04:15:41,367 409 WARNING 10270-16-0-without_demo py.warnings: /data/build/odoo/odoo/fields.py:809: UserWarning: Field 'purchase.order.wa_ids' in dependency of purchase.order.wa_fines_total should be searchable. This is necessary to determine which records to recompute when work.acceptance.is_disbursed is modified. You should either make the field searchable, or simplify the field dependency. File "/usr/lib/python3.12/threading.py", line 1030, in _bootstrap self._bootstrap_inner() File "/usr/lib/python3.12/threading.py", line 1073, in _bootstrap_inner self.run() File "/usr/lib/python3.12/threading.py", line 1010, in run self._target(*self._args, **self._kwargs) File "/data/build/odoo/odoo/service/server.py", line 1129, in _runloop self.process_work() File "/data/build/odoo/odoo/service/server.py", line 1228, in process_work base.models.ir_cron.ir_cron._process_jobs(db_name) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 135, in _process_jobs registry[cls._name]._process_job(db, cron_cr, job) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 350, in _process_job ir_cron._callback(job['cron_name'], job['ir_actions_server_id'], job['id']) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) File "ir.actions.server(749,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 34, in action_recompute_expire records._compute_days_to_expire() File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 47, in _compute_days_to_expire record.days_to_expire = (record.work_end - today).days File "/data/build/odoo/odoo/fields.py", line 1337, in __set__ records.write({self.name: write_value}) File "/data/build/odoo/addons/purchase_stock/models/purchase.py", line 95, in write res = super(PurchaseOrder, self).write(vals) File "/data/build/odoo/addons/purchase_requisition/models/purchase.py", line 158, in write result = super(PurchaseOrder, self).write(vals) File "/data/build/purchase-workflow/purchase_exception/models/purchase.py", line 41, in write result = super().write(vals) File "/data/build/odoo/addons/purchase/models/purchase.py", line 235, in write res = super().write(vals) File "/data/build/odoo/addons/mail/models/mail_thread.py", line 315, in write result = super(MailThread, self).write(values) File "/data/build/odoo/addons/mail/models/mail_activity_mixin.py", line 241, in write return super(MailActivityMixin, self).write(vals) File "/data/build/kmitl/account_analytic_kmitl/models/analytic_mixin.py", line 82, in write res = super().write(vals) File "/data/build/odoo/addons/analytic/models/analytic_mixin.py", line 82, in write return super().write(vals) File "/data/build/odoo/odoo/models.py", line 3766, in write if self.pool.is_modifying_relations(field): File "/data/build/odoo/odoo/modules/registry.py", line 458, in is_modifying_relations result = field in self._field_triggers and ( File "/data/build/odoo/odoo/tools/func.py", line 28, in __get__ value = self.fget(obj) File "/data/build/odoo/odoo/modules/registry.py", line 439, in _field_triggers dependencies = list(field.resolve_depends(self)) File "/data/build/odoo/odoo/fields.py", line 809, in resolve_depends warnings.warn( 2026-04-08 04:15:41,368 409 WARNING 10270-16-0-without_demo py.warnings: /data/build/odoo/odoo/fields.py:809: UserWarning: Field 'purchase.order.wa_ids' in dependency of purchase.order.wa_fines_total should be searchable. This is necessary to determine which records to recompute when work.acceptance.fines_total is modified. You should either make the field searchable, or simplify the field dependency. File "/usr/lib/python3.12/threading.py", line 1030, in _bootstrap self._bootstrap_inner() File "/usr/lib/python3.12/threading.py", line 1073, in _bootstrap_inner self.run() File "/usr/lib/python3.12/threading.py", line 1010, in run self._target(*self._args, **self._kwargs) File "/data/build/odoo/odoo/service/server.py", line 1129, in _runloop self.process_work() File "/data/build/odoo/odoo/service/server.py", line 1228, in process_work base.models.ir_cron.ir_cron._process_jobs(db_name) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 135, in _process_jobs registry[cls._name]._process_job(db, cron_cr, job) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 350, in _process_job ir_cron._callback(job['cron_name'], job['ir_actions_server_id'], job['id']) File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) File "ir.actions.server(749,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 34, in action_recompute_expire records._compute_days_to_expire() File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 47, in _compute_days_to_expire record.days_to_expire = (record.work_end - today).days File "/data/build/odoo/odoo/fields.py", line 1337, in __set__ records.write({self.name: write_value}) File "/data/build/odoo/addons/purchase_stock/models/purchase.py", line 95, in write res = super(PurchaseOrder, self).write(vals) File "/data/build/odoo/addons/purchase_requisition/models/purchase.py", line 158, in write result = super(PurchaseOrder, self).write(vals) File "/data/build/purchase-workflow/purchase_exception/models/purchase.py", line 41, in write result = super().write(vals) File "/data/build/odoo/addons/purchase/models/purchase.py", line 235, in write res = super().write(vals) File "/data/build/odoo/addons/mail/models/mail_thread.py", line 315, in write result = super(MailThread, self).write(values) File "/data/build/odoo/addons/mail/models/mail_activity_mixin.py", line 241, in write return super(MailActivityMixin, self).write(vals) File "/data/build/kmitl/account_analytic_kmitl/models/analytic_mixin.py", line 82, in write res = super().write(vals) File "/data/build/odoo/addons/analytic/models/analytic_mixin.py", line 82, in write return super().write(vals) File "/data/build/odoo/odoo/models.py", line 3766, in write if self.pool.is_modifying_relations(field): File "/data/build/odoo/odoo/modules/registry.py", line 458, in is_modifying_relations result = field in self._field_triggers and ( File "/data/build/odoo/odoo/tools/func.py", line 28, in __get__ value = self.fget(obj) File "/data/build/odoo/odoo/modules/registry.py", line 439, in _field_triggers dependencies = list(field.resolve_depends(self)) File "/data/build/odoo/odoo/fields.py", line 809, in resolve_depends warnings.warn( 2026-04-08 04:15:41,407 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Recompute Contract Expire Days` done. 2026-04-08 04:15:41,414 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notify Contract Nearly Expire`. 2026-04-08 04:15:41,430 409 ERROR 10270-16-0-without_demo odoo.sql_db: bad query: INSERT INTO "mail_channel_member" ("channel_id", "create_date", "create_uid", "fold_state", "is_pinned", "last_interest_dt", "partner_id", "write_date", "write_uid") VALUES (2, '2026-04-08 04:15:41.411616', 1, 'open', true, '2026-04-08 04:15:41', 2, '2026-04-08 04:15:41.411616', 1), (2, '2026-04-08 04:15:41.411616', 1, 'open', true, '2026-04-08 04:15:41', 2, '2026-04-08 04:15:41.411616', 1) RETURNING "id" ERROR: duplicate key value violates unique constraint "mail_channel_member_partner_unique" DETAIL: Key (channel_id, partner_id)=(2, 2) already exists. 2026-04-08 04:15:41,432 409 ERROR 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Call from cron Notify Contract Nearly Expire for server action #750 failed in Job #35 Traceback (most recent call last): File "/data/build/odoo/odoo/tools/safe_eval.py", line 399, in safe_eval return unsafe_eval(c, globals_dict, locals_dict) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "ir.actions.server(750,)", line 1, in File "/data/build/kmitl/purchase_order_expiration/models/purchase_order.py", line 101, in _cron_notify_contract_expire channel_data = self.env['mail.channel'].sudo().channel_get( ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/addons/mail/models/mail_channel.py", line 894, in channel_get channel = self.create({ ^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 430, in _model_create_multi return create(self, [arg]) ^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/addons/mail/models/mail_channel.py", line 239, in create channels = super(Channel, self.with_context(mail_create_bypass_create_check=self.env['mail.channel.member']._bypass_create_check, mail_create_nolog=True, mail_create_nosubscribe=True)).create(vals_list) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/addons/mail/models/mail_thread.py", line 258, in create threads = super(MailThread, self).create(vals_list) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/addons/base/models/ir_fields.py", line 670, in create recs = super().create(vals_list) ^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/models.py", line 4019, in create records = self._create(data_list) ^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/models.py", line 4256, in _create field.create([ File "/data/build/odoo/odoo/fields.py", line 4282, in create self.write_batch(record_values, True) File "/data/build/odoo/odoo/fields.py", line 4308, in write_batch return self.write_real(records_commands_list, create) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/fields.py", line 4508, in write_real flush() File "/data/build/odoo/odoo/fields.py", line 4464, in flush comodel.create(to_create) File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/addons/mail/models/mail_channel_member.py", line 88, in create return super().create(vals_list) ^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/addons/base/models/ir_fields.py", line 670, in create recs = super().create(vals_list) ^^^^^^^^^^^^^^^^^^^^^^^^^ File "", line 2, in create File "/data/build/odoo/odoo/api.py", line 431, in _model_create_multi return create(self, arg) ^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/models.py", line 4019, in create records = self._create(data_list) ^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/models.py", line 4200, in _create cr.execute( File "/data/build/odoo/odoo/sql_db.py", line 321, in execute res = self._obj.execute(query, params) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ psycopg2.errors.UniqueViolation: duplicate key value violates unique constraint "mail_channel_member_partner_unique" DETAIL: Key (channel_id, partner_id)=(2, 2) already exists. During handling of the above exception, another exception occurred: Traceback (most recent call last): File "/data/build/odoo/odoo/addons/base/models/ir_cron.py", line 391, in _callback self.env['ir.actions.server'].browse(server_action_id).run() File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 675, in run res = runner(run_self, eval_context=eval_context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/addons/website/models/ir_actions_server.py", line 61, in _run_action_code_multi res = super(ServerAction, self)._run_action_code_multi(eval_context) ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/addons/base/models/ir_actions.py", line 545, in _run_action_code_multi safe_eval(self.code.strip(), eval_context, mode="exec", nocopy=True, filename=str(self)) # nocopy allows to return 'action' ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ File "/data/build/odoo/odoo/tools/safe_eval.py", line 413, in safe_eval raise ValueError('%s: "%s" while evaluating\n%r' % (ustr(type(e)), ustr(e), expr)) ValueError: : "duplicate key value violates unique constraint "mail_channel_member_partner_unique" DETAIL: Key (channel_id, partner_id)=(2, 2) already exists. " while evaluating 'model._cron_notify_contract_expire()' 2026-04-08 04:15:41,443 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Base: Auto-vacuum internal data`. 2026-04-08 04:15:41,475 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_attachment: filestore gc 131 checked, 7 removed 2026-04-08 04:15:41,544 409 INFO 10270-16-0-without_demo odoo.addons.base.models.res_users: GC'd 0 user log entries 2026-04-08 04:15:41,583 409 INFO 10270-16-0-without_demo odoo.addons.auth_totp.models.auth_totp: GC'd 0 totp devices entries 2026-04-08 04:15:41,611 409 INFO 10270-16-0-without_demo odoo.models.unlink: User #1 deleted bus.bus records with IDs: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30] 2026-04-08 04:15:42,110 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Base: Auto-vacuum internal data` done. 2026-04-08 04:15:42,116 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 04:15:42,120 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 04:15:42,125 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Delete Notifications older than 6 Month`. 2026-04-08 04:15:42,129 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Delete Notifications older than 6 Month` done. 2026-04-08 04:15:42,133 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 04:15:42,135 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 04:15:42,140 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Users: Notify About Unregistered Users`. 2026-04-08 04:15:42,144 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Users: Notify About Unregistered Users` done. 2026-04-08 04:15:42,148 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Disable unused snippets assets`. 2026-04-08 04:15:43,570 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Disable unused snippets assets` done. 2026-04-08 04:15:43,578 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Website Visitor : clean inactive visitors`. 2026-04-08 04:15:43,581 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Website Visitor : clean inactive visitors` done. 2026-04-08 04:15:43,585 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Procurement: run scheduler`. 2026-04-08 04:15:43,594 409 INFO 10270-16-0-without_demo odoo.addons.stock.models.stock_rule: _run_scheduler_tasks is finished and committed 2026-04-08 04:15:43,594 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Procurement: run scheduler` done. 2026-04-08 04:15:43,598 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Purchase reminder`. 2026-04-08 04:15:43,602 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Purchase reminder` done. 2026-04-08 04:15:43,606 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Project: Send rating`. 2026-04-08 04:15:43,608 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Project: Send rating` done. 2026-04-08 04:15:43,612 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `HR Employee: check work permit validity`. 2026-04-08 04:15:43,615 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `HR Employee: check work permit validity` done. 2026-04-08 04:15:43,618 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Calendar: Event Reminder`. 2026-04-08 04:15:43,622 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Calendar: Event Reminder` done. 2026-04-08 04:15:43,626 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Accrual Time Off: Updates the number of time off`. 2026-04-08 04:15:43,630 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Accrual Time Off: Updates the number of time off` done. 2026-04-08 04:15:43,634 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `HR Contract: update state`. 2026-04-08 04:15:43,639 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `HR Contract: update state` done. 2026-04-08 04:15:43,644 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 04:15:43,646 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 04:15:43,650 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:15:43,653 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 04:15:43,657 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Close Expired Job Postings`. 2026-04-08 04:15:43,660 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Close Expired Job Postings` done. 2026-04-08 04:15:43,664 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 04:15:43,667 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 04:15:43,671 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Update user roles`. 2026-04-08 04:15:43,673 409 INFO 10270-16-0-without_demo root: Update user roles 2026-04-08 04:15:43,674 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Update user roles` done. 2026-04-08 04:15:43,678 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 04:15:43,680 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 04:19:11,211 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:19:11,220 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 04:28:24,656 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:28:24,661 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 04:38:47,337 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:38:47,343 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 04:49:09,943 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:49:09,951 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 04:58:23,214 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 04:58:23,221 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:07:36,706 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 05:07:36,713 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 05:07:36,725 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 05:07:36,732 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 05:08:45,927 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 05:08:45,934 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 05:08:45,946 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 05:08:45,952 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 05:08:45,962 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 05:08:45,969 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 05:08:45,979 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:08:45,985 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:13:22,697 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 05:13:22,704 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 05:19:08,610 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:19:08,618 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:28:21,944 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:28:21,957 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:38:44,649 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:38:44,656 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:49:07,310 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:49:07,322 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 05:58:20,747 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 05:58:20,754 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:07:34,132 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 06:07:34,144 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 06:07:34,154 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 06:07:34,160 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 06:08:43,284 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Digest Emails`. 2026-04-08 06:08:45,937 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Digest Emails` done. 2026-04-08 06:08:45,953 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 06:08:45,957 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 06:08:45,965 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 06:08:45,969 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 06:08:45,986 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 06:08:45,991 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 06:08:45,998 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:08:46,002 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:13:22,703 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 06:13:22,709 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 06:19:08,595 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:19:08,600 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:28:22,112 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:28:22,119 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:38:44,846 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:38:44,850 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:49:07,565 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:49:07,571 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 06:58:21,025 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 06:58:21,029 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:07:34,528 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Update user roles`. 2026-04-08 07:07:34,532 409 INFO 10270-16-0-without_demo root: Update user roles 2026-04-08 07:07:34,534 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Update user roles` done. 2026-04-08 07:07:34,543 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 07:07:34,567 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 07:07:34,575 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 07:07:34,580 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 07:08:43,784 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 07:08:43,789 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 07:08:43,800 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 07:08:43,806 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 07:08:43,815 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:08:43,820 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:08:43,830 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 07:08:43,836 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 07:13:20,607 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 07:13:20,611 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 07:19:06,576 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:19:06,582 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:28:20,049 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:28:20,056 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:38:42,753 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:38:42,760 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:49:05,488 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:49:05,496 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 07:58:19,007 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 07:58:19,019 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:08:41,632 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 08:08:41,638 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 08:08:41,648 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 08:08:41,655 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 08:08:41,666 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 08:08:41,671 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 08:08:41,681 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:08:41,687 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:08:41,697 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 08:08:41,702 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 08:08:41,709 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 08:08:41,716 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 08:13:18,473 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 08:13:18,485 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 08:19:04,464 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:19:04,472 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:28:17,958 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:28:17,971 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:38:40,704 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:38:40,709 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:49:03,453 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:49:03,461 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 08:58:17,009 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 08:58:17,017 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:08:39,699 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 09:08:39,711 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 09:08:39,725 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 09:08:39,733 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 09:08:39,740 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 09:08:39,745 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 09:08:39,753 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 09:08:39,758 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 09:08:39,765 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:08:39,770 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:08:39,778 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 09:08:39,782 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 09:13:16,555 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 09:13:16,565 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 09:19:02,519 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:19:02,527 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:28:16,031 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:28:16,038 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:38:38,772 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:38:38,785 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:49:01,480 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:49:01,492 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 09:58:14,915 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 09:58:14,925 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:07:28,491 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Update user roles`. 2026-04-08 10:07:28,497 409 INFO 10270-16-0-without_demo root: Update user roles 2026-04-08 10:07:28,498 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Update user roles` done. 2026-04-08 10:08:37,708 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Mail: Email Queue Manager`. 2026-04-08 10:08:37,720 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Mail: Email Queue Manager` done. 2026-04-08 10:08:37,842 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Notification: Send scheduled message notifications`. 2026-04-08 10:08:37,850 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Notification: Send scheduled message notifications` done. 2026-04-08 10:08:37,859 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Partner Autocomplete : Sync with remote DB`. 2026-04-08 10:08:37,863 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Partner Autocomplete : Sync with remote DB` done. 2026-04-08 10:08:37,871 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Snailmail: process letters queue`. 2026-04-08 10:08:37,877 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Snailmail: process letters queue` done. 2026-04-08 10:08:37,885 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:08:37,890 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:08:37,898 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `SMS: SMS Queue Manager`. 2026-04-08 10:08:37,902 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `SMS: SMS Queue Manager` done. 2026-04-08 10:13:14,683 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `Automatic Tier Validation`. 2026-04-08 10:13:14,692 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `Automatic Tier Validation` done. 2026-04-08 10:19:00,593 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:19:00,601 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:28:14,075 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:28:14,087 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:38:36,769 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:38:36,781 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:48:59,457 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:48:59,465 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done. 2026-04-08 10:58:13,031 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Starting job `payment: post-process transactions`. 2026-04-08 10:58:13,036 409 INFO 10270-16-0-without_demo odoo.addons.base.models.ir_cron: Job `payment: post-process transactions` done.