Description: Install and run Odoo without demo data
Commit: kmitl:7aff8947  
Subject: [IMP] budget_appropriation_summary: show fiscal year in compilation kanban
Author: n3n
Committer: n3n
Commit: stock-logistics-warehouse:4ded2829  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: stock-logistics-request:fa8a6725  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: product-attribute:38ea6888  
Subject: Translated using Weblate (Portuguese (Brazil))
Author: Rodrigo A. Madureira
Committer: Weblate
Commit: social:6c3434b6  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: account-analytic:fec6e341  
Subject: Added translation using Weblate (Galician (gl_ES))
Author: Cándido Martínez
Committer: Weblate
Commit: partner-contact:7acbeb8d  
Subject: Translated using Weblate (French)
Author: risto42
Committer: Weblate
Commit: operating-unit:dd59492d  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: agreement:800e753c  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: server-backend:ccf60878  
Subject: Update requirements.txt
Author: Nopparut Saelim
Committer: GitHub
Commit: account-reconcile:c031db9d  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: mis-builder:82d39175  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: reporting-engine:4cafaadb  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: odoo:6491e005  
Subject: [FIX] survey: avoid timer early submissions due to time difference
Author: João Alves
Committer: João Horta Alves
Commit: account-financial-reporting:948901d9  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: project:7a5c615c  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: server-tools:3abe25d7  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: server-ux:23e96d19  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: hr:3af635cb  
Subject: Translated using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: account-financial-tools:c3b3e7dd  
Subject: Added translation using Weblate (Italian)
Author: mymage
Committer: Weblate
Commit: web:fb9be06e  
Subject: Translated using Weblate (Portuguese (Brazil))
Author: Luis Felipe Miléo
Committer: Weblate
Commit: account-invoicing:7207e6e2  
Subject: [BOT] post-merge updates
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: purchase-workflow:ecf70d6c  
Subject: Translated using Weblate (Turkish)
Author: Betül Öğmen
Committer: Weblate
Commit: server-brand:2bc45d77  
Subject: [UPD] addons table in README.md
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: l10n-thailand:0b7b078e  
Subject: [UPD] addons table in README.md
Author: OCA-git-bot
Committer: OCA-git-bot
Commit: odoo-modules:76529673  
Subject: Merge branch '16.0' of github.com:Aginix/odoo-modules into 16.0
Author: Nonpawit Teerachetmongkol
Committer: Nonpawit Teerachetmongkol
Version: 16.0
Config: Without demo
Total time: 7m
Date Level Type Message
2026-04-08 09:25:38 INFO runbot Init build environment with config Without demo
2026-04-08 09:25:38 Starting step install_without_demo from config Without demo
2026-04-08 09:25:38 INFO runbot Using Dockerfile Tag odoo:DockerDefaultAke
2026-04-08 09:27:29 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_approval', defaulting to LGPL-3
2026-04-08 09:27:29 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_construction', defaulting to LGPL-3
2026-04-08 09:27:44 INFO server odoo.modules.loading:336 1 modules loaded in 9.66s, 7917 queries (+7917 extra)
2026-04-08 09:28:10 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:10 WARNING server odoo.addons.base.models.ir_module:964 module office_order: description is empty !
2026-04-08 09:28:14 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:16 WARNING server odoo.addons.base.models.ir_module:964 module aginix_hrms_base: description is empty !
2026-04-08 09:28:20 WARNING server odoo.addons.base.models.ir_module:964 module hr_employee_education_history: description is empty !
2026-04-08 09:28:20 WARNING server odoo.addons.base.models.ir_module:964 module hr_employee_role: description is empty !
2026-04-08 09:28:23 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:25 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:26 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:27 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of sarabun.document() have the same label: Attachment Count. [Modules: agx_sarabun and mail]
2026-04-08 09:28:28 WARNING server odoo.addons.base.models.ir_ui_view:773
A button with icon attribute (fa-envelope-open) must have title in its tag, parents, descendants or have text
View error context:
{'file': '/data/build/kmitl/agx_sarabun/views/sarabun_document_views.xml',
 'line': 13,
 'name': 'sarabun.document.view.tree.incoming',
 'view': ir.ui.view(834,),
 'view.model': 'sarabun.document',
 'view.parent': ir.ui.view(),
 'xmlid': 'sarabun_document_view_tree_incoming'}
2026-04-08 09:28:28 WARNING server odoo.addons.base.models.ir_ui_view:773
A button with icon attribute (fa-envelope) must have title in its tag, parents, descendants or have text
View error context:
{'file': '/data/build/kmitl/agx_sarabun/views/sarabun_document_views.xml',
 'line': 14,
 'name': 'sarabun.document.view.tree.incoming',
 'view': ir.ui.view(834,),
 'view.model': 'sarabun.document',
 'view.parent': ir.ui.view(),
 'xmlid': 'sarabun_document_view_tree_incoming'}
2026-04-08 09:28:30 WARNING server odoo.addons.base.models.ir_module:964 module hr_employee_security_role: description is empty !
2026-04-08 09:28:30 WARNING server odoo.models:4437 Creating record hr.access_hr_central_user in module hr_employee_security_role.
2026-04-08 09:28:30 WARNING server odoo.models:4437 Creating record hr.access_hr_department_manager in module hr_employee_security_role.
2026-04-08 09:28:30 WARNING server odoo.models:4437 Creating record hr.access_hr_departure_reason_manager in module hr_employee_security_role.
2026-04-08 09:28:30 WARNING server odoo.addons.base.models.ir_ui_view:412 Error-prone use of @class in view hr.employee.form.inherit (): use the hasclass(*classes) function to filter elements by their classes
2026-04-08 09:28:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of sarabun.document() have the same label: Attachment Count. [Modules: agx_sarabun and mail]
2026-04-08 09:28:39 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (position_level_id, position_level_ids) of hr.employee() have the same label: Position Level. [Modules: hr_employee_position_level and hr_employee_position_level]
2026-04-08 09:28:39 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:39 WARNING server odoo.addons.base.models.ir_module:964 module hr_employee_position_level: description is empty !
2026-04-08 09:28:40 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (position_level_id, position_level_ids) of hr.employee() have the same label: Position Level. [Modules: hr_employee_position_level and hr_employee_position_level]
2026-04-08 09:28:53 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (position_level_id, position_level_ids) of hr.employee() have the same label: Position Level. [Modules: hr_employee_position_level and hr_employee_position_level]
2026-04-08 09:28:53 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of office.order() have the same label: Attachment Count. [Modules: office_order and mail]
2026-04-08 09:28:53 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (attachment_count, message_attachment_count) of sarabun.document() have the same label: Attachment Count. [Modules: agx_sarabun and mail]
2026-04-08 09:29:04 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (position_level_id, position_level_ids) of hr.employee() have the same label: Position Level. [Modules: hr_employee_position_level and hr_employee_position_level]
2026-04-08 09:29:04 WARNING server odoo.addons.base.models.ir_module:964 module hr_employee_academic_standing_thailand: description is empty !
2026-04-08 09:29:47 WARNING server odoo.addons.stock_warehouse_kmitl.hooks:16 Updated warehouse 1 -> KMITL, OU cleared
2026-04-08 09:29:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.move.line() have the same label: รหัสงบประมาณ. [Modules: budget and budget]
This error is already known.
2026-04-08 09:30:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:30:50 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.move.line() have the same label: รหัสงบประมาณ. [Modules: budget and budget]
This error is already known.
2026-04-08 09:30:51 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (participant_ids, target_ids) of kmitl.project() have the same label: กลุ่มเป้าหมาย/ผู้ดำเนินโครงการ. [Modules: kmitl_project and kmitl_project]
2026-04-08 09:30:51 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (organizer_ids, target_ids) of kmitl.project() have the same label: กลุ่มเป้าหมาย/ผู้ดำเนินโครงการ. [Modules: kmitl_project and kmitl_project]
2026-04-08 09:30:53 WARNING server odoo.modules.loading:276
The models ['kmitl.project.exception.confirm'] have no access rules in module kmitl_project, consider adding some, like:
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
kmitl_project.access_kmitl_project_exception_confirm,access_kmitl_project_exception_confirm,kmitl_project.model_kmitl_project_exception_confirm,base.group_user,1,0,0,0
2026-04-08 09:30:55 WARNING server odoo.fields:2831 Field procurement.plan.procurement_method_id with unknown comodel_name 'procurement.method'
2026-04-08 09:30:55 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.move.line() have the same label: รหัสงบประมาณ. [Modules: budget and budget]
This error is already known.
2026-04-08 09:30:55 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:31:00 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (tax_id, price_tax) of purchase.request.line() have the same label: Tax. [Modules: purchase_request_price_tax_included and purchase_request_price_tax_included]
2026-04-08 09:31:00 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (tax_id, price_tax) of purchase.request.line.make.purchase.order.item() have the same label: Tax. [Modules: purchase_request_price_tax_included and purchase_request_price_tax_included]
2026-04-08 09:31:04 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:31:05 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_expenditure_amount, capital_budget_amount) of budget.appropriation.compilation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:05 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.compilation() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:05 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.master.summary() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:05 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_budget_amount, capital_expenditure_amount) of budget.appropriation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation]
2026-04-08 09:31:05 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:31:06 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_budget_amount, capital_expenditure_amount) of budget.appropriation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation]
2026-04-08 09:31:27 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:33 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_expenditure_amount, capital_budget_amount) of budget.appropriation.compilation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:33 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.compilation() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:33 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_expenditure_amount, capital_budget_amount) of budget.appropriation.compilation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:33 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.compilation() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:33 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.master.summary() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:31:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_budget_amount, capital_expenditure_amount) of budget.appropriation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation]
2026-04-08 09:31:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (capital_expenditure_amount, capital_budget_amount) of budget.appropriation.compilation() have the same label: งบลงทุน. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:35 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (create_uid, user_id) of budget.appropriation.compilation() have the same label: Created by. [Modules: budget_appropriation_summary and budget_appropriation_summary]
2026-04-08 09:31:36 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:37 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:37 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:38 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:38 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:42 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (account_id, code) of budget.appropriation.line() have the same label: รหัสงบประมาณ. [Modules: budget_appropriation and budget_appropriation]
2026-04-08 09:31:42 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:42 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:43 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:43 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:44 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (quantity_unsigned, quantity) of stock.valuation.layer() have the same label: Quantity. [Modules: stock_picking_kmitl and stock_account]
2026-04-08 09:31:44 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:44 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:45 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:45 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:46 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (tax_id, price_tax) of purchase.request.line() have the same label: Tax. [Modules: purchase_request_price_tax_included and purchase_request_price_tax_included]
2026-04-08 09:31:46 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (tax_id, price_tax) of purchase.request.line.make.purchase.order.item() have the same label: Tax. [Modules: purchase_request_price_tax_included and purchase_request_price_tax_included]
2026-04-08 09:31:47 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:47 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:48 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:48 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:49 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:50 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (tax_id, price_tax) of purchase.request.line() have the same label: Tax. [Modules: purchase_request_price_tax_included and purchase_request_price_tax_included]
2026-04-08 09:31:53 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:53 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:54 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:54 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:57 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:57 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:57 WARNING server py.warnings:328
/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 "/data/build/odoo/odoo-bin", line 8, in <module>
    odoo.cli.main()
  File "/data/build/odoo/odoo/cli/command.py", line 66, in main
    o.run(args)
  File "/data/build/odoo/odoo/cli/server.py", line 187, in run
    main(args)
  File "/data/build/odoo/odoo/cli/server.py", line 180, in main
    rc = odoo.service.server.start(preload=preload, stop=stop)
  File "/data/build/odoo/odoo/service/server.py", line 1427, in start
    rc = server.run(preload, stop)
  File "/data/build/odoo/odoo/service/server.py", line 596, in run
    rc = preload_registries(preload)
  File "/data/build/odoo/odoo/service/server.py", line 1327, in preload_registries
    registry = Registry.new(dbname, update_module=update_module)
  File "<decorator-gen-16>", line 2, in new
  File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
    return func(inst, *args, **kwargs)
  File "/data/build/odoo/odoo/modules/registry.py", line 87, in new
    odoo.modules.load_modules(registry, force_demo, status, update_module)
  File "/data/build/odoo/odoo/modules/loading.py", line 493, in load_modules
    processed_modules += load_marked_modules(cr, graph,
  File "/data/build/odoo/odoo/modules/loading.py", line 374, in load_marked_modules
    loaded, processed = load_module_graph(
  File "/data/build/odoo/odoo/modules/loading.py", line 210, in load_module_graph
    registry.init_models(cr, model_names, {'module': package.name}, new_install)
  File "/data/build/odoo/odoo/modules/registry.py", line 538, in init_models
    func()
  File "/data/build/odoo/odoo/addons/base/models/ir_model.py", line 47, in mark_modified
    records.modified(fnames)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 09:31:57 WARNING server py.warnings:328
/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 "/data/build/odoo/odoo-bin", line 8, in <module>
    odoo.cli.main()
  File "/data/build/odoo/odoo/cli/command.py", line 66, in main
    o.run(args)
  File "/data/build/odoo/odoo/cli/server.py", line 187, in run
    main(args)
  File "/data/build/odoo/odoo/cli/server.py", line 180, in main
    rc = odoo.service.server.start(preload=preload, stop=stop)
  File "/data/build/odoo/odoo/service/server.py", line 1427, in start
    rc = server.run(preload, stop)
  File "/data/build/odoo/odoo/service/server.py", line 596, in run
    rc = preload_registries(preload)
  File "/data/build/odoo/odoo/service/server.py", line 1327, in preload_registries
    registry = Registry.new(dbname, update_module=update_module)
  File "<decorator-gen-16>", line 2, in new
  File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
    return func(inst, *args, **kwargs)
  File "/data/build/odoo/odoo/modules/registry.py", line 87, in new
    odoo.modules.load_modules(registry, force_demo, status, update_module)
  File "/data/build/odoo/odoo/modules/loading.py", line 493, in load_modules
    processed_modules += load_marked_modules(cr, graph,
  File "/data/build/odoo/odoo/modules/loading.py", line 374, in load_marked_modules
    loaded, processed = load_module_graph(
  File "/data/build/odoo/odoo/modules/loading.py", line 210, in load_module_graph
    registry.init_models(cr, model_names, {'module': package.name}, new_install)
  File "/data/build/odoo/odoo/modules/registry.py", line 538, in init_models
    func()
  File "/data/build/odoo/odoo/addons/base/models/ir_model.py", line 47, in mark_modified
    records.modified(fnames)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 09:31:57 WARNING server py.warnings:328
/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 "/data/build/odoo/odoo-bin", line 8, in <module>
    odoo.cli.main()
  File "/data/build/odoo/odoo/cli/command.py", line 66, in main
    o.run(args)
  File "/data/build/odoo/odoo/cli/server.py", line 187, in run
    main(args)
  File "/data/build/odoo/odoo/cli/server.py", line 180, in main
    rc = odoo.service.server.start(preload=preload, stop=stop)
  File "/data/build/odoo/odoo/service/server.py", line 1427, in start
    rc = server.run(preload, stop)
  File "/data/build/odoo/odoo/service/server.py", line 596, in run
    rc = preload_registries(preload)
  File "/data/build/odoo/odoo/service/server.py", line 1327, in preload_registries
    registry = Registry.new(dbname, update_module=update_module)
  File "<decorator-gen-16>", line 2, in new
  File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
    return func(inst, *args, **kwargs)
  File "/data/build/odoo/odoo/modules/registry.py", line 87, in new
    odoo.modules.load_modules(registry, force_demo, status, update_module)
  File "/data/build/odoo/odoo/modules/loading.py", line 493, in load_modules
    processed_modules += load_marked_modules(cr, graph,
  File "/data/build/odoo/odoo/modules/loading.py", line 374, in load_marked_modules
    loaded, processed = load_module_graph(
  File "/data/build/odoo/odoo/modules/loading.py", line 210, in load_module_graph
    registry.init_models(cr, model_names, {'module': package.name}, new_install)
  File "/data/build/odoo/odoo/modules/registry.py", line 538, in init_models
    func()
  File "/data/build/odoo/odoo/addons/base/models/ir_model.py", line 47, in mark_modified
    records.modified(fnames)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 09:31:57 WARNING server py.warnings:328
/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 "/data/build/odoo/odoo-bin", line 8, in <module>
    odoo.cli.main()
  File "/data/build/odoo/odoo/cli/command.py", line 66, in main
    o.run(args)
  File "/data/build/odoo/odoo/cli/server.py", line 187, in run
    main(args)
  File "/data/build/odoo/odoo/cli/server.py", line 180, in main
    rc = odoo.service.server.start(preload=preload, stop=stop)
  File "/data/build/odoo/odoo/service/server.py", line 1427, in start
    rc = server.run(preload, stop)
  File "/data/build/odoo/odoo/service/server.py", line 596, in run
    rc = preload_registries(preload)
  File "/data/build/odoo/odoo/service/server.py", line 1327, in preload_registries
    registry = Registry.new(dbname, update_module=update_module)
  File "<decorator-gen-16>", line 2, in new
  File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
    return func(inst, *args, **kwargs)
  File "/data/build/odoo/odoo/modules/registry.py", line 87, in new
    odoo.modules.load_modules(registry, force_demo, status, update_module)
  File "/data/build/odoo/odoo/modules/loading.py", line 493, in load_modules
    processed_modules += load_marked_modules(cr, graph,
  File "/data/build/odoo/odoo/modules/loading.py", line 374, in load_marked_modules
    loaded, processed = load_module_graph(
  File "/data/build/odoo/odoo/modules/loading.py", line 210, in load_module_graph
    registry.init_models(cr, model_names, {'module': package.name}, new_install)
  File "/data/build/odoo/odoo/modules/registry.py", line 538, in init_models
    func()
  File "/data/build/odoo/odoo/addons/base/models/ir_model.py", line 47, in mark_modified
    records.modified(fnames)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 09:31:57 WARNING server py.warnings:328
/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 "/data/build/odoo/odoo-bin", line 8, in <module>
    odoo.cli.main()
  File "/data/build/odoo/odoo/cli/command.py", line 66, in main
    o.run(args)
  File "/data/build/odoo/odoo/cli/server.py", line 187, in run
    main(args)
  File "/data/build/odoo/odoo/cli/server.py", line 180, in main
    rc = odoo.service.server.start(preload=preload, stop=stop)
  File "/data/build/odoo/odoo/service/server.py", line 1427, in start
    rc = server.run(preload, stop)
  File "/data/build/odoo/odoo/service/server.py", line 596, in run
    rc = preload_registries(preload)
  File "/data/build/odoo/odoo/service/server.py", line 1327, in preload_registries
    registry = Registry.new(dbname, update_module=update_module)
  File "<decorator-gen-16>", line 2, in new
  File "/data/build/odoo/odoo/tools/func.py", line 87, in locked
    return func(inst, *args, **kwargs)
  File "/data/build/odoo/odoo/modules/registry.py", line 87, in new
    odoo.modules.load_modules(registry, force_demo, status, update_module)
  File "/data/build/odoo/odoo/modules/loading.py", line 493, in load_modules
    processed_modules += load_marked_modules(cr, graph,
  File "/data/build/odoo/odoo/modules/loading.py", line 374, in load_marked_modules
    loaded, processed = load_module_graph(
  File "/data/build/odoo/odoo/modules/loading.py", line 210, in load_module_graph
    registry.init_models(cr, model_names, {'module': package.name}, new_install)
  File "/data/build/odoo/odoo/modules/registry.py", line 538, in init_models
    func()
  File "/data/build/odoo/odoo/addons/base/models/ir_model.py", line 47, in mark_modified
    records.modified(fnames)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 09:31:58 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (work_end_display, work_end) of purchase.order() have the same label: Work End. [Modules: purchase_contract_kmitl and purchase_contract_kmitl]
2026-04-08 09:31:58 WARNING server odoo.addons.base.models.ir_model:1077 Two fields (days_to_expire_display, days_to_expire) of purchase.order() have the same label: Days to Expire. [Modules: purchase_order_expiration and purchase_order_expiration]
2026-04-08 09:31:58 Log limit reached (full logs are still available in the log file)
2026-04-08 09:32:48 Step install_without_demo finished in 7m
2026-04-08 09:32:48 Starting step run_without_demo from config Without demo
2026-04-08 09:32:48 INFO runbot Start running build 10282-16-0
2026-04-08 09:32:48 INFO runbot Using Dockerfile Tag odoo:DockerDefaultAke
2026-04-08 09:34:35 INFO server odoo.modules.loading:336 1 modules loaded in 0.01s, 0 queries (+0 extra)
2026-04-08 09:34:35 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_construction', defaulting to LGPL-3
2026-04-08 09:34:35 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_approval', defaulting to LGPL-3
2026-04-08 09:34:39 INFO server odoo.modules.loading:336 321 modules loaded in 3.21s, 0 queries (+0 extra)
2026-04-08 09:35:48 WARNING server py.warnings:328
/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 <module>
  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 09:35:48 WARNING server py.warnings:328
/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 <module>
  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 09:35:48 WARNING server py.warnings:328
/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 <module>
  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 09:35:48 WARNING server py.warnings:328
/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 <module>
  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 09:35:48 WARNING server py.warnings:328
/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 <module>
  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 09:35:48 ERROR server odoo.sql_db:324
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 09:35:48.284520', 1, 'open', true, '2026-04-08 09:35:48', 2, '2026-04-08 09:35:48.284520', 1), (2, '2026-04-08 09:35:48.284520', 1, 'open', true, '2026-04-08 09:35:48', 2, '2026-04-08 09:35:48.284520', 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 09:35:48 ERROR server odoo.addons.base.models.ir_cron:400
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 <module>
  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 "<decorator-gen-159>", 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 "<decorator-gen-142>", 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 "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 "<decorator-gen-157>", 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 "<decorator-gen-68>", 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 "<decorator-gen-15>", 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: <class 'psycopg2.errors.UniqueViolation'>: "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 10:57:57 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_approval', defaulting to LGPL-3
2026-04-08 10:57:57 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_construction', defaulting to LGPL-3
2026-04-08 10:57:59 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_approval', defaulting to LGPL-3
2026-04-08 10:58:00 WARNING server odoo.modules.module:411 Missing `license` key in manifest for 'agx_construction', defaulting to LGPL-3
2026-04-08 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:01 WARNING server py.warnings:328
/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 1168, in process_work
    self.process_request(client, addr)
  File "/data/build/odoo/odoo/service/server.py", line 1159, in process_request
    self.server.process_request(client, addr)
  File "/usr/lib/python3.12/socketserver.py", line 349, in process_request
    self.finish_request(request, client_address)
  File "/usr/lib/python3.12/socketserver.py", line 362, in finish_request
    self.RequestHandlerClass(request, client_address, self)
  File "/usr/lib/python3.12/socketserver.py", line 761, in __init__
    self.handle()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 342, in handle
    BaseHTTPRequestHandler.handle(self)
  File "/usr/lib/python3.12/http/server.py", line 436, in handle
    self.handle_one_request()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 374, in handle_one_request
    self.run_wsgi()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 319, in run_wsgi
    execute(self.server.app)
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/serving.py", line 308, in execute
    application_iter = app(environ, start_response)
  File "/data/build/odoo/odoo/http.py", line 2237, in __call__
    response = request._serve_db()
  File "/data/build/odoo/odoo/http.py", line 1824, in _serve_db
    return service_model.retrying(self._serve_ir_http, self.env)
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/odoo/http.py", line 1852, in _serve_ir_http
    response = self.dispatcher.dispatch(rule.endpoint, args)
  File "/data/build/odoo/odoo/http.py", line 1966, in dispatch
    return self.request.registry['ir.http']._dispatch(endpoint)
  File "/data/build/odoo/addons/website/models/ir_http.py", line 237, in _dispatch
    response = super()._dispatch(endpoint)
  File "/data/build/odoo/odoo/addons/base/models/ir_http.py", line 156, in _dispatch
    result.flatten()
  File "/data/build/odoo/odoo/tools/facade.py", line 83, in wrap_func
    func(self._wrapped__, *args, **kwargs)
  File "/data/build/odoo/odoo/http.py", line 1213, in flatten
    self.response.append(self.render())
  File "/data/build/odoo/odoo/http.py", line 1205, in render
    return request.env["ir.ui.view"]._render_template(self.template, self.qcontext)
  File "/data/build/odoo/addons/website/models/ir_ui_view.py", line 419, in _render_template
    return super()._render_template(template, values=values)
  File "/data/build/odoo/odoo/addons/base/models/ir_ui_view.py", line 2135, in _render_template
    return self.env['ir.qweb']._render(template, values)
  File "/data/build/odoo/odoo/tools/profiler.py", line 301, in _tracked_method_render
    return method_render(self, template, values, **options)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 593, in _render
    result = ''.join(rendering)
  File "<1379>", line 39, in template_1379
  File "<1379>", line 28, in template_1379_content
  File "<1381>", line 1402, in template_1381
  File "<1381>", line 1015, in template_1381_content
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2470, in _load_values
    value = self._get_cached_values(cache_key, get_value)
  File "<decorator-gen-70>", line 2, in _get_cached_values
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2483, in _get_cached_values
    return get_value()
  File "<1381>", line 1005, in template_1381_t_cache_0_cache
  File "<1381>", line 426, in template_1381_t_cache_0
  File "/data/build/odoo/addons/website/models/ir_qweb.py", line 122, in _get_asset_nodes
    return super(IrQWeb, self_website)._get_asset_nodes(bundle, css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load, media=media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2438, in _get_asset_nodes
    return self._generate_asset_nodes_cache(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "<decorator-gen-71>", line 2, in _generate_asset_nodes_cache
  File "/data/build/odoo/odoo/tools/cache.py", line 90, in lookup
    value = d[key] = self.method(*args, **kwargs)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2493, in _generate_asset_nodes_cache
    return self._generate_asset_nodes(bundle, css, js, debug, async_load, defer_load, lazy_load, media)
  File "/data/build/odoo/odoo/addons/base/models/ir_qweb.py", line 2567, in _generate_asset_nodes
    return remains + asset.to_node(css=css, js=js, debug=debug, async_load=async_load, defer_load=defer_load, lazy_load=lazy_load)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 159, in to_node
    css_attachments = self.css(is_minified=not is_debug_assets) or []
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 627, in css
    self.save_attachment(extension, css)
  File "/data/build/odoo/odoo/addons/base/models/assetsbundle.py", line 373, in save_attachment
    attachment = ira.with_user(SUPERUSER_ID).create(values)
  File "<decorator-gen-244>", 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/website/models/ir_attachment.py", line 23, in create
    return super().create(vals_list)
  File "<decorator-gen-60>", 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_attachment.py", line 673, in create
    return super().create(vals_list)
  File "<decorator-gen-68>", 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 "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:45 WARNING server py.warnings:328
/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/dist-packages/gevent/baseserver.py", line 34, in _handle_and_close_when_done
    return handle(*args_tuple)
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1700, in handle
    handler.handle()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 574, in handle
    result = self.handle_one_request()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 804, in handle_one_request
    self.handle_one_response()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1107, in handle_one_response
    self.run_application()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1059, in run_application
    close()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wsgi.py", line 466, in close
    callback()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wrappers/response.py", line 439, in close
    func()
  File "/data/build/odoo/addons/bus/websocket.py", line 821, in <lambda>
    response.call_on_close(lambda: cls._serve_forever(
  File "/data/build/odoo/addons/bus/websocket.py", line 918, in _serve_forever
    req.serve_websocket_message(message)
  File "/data/build/odoo/addons/bus/websocket.py", line 758, in serve_websocket_message
    service_model.retrying(
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/addons/bus/websocket.py", line 775, in _serve_ir_websocket
    ir_websocket._update_bus_presence(**data)
  File "/data/build/odoo/addons/mail/models/ir_websocket.py", line 39, in _update_bus_presence
    super()._update_bus_presence(inactivity_period, im_status_ids_by_model)
  File "/data/build/odoo/addons/bus/models/ir_websocket.py", line 43, in _update_bus_presence
    self.env['bus.presence'].update(
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 47, in update
    self._update(inactivity_period=inactivity_period, identity_field=identity_field, identity_value=identity_value)
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 68, in _update
    self.create(values)
  File "<decorator-gen-68>", 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/odoo/addons/base/models/ir_fields.py", line 670, in create
    recs = super().create(vals_list)
  File "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:45 WARNING server py.warnings:328
/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/dist-packages/gevent/baseserver.py", line 34, in _handle_and_close_when_done
    return handle(*args_tuple)
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1700, in handle
    handler.handle()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 574, in handle
    result = self.handle_one_request()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 804, in handle_one_request
    self.handle_one_response()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1107, in handle_one_response
    self.run_application()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1059, in run_application
    close()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wsgi.py", line 466, in close
    callback()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wrappers/response.py", line 439, in close
    func()
  File "/data/build/odoo/addons/bus/websocket.py", line 821, in <lambda>
    response.call_on_close(lambda: cls._serve_forever(
  File "/data/build/odoo/addons/bus/websocket.py", line 918, in _serve_forever
    req.serve_websocket_message(message)
  File "/data/build/odoo/addons/bus/websocket.py", line 758, in serve_websocket_message
    service_model.retrying(
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/addons/bus/websocket.py", line 775, in _serve_ir_websocket
    ir_websocket._update_bus_presence(**data)
  File "/data/build/odoo/addons/mail/models/ir_websocket.py", line 39, in _update_bus_presence
    super()._update_bus_presence(inactivity_period, im_status_ids_by_model)
  File "/data/build/odoo/addons/bus/models/ir_websocket.py", line 43, in _update_bus_presence
    self.env['bus.presence'].update(
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 47, in update
    self._update(inactivity_period=inactivity_period, identity_field=identity_field, identity_value=identity_value)
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 68, in _update
    self.create(values)
  File "<decorator-gen-68>", 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/odoo/addons/base/models/ir_fields.py", line 670, in create
    recs = super().create(vals_list)
  File "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:45 WARNING server py.warnings:328
/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/dist-packages/gevent/baseserver.py", line 34, in _handle_and_close_when_done
    return handle(*args_tuple)
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1700, in handle
    handler.handle()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 574, in handle
    result = self.handle_one_request()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 804, in handle_one_request
    self.handle_one_response()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1107, in handle_one_response
    self.run_application()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1059, in run_application
    close()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wsgi.py", line 466, in close
    callback()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wrappers/response.py", line 439, in close
    func()
  File "/data/build/odoo/addons/bus/websocket.py", line 821, in <lambda>
    response.call_on_close(lambda: cls._serve_forever(
  File "/data/build/odoo/addons/bus/websocket.py", line 918, in _serve_forever
    req.serve_websocket_message(message)
  File "/data/build/odoo/addons/bus/websocket.py", line 758, in serve_websocket_message
    service_model.retrying(
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/addons/bus/websocket.py", line 775, in _serve_ir_websocket
    ir_websocket._update_bus_presence(**data)
  File "/data/build/odoo/addons/mail/models/ir_websocket.py", line 39, in _update_bus_presence
    super()._update_bus_presence(inactivity_period, im_status_ids_by_model)
  File "/data/build/odoo/addons/bus/models/ir_websocket.py", line 43, in _update_bus_presence
    self.env['bus.presence'].update(
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 47, in update
    self._update(inactivity_period=inactivity_period, identity_field=identity_field, identity_value=identity_value)
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 68, in _update
    self.create(values)
  File "<decorator-gen-68>", 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/odoo/addons/base/models/ir_fields.py", line 670, in create
    recs = super().create(vals_list)
  File "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:45 WARNING server py.warnings:328
/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/dist-packages/gevent/baseserver.py", line 34, in _handle_and_close_when_done
    return handle(*args_tuple)
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1700, in handle
    handler.handle()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 574, in handle
    result = self.handle_one_request()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 804, in handle_one_request
    self.handle_one_response()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1107, in handle_one_response
    self.run_application()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1059, in run_application
    close()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wsgi.py", line 466, in close
    callback()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wrappers/response.py", line 439, in close
    func()
  File "/data/build/odoo/addons/bus/websocket.py", line 821, in <lambda>
    response.call_on_close(lambda: cls._serve_forever(
  File "/data/build/odoo/addons/bus/websocket.py", line 918, in _serve_forever
    req.serve_websocket_message(message)
  File "/data/build/odoo/addons/bus/websocket.py", line 758, in serve_websocket_message
    service_model.retrying(
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/addons/bus/websocket.py", line 775, in _serve_ir_websocket
    ir_websocket._update_bus_presence(**data)
  File "/data/build/odoo/addons/mail/models/ir_websocket.py", line 39, in _update_bus_presence
    super()._update_bus_presence(inactivity_period, im_status_ids_by_model)
  File "/data/build/odoo/addons/bus/models/ir_websocket.py", line 43, in _update_bus_presence
    self.env['bus.presence'].update(
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 47, in update
    self._update(inactivity_period=inactivity_period, identity_field=identity_field, identity_value=identity_value)
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 68, in _update
    self.create(values)
  File "<decorator-gen-68>", 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/odoo/addons/base/models/ir_fields.py", line 670, in create
    recs = super().create(vals_list)
  File "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 10:58:45 WARNING server py.warnings:328
/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/dist-packages/gevent/baseserver.py", line 34, in _handle_and_close_when_done
    return handle(*args_tuple)
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1700, in handle
    handler.handle()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 574, in handle
    result = self.handle_one_request()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 804, in handle_one_request
    self.handle_one_response()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1107, in handle_one_response
    self.run_application()
  File "/usr/lib/python3/dist-packages/gevent/pywsgi.py", line 1059, in run_application
    close()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wsgi.py", line 466, in close
    callback()
  File "/home/runbot/.local/lib/python3.12/site-packages/werkzeug/wrappers/response.py", line 439, in close
    func()
  File "/data/build/odoo/addons/bus/websocket.py", line 821, in <lambda>
    response.call_on_close(lambda: cls._serve_forever(
  File "/data/build/odoo/addons/bus/websocket.py", line 918, in _serve_forever
    req.serve_websocket_message(message)
  File "/data/build/odoo/addons/bus/websocket.py", line 758, in serve_websocket_message
    service_model.retrying(
  File "/data/build/odoo/odoo/service/model.py", line 152, in retrying
    result = func()
  File "/data/build/odoo/addons/bus/websocket.py", line 775, in _serve_ir_websocket
    ir_websocket._update_bus_presence(**data)
  File "/data/build/odoo/addons/mail/models/ir_websocket.py", line 39, in _update_bus_presence
    super()._update_bus_presence(inactivity_period, im_status_ids_by_model)
  File "/data/build/odoo/addons/bus/models/ir_websocket.py", line 43, in _update_bus_presence
    self.env['bus.presence'].update(
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 47, in update
    self._update(inactivity_period=inactivity_period, identity_field=identity_field, identity_value=identity_value)
  File "/data/build/odoo/addons/bus/models/bus_presence.py", line 68, in _update
    self.create(values)
  File "<decorator-gen-68>", 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/odoo/addons/base/models/ir_fields.py", line 670, in create
    recs = super().create(vals_list)
  File "<decorator-gen-15>", 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 4250, in _create
    records.modified(self._fields, create=True)
  File "/data/build/odoo/odoo/models.py", line 6165, in modified
    todo = [self._modified([self._fields[fname] for fname in fnames], create)]
  File "/data/build/odoo/odoo/models.py", line 6216, in _modified
    tree = self.pool.get_trigger_tree(fields, select=select)
  File "/data/build/odoo/odoo/modules/registry.py", line 345, in get_trigger_tree
    if field in self._field_triggers
  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 15:05:26 INFO runbot Kill build 10282-16-0