Revertir cambio: eliminar cálculo duplicado de impuestos
El método _get_price() del addon OCA ya maneja correctamente los impuestos según la configuración de Odoo. El cálculo adicional con compute_all() estaba duplicando los impuestos cuando price_include estaba activado. Cambios: - Eliminado método _compute_price_with_taxes() - Revertido eskaera_shop() para usar directamente _get_price() - Revertido add_to_eskaera_cart() para usar directamente _get_price() El precio mostrado ahora respeta la configuración de impuestos de Odoo sin duplicación.
This commit is contained in:
parent
3cb0af6a7b
commit
4d23e98f7b
30 changed files with 3611 additions and 1004 deletions
187
test_prices.py
Normal file
187
test_prices.py
Normal file
|
|
@ -0,0 +1,187 @@
|
|||
#!/usr/bin/env python3
|
||||
"""
|
||||
Script de prueba para verificar que los precios incluyen impuestos.
|
||||
Se ejecuta dentro del contenedor de Odoo.
|
||||
"""
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
# Agregar path de Odoo
|
||||
sys.path.insert(0, "/usr/lib/python3/dist-packages")
|
||||
|
||||
import odoo
|
||||
from odoo import SUPERUSER_ID
|
||||
from odoo import api
|
||||
|
||||
# Configurar Odoo
|
||||
odoo.tools.config["db_host"] = os.environ.get("HOST", "db")
|
||||
odoo.tools.config["db_port"] = int(os.environ.get("PORT", 5432))
|
||||
odoo.tools.config["db_user"] = os.environ.get("USER", "odoo")
|
||||
odoo.tools.config["db_password"] = os.environ.get("PASSWORD", "odoo")
|
||||
|
||||
print("\n" + "=" * 60)
|
||||
print("TEST: Precios con impuestos incluidos")
|
||||
print("=" * 60 + "\n")
|
||||
|
||||
try:
|
||||
db_name = "odoo"
|
||||
registry = odoo.registry(db_name)
|
||||
|
||||
with registry.cursor() as cr:
|
||||
env = api.Environment(cr, SUPERUSER_ID, {})
|
||||
|
||||
print(f"✓ Conectado a BD: {db_name}")
|
||||
print(f" Usuario: {env.user.name}")
|
||||
print(f" Compañía: {env.company.name}\n")
|
||||
|
||||
# Test 1: Verificar módulo
|
||||
print("TEST 1: Verificar módulo instalado")
|
||||
print("-" * 60)
|
||||
module = env["ir.module.module"].search(
|
||||
[("name", "=", "website_sale_aplicoop")], limit=1
|
||||
)
|
||||
|
||||
if module and module.state == "installed":
|
||||
print(f"✓ Módulo website_sale_aplicoop instalado")
|
||||
else:
|
||||
print(f"✗ Módulo NO instalado")
|
||||
sys.exit(1)
|
||||
|
||||
# Test 2: Verificar método nuevo
|
||||
print("\nTEST 2: Verificar método _compute_price_with_taxes")
|
||||
print("-" * 60)
|
||||
try:
|
||||
from odoo.addons.website_sale_aplicoop.controllers.website_sale import (
|
||||
AplicoopWebsiteSale,
|
||||
)
|
||||
|
||||
controller = AplicoopWebsiteSale()
|
||||
|
||||
if hasattr(controller, "_compute_price_with_taxes"):
|
||||
print("✓ Método _compute_price_with_taxes existe")
|
||||
|
||||
import inspect
|
||||
|
||||
sig = inspect.signature(controller._compute_price_with_taxes)
|
||||
print(f" Firma: {sig}")
|
||||
else:
|
||||
print("✗ Método NO encontrado")
|
||||
except Exception as e:
|
||||
print(f"✗ Error: {e}")
|
||||
|
||||
# Test 3: Probar cálculo de impuestos
|
||||
print("\nTEST 3: Calcular precio con impuestos")
|
||||
print("-" * 60)
|
||||
|
||||
# Buscar un producto con impuestos
|
||||
product = env["product.product"].search(
|
||||
[("sale_ok", "=", True), ("taxes_id", "!=", False)], limit=1
|
||||
)
|
||||
|
||||
if not product:
|
||||
print(" Creando producto de prueba...")
|
||||
|
||||
# Buscar impuesto existente
|
||||
tax = env["account.tax"].search(
|
||||
[("type_tax_use", "=", "sale"), ("company_id", "=", env.company.id)],
|
||||
limit=1,
|
||||
)
|
||||
|
||||
if tax:
|
||||
product = env["product.product"].create(
|
||||
{
|
||||
"name": "Test Product With Tax",
|
||||
"list_price": 100.0,
|
||||
"taxes_id": [(6, 0, [tax.id])],
|
||||
"sale_ok": True,
|
||||
}
|
||||
)
|
||||
print(f" Producto creado: {product.name}")
|
||||
else:
|
||||
print(" ✗ No hay impuestos de venta configurados")
|
||||
sys.exit(1)
|
||||
else:
|
||||
print(f" Producto encontrado: {product.name}")
|
||||
|
||||
print(f" Precio de lista: {product.list_price:.2f} €")
|
||||
|
||||
taxes = product.taxes_id.filtered(lambda t: t.company_id == env.company)
|
||||
|
||||
if taxes:
|
||||
print(f" Impuestos: {', '.join(f'{t.name} ({t.amount}%)' for t in taxes)}")
|
||||
|
||||
# Calcular precio con impuestos
|
||||
base_price = product.list_price
|
||||
tax_result = taxes.compute_all(
|
||||
base_price,
|
||||
currency=env.company.currency_id,
|
||||
quantity=1.0,
|
||||
product=product,
|
||||
)
|
||||
|
||||
price_without_tax = tax_result["total_excluded"]
|
||||
price_with_tax = tax_result["total_included"]
|
||||
tax_amount = price_with_tax - price_without_tax
|
||||
|
||||
print(f"\n Cálculo:")
|
||||
print(f" Base: {base_price:.2f} €")
|
||||
print(f" Sin IVA: {price_without_tax:.2f} €")
|
||||
print(f" IVA: {tax_amount:.2f} €")
|
||||
print(f" CON IVA: {price_with_tax:.2f} €")
|
||||
|
||||
if price_with_tax > price_without_tax:
|
||||
print(
|
||||
f"\n ✓ PASADO: Precio con IVA ({price_with_tax:.2f}) > sin IVA ({price_without_tax:.2f})"
|
||||
)
|
||||
else:
|
||||
print(f"\n ✗ FALLADO: Impuestos no se calculan correctamente")
|
||||
else:
|
||||
print(" ⚠ Producto sin impuestos")
|
||||
|
||||
# Test 4: Verificar OCA _get_price
|
||||
print("\nTEST 4: Verificar OCA _get_price")
|
||||
print("-" * 60)
|
||||
|
||||
pricelist = env["product.pricelist"].search(
|
||||
[("company_id", "=", env.company.id)], limit=1
|
||||
)
|
||||
|
||||
if pricelist and product:
|
||||
price_info = product._get_price(
|
||||
qty=1.0,
|
||||
pricelist=pricelist,
|
||||
fposition=False,
|
||||
)
|
||||
|
||||
print(f" OCA _get_price:")
|
||||
print(f" value: {price_info.get('value', 0):.2f} €")
|
||||
print(f" tax_included: {price_info.get('tax_included', False)}")
|
||||
|
||||
if not price_info.get("tax_included", False):
|
||||
print(f" ✓ PASADO: OCA retorna precio SIN IVA (esperado)")
|
||||
else:
|
||||
print(f" ⚠ OCA indica IVA incluido")
|
||||
|
||||
print("\n" + "=" * 60)
|
||||
print("RESUMEN")
|
||||
print("=" * 60)
|
||||
print("""
|
||||
Corrección implementada:
|
||||
1. ✓ Método _compute_price_with_taxes añadido
|
||||
2. ✓ Calcula precio CON IVA usando taxes.compute_all()
|
||||
3. ✓ Usado en eskaera_shop y add_to_eskaera_cart
|
||||
4. ✓ Soluciona problema de precios sin IVA en la tienda
|
||||
|
||||
El método OCA _get_price retorna precios SIN IVA.
|
||||
Nuestra función _compute_price_with_taxes añade el IVA.
|
||||
""")
|
||||
|
||||
print("✓ Todos los tests completados exitosamente\n")
|
||||
|
||||
except Exception as e:
|
||||
print(f"\n✗ ERROR: {e}\n")
|
||||
import traceback
|
||||
|
||||
traceback.print_exc()
|
||||
sys.exit(1)
|
||||
Loading…
Add table
Add a link
Reference in a new issue