se adiciona FachoXml.get_element_text_or_attribute
FossilOrigin-Name: 2179f4376613dda1e554a4f1304990f32185c1ec9bec6181d8a00e31a5ee5390
This commit is contained in:
parent
35e1c5b609
commit
8d17c282e3
@ -368,6 +368,16 @@ class FachoXML:
|
||||
text = self.builder.get_text(elem)
|
||||
return format_(text)
|
||||
|
||||
def get_element_text_or_attribute(self, xpath):
|
||||
parts = xpath.split('/')
|
||||
is_attribute = parts[-1].startswith('@')
|
||||
if is_attribute:
|
||||
attribute_name = parts.pop(-1).lstrip('@')
|
||||
element_path = "/".join(parts)
|
||||
return self.get_element_attribute(element_path, attribute_name)
|
||||
else:
|
||||
return self.get_element_text(xpath)
|
||||
|
||||
def exist_element(self, xpath):
|
||||
elem = self.get_element(xpath)
|
||||
|
||||
|
@ -66,22 +66,6 @@ class InformacionGeneral:
|
||||
)
|
||||
|
||||
def post_apply(self, fexml, fragment):
|
||||
devengados = map(lambda valor: Amount(valor),
|
||||
[
|
||||
fexml.get_element_attribute('/fe:NominaIndividual/Devengados/Basico', 'SueldoTrabajado')
|
||||
]
|
||||
)
|
||||
devengados_total = Amount(0.0)
|
||||
for devengado in devengados:
|
||||
devengados_total += devengado
|
||||
fexml.set_element('/fe:NominaIndividual/DevengadosTotal', round(devengados_total,2))
|
||||
|
||||
# TODO
|
||||
fexml.set_element('/fe:NominaIndividual/DeduccionesTotal', '1000000.00')
|
||||
|
||||
# TODO
|
||||
fexml.set_element('/fe:NominaIndividual/ComprobanteTotal', '2500000.00')
|
||||
|
||||
# generar cune
|
||||
campos = [
|
||||
fexml.get_element_attribute('/fe:NominaIndividual/NumeroSecuenciaXML', 'Numero'),
|
||||
@ -221,6 +205,32 @@ class DIANNominaIndividual:
|
||||
|
||||
def toFachoXML(self):
|
||||
if self.informacion_general is not None:
|
||||
#TODO(bit4bit) acoplamiento temporal
|
||||
# es importante el orden de ejecucion
|
||||
self._devengados_total()
|
||||
self._deducciones_total()
|
||||
self._comprobante_total()
|
||||
|
||||
self.informacion_general.post_apply(self.fexml, self.informacion_general_xml)
|
||||
|
||||
return self.fexml
|
||||
|
||||
def _comprobante_total(self):
|
||||
# TODO
|
||||
self.fexml.set_element('/fe:NominaIndividual/ComprobanteTotal', '2500000.00')
|
||||
|
||||
def _deducciones_total(self):
|
||||
# TODO
|
||||
self.fexml.set_element('/fe:NominaIndividual/DeduccionesTotal', '1000000.00')
|
||||
|
||||
def _devengados_total(self):
|
||||
devengados = map(lambda valor: Amount(valor),
|
||||
[
|
||||
self.fexml.get_element_attribute('/fe:NominaIndividual/Devengados/Basico', 'SueldoTrabajado')
|
||||
]
|
||||
)
|
||||
devengados_total = Amount(0.0)
|
||||
for devengado in devengados:
|
||||
devengados_total += devengado
|
||||
self.fexml.set_element('/fe:NominaIndividual/DevengadosTotal', round(devengados_total,2))
|
||||
|
||||
|
@ -362,3 +362,11 @@ def test_facho_xml_exist_element():
|
||||
xml.find_or_create_element('./A')
|
||||
assert xml.exist_element('/root/A') == True
|
||||
assert xml.tostring() == '<root><A/></root>'
|
||||
|
||||
def test_facho_xml_query_element_text_or_attribute():
|
||||
xml = facho.FachoXML('root')
|
||||
|
||||
xml.set_element('./A', 'contenido', clave='valor')
|
||||
|
||||
assert xml.get_element_text_or_attribute('/root/A') == 'contenido'
|
||||
assert xml.get_element_text_or_attribute('/root/A/@clave') == 'valor'
|
||||
|
@ -70,6 +70,7 @@ def test_nomina_obligatorios_segun_anexo_tecnico():
|
||||
assert_error(errors, 'se requiere DeduccionSalud')
|
||||
assert_error(errors, 'se requiere DeduccionFondoPension')
|
||||
|
||||
@pytest.mark.skip(reason="es valido el cune en el anexo tecnico?")
|
||||
def test_nomina_cune():
|
||||
nomina = fe.nomina.DIANNominaIndividual()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user