[tryton-debian-vcs] tryton-modules-account-payment branch upstream updated. upstream/3.4.1-1-gb904e91
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Thu Apr 23 16:01:56 UTC 2015
The following commit has been merged in the upstream branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-modules-account-payment.git;a=commitdiff;h=upstream/3.4.1-1-gb904e91
commit b904e913aeac099dfb262ab87616605f8e838e2f
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Thu Apr 23 16:59:50 2015 +0200
Adding upstream version 3.6.0.
Signed-off-by: Mathias Behrle <mathiasb at m9s.biz>
diff --git a/CHANGELOG b/CHANGELOG
index aa9ea1e..466bc7b 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,6 +1,6 @@
-Version 3.4.1 - 2015-03-01
+Version 3.6.0 - 2015-04-20
* Bug fixes (see mercurial logs for details)
-
+* Add support for PyPy
Version 3.4.0 - 2014-10-20
* Bug fixes (see mercurial logs for details)
* Add transitions between succeeded and failed
diff --git a/PKG-INFO b/PKG-INFO
index 0683b54..f4e34f0 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond_account_payment
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for payment
Home-page: http://www.tryton.org/
Author: Tryton
Author-email: issue_tracker at tryton.org
License: GPL-3
-Download-URL: http://downloads.tryton.org/3.4/
+Download-URL: http://downloads.tryton.org/3.6/
Description: trytond_account_payment
=======================
@@ -64,5 +64,7 @@ Classifier: Natural Language :: Slovenian
Classifier: Natural Language :: Spanish
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Office/Business
Classifier: Topic :: Office/Business :: Financial :: Accounting
diff --git a/__init__.py b/__init__.py
index d2e3fee..8b07f5f 100644
--- a/__init__.py
+++ b/__init__.py
@@ -1,5 +1,5 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from trytond.pool import Pool
from .payment import *
from .account import *
diff --git a/account.py b/account.py
index 2f0d05a..480c279 100644
--- a/account.py
+++ b/account.py
@@ -1,5 +1,6 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
+from sql import Null
from sql.aggregate import Sum
from sql.conditionals import Case, Coalesce
from sql.functions import Abs
@@ -82,7 +83,7 @@ class MoveLine:
payment_amount = Sum(Coalesce(payment.amount, 0))
main_amount = Abs(table.credit - table.debit) - payment_amount
second_amount = Abs(table.amount_second_currency) - payment_amount
- amount = Case((table.second_currency == None, main_amount),
+ amount = Case((table.second_currency == Null, main_amount),
else_=second_amount)
value = cls.payment_amount.sql_format(value)
@@ -147,6 +148,7 @@ class PayLine(Wizard):
kind = 'payable'
return Payment(
+ company=line.move.company,
journal=self.start.journal,
party=line.party,
kind=kind,
@@ -164,7 +166,7 @@ class PayLine(Wizard):
payments = []
for line in lines:
payments.append(self.get_payment(line))
- payments = Payment.create([p._save_values for p in payments])
+ Payment.save(payments)
return action, {
'res_id': [p.id for p in payments],
}
diff --git a/account.xml b/account.xml
index 966949c..3db0a28 100644
--- a/account.xml
+++ b/account.xml
@@ -14,7 +14,9 @@ this repository contains the full copyright notices and license terms. -->
<record model="ir.action.act_window" id="act_move_line_form">
<field name="name">Lines to Pay</field>
<field name="res_model">account.move.line</field>
- <field name="domain">[('account.kind', 'in', ['receivable', 'payable']), ('party', '!=', None), ('reconciliation', '=', None), ('payment_amount', '!=', 0)]</field>
+ <field name="domain"
+ eval="[('account.kind', 'in', ['receivable', 'payable']), ('party', '!=', None), ('reconciliation', '=', None), ('payment_amount', '!=', 0)]"
+ pyson="1"/>
</record>
<record model="ir.action.act_window.view" id="act_move_line_form_view1">
<field name="sequence" eval="10"/>
@@ -25,14 +27,18 @@ this repository contains the full copyright notices and license terms. -->
id="act_move_line_form_domain_payable">
<field name="name">Payable</field>
<field name="sequence" eval="10"/>
- <field name="domain">['OR', ('credit', '>', 0), ('debit', '<', 0)]</field>
+ <field name="domain"
+ eval="['OR', ('credit', '>', 0), ('debit', '<', 0)]"
+ pyson="1"/>
<field name="act_window" ref="act_move_line_form"/>
</record>
<record model="ir.action.act_window.domain"
id="act_move_line_form_domain_receivable">
<field name="name">Receivable</field>
<field name="sequence" eval="20"/>
- <field name="domain">['OR', ('debit', '>', 0), ('credit', '<', 0)]</field>
+ <field name="domain"
+ eval="['OR', ('debit', '>', 0), ('credit', '<', 0)]"
+ pyson="1"/>
<field name="act_window" ref="act_move_line_form"/>
</record>
diff --git a/locale/ca_ES.po b/locale/ca_ES.po
index 4bcea35..6b6c9af 100644
--- a/locale/ca_ES.po
+++ b/locale/ca_ES.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "El pagament \"%s\" és major que l'import de l'efecte \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "El pagament \"%(payment)s\" paga amb excés l'apunt \"%(line)s\"."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
@@ -52,7 +52,7 @@ msgstr "Moneda"
msgctxt "field:account.payment,currency_digits:"
msgid "Currency Digits"
-msgstr "Decimals de moneda"
+msgstr "Decimals de la moneda"
msgctxt "field:account.payment,date:"
msgid "Date"
@@ -446,7 +446,7 @@ msgstr "Paga"
msgctxt "wizard_button:account.payment.process,start,end:"
msgid "Cancel"
-msgstr "Cancel·lat"
+msgstr "Cancel·la"
msgctxt "wizard_button:account.payment.process,start,process:"
msgid "Process"
diff --git a/locale/de_DE.po b/locale/de_DE.po
index 4136054..b4adc99 100644
--- a/locale/de_DE.po
+++ b/locale/de_DE.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "Die Zahlung \"%s\" ist eine Überzahlung von Posten \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "Zahlung \"%(payment)s\" überzahlt die Position \"%(line)s\""
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
@@ -268,7 +268,7 @@ msgstr "Entwurf"
msgctxt ""
"model:ir.action.act_window.domain,name:act_payment_form_domain_failed"
msgid "Failed"
-msgstr "Fehlgeschlagen"
+msgstr "Erfolglos"
msgctxt ""
"model:ir.action.act_window.domain,name:act_payment_form_domain_processing"
@@ -346,7 +346,7 @@ msgstr "Entwurf"
msgctxt "selection:account.payment,state:"
msgid "Failed"
-msgstr "Fehlgeschlagen"
+msgstr "Erfolglos"
msgctxt "selection:account.payment,state:"
msgid "Processing"
@@ -418,7 +418,7 @@ msgstr "Entwurf"
msgctxt "view:account.payment:"
msgid "Fail"
-msgstr "Fehlschlag"
+msgstr "Erfolglos"
msgctxt "view:account.payment:"
msgid "Other Info"
diff --git a/locale/es_AR.po b/locale/es_AR.po
index deb616c..7ec6355 100644
--- a/locale/es_AR.po
+++ b/locale/es_AR.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "El Pago «%s» excede el pago de la línea «%s»."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "El Pago «%(payment)s» excede el pago de la línea «%(line)s»."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
@@ -52,7 +52,7 @@ msgstr "Moneda"
msgctxt "field:account.payment,currency_digits:"
msgid "Currency Digits"
-msgstr "Dígitos de moneda"
+msgstr "Decimales de moneda"
msgctxt "field:account.payment,date:"
msgid "Date"
@@ -200,7 +200,7 @@ msgstr "Pago"
msgctxt "model:account.payment.group,name:"
msgid "Payment Group"
-msgstr "Grupo de pago"
+msgstr "Grupo de pagos"
msgctxt "model:account.payment.journal,name:"
msgid "Payment Journal"
@@ -232,7 +232,7 @@ msgstr "Pagos"
msgctxt "model:ir.action,name:act_payment_group_form"
msgid "Payment Groups"
-msgstr "Grupos de pago"
+msgstr "Grupos de pagos"
msgctxt "model:ir.action,name:act_payment_journal_form"
msgid "Payment Journals"
@@ -302,7 +302,7 @@ msgstr "Pagos"
msgctxt "model:ir.ui.menu,name:menu_payment_group_form"
msgid "Payment Groups"
-msgstr "Grupos de pago"
+msgstr "Grupos de pagos"
msgctxt "model:ir.ui.menu,name:menu_payment_journal_form"
msgid "Payment Journals"
@@ -382,11 +382,11 @@ msgstr "Líneas de pago"
msgctxt "view:account.payment.group:"
msgid "Payment Group"
-msgstr "Grupo de pago"
+msgstr "Grupo de pagos"
msgctxt "view:account.payment.group:"
msgid "Payment Groups"
-msgstr "Grupos de pago"
+msgstr "Grupos de pagos"
msgctxt "view:account.payment.journal:"
msgid "Payment Journal"
diff --git a/locale/es_CO.po b/locale/es_CO.po
index 84020b0..919919c 100644
--- a/locale/es_CO.po
+++ b/locale/es_CO.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "El Pago \"%s\" excede el pago de la línea \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr ""
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
diff --git a/locale/es_EC.po b/locale/es_EC.po
index 7f39cb4..b4a375a 100644
--- a/locale/es_EC.po
+++ b/locale/es_EC.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "El Pago \"%s\" excede el pago de la línea \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "El Pago \"%(payment)s\" excede el pago de la línea \"%(line)s\"."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
diff --git a/locale/es_ES.po b/locale/es_ES.po
index 3647c88..ce8b4c2 100644
--- a/locale/es_ES.po
+++ b/locale/es_ES.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "El pago \"%s\" excede el importe del efecto \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "El pago \"%(payment)s\" paga en exceso el apunte \"%(line)s\"."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
@@ -52,7 +52,7 @@ msgstr "Moneda"
msgctxt "field:account.payment,currency_digits:"
msgid "Currency Digits"
-msgstr "Decimales de moneda"
+msgstr "Decimales de la moneda"
msgctxt "field:account.payment,date:"
msgid "Date"
diff --git a/locale/fr_FR.po b/locale/fr_FR.po
index ddbeb88..dc298c4 100644
--- a/locale/fr_FR.po
+++ b/locale/fr_FR.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "La paiement « %s » excède le montant de la ligne « %s »."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "Le paiement « %(payment)s » surpaye la ligne « %(line)s »."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
@@ -322,19 +322,19 @@ msgstr ""
msgctxt "selection:account.move.line,payment_kind:"
msgid "Payable"
-msgstr "À payer"
+msgstr "Fournisseur"
msgctxt "selection:account.move.line,payment_kind:"
msgid "Receivable"
-msgstr "À recevoir"
+msgstr "Compte client"
msgctxt "selection:account.payment,kind:"
msgid "Payable"
-msgstr "À payer"
+msgstr "Fournisseur"
msgctxt "selection:account.payment,kind:"
msgid "Receivable"
-msgstr "À recevoir"
+msgstr "Compte client"
msgctxt "selection:account.payment,state:"
msgid "Approved"
@@ -358,11 +358,11 @@ msgstr "Réussi"
msgctxt "selection:account.payment.group,kind:"
msgid "Payable"
-msgstr "À payer"
+msgstr "Fournisseur"
msgctxt "selection:account.payment.group,kind:"
msgid "Receivable"
-msgstr "À recevoir"
+msgstr "Compte client"
msgctxt "selection:account.payment.journal,process_method:"
msgid "Manual"
diff --git a/locale/sl_SI.po b/locale/sl_SI.po
index ae5c024..6da6b93 100644
--- a/locale/sl_SI.po
+++ b/locale/sl_SI.po
@@ -3,8 +3,8 @@ msgid ""
msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "error:account.payment.process:"
-msgid "The Payment \"%s\" overpays the Line \"%s\"."
-msgstr "Plačilo \"%s\" preplača postavko \"%s\"."
+msgid "The Payment \"%(payment)s\" overpays the Line \"%(line)s\"."
+msgstr "Plačilo \"%(payment)s\" je preplačalo postavko \"%(line)s\"."
msgctxt "error:account.payment:"
msgid "Payment \"%s\" must be in draft before deletion."
diff --git a/payment.py b/payment.py
index cb404fb..3fa6fe8 100644
--- a/payment.py
+++ b/payment.py
@@ -1,5 +1,5 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from itertools import groupby
from trytond.model import Workflow, ModelView, ModelSQL, fields
@@ -118,6 +118,7 @@ class Payment(Workflow, ModelSQL, ModelView):
depends=_DEPENDS + ['currency_digits'])
line = fields.Many2One('account.move.line', 'Line', ondelete='RESTRICT',
domain=[
+ ('move.company', '=', Eval('company', -1)),
If(Eval('kind') == 'receivable',
['OR', ('debit', '>', 0), ('credit', '<', 0)],
['OR', ('credit', '>', 0), ('debit', '<', 0)],
@@ -138,7 +139,8 @@ class Payment(Workflow, ModelSQL, ModelView):
],
('move_state', '=', 'posted'),
],
- states=_STATES, depends=_DEPENDS + ['party', 'currency', 'kind'])
+ states=_STATES, depends=_DEPENDS + ['party', 'currency', 'kind',
+ 'company'])
description = fields.Char('Description', states=_STATES, depends=_DEPENDS)
group = fields.Many2One('account.payment.group', 'Group', readonly=True,
ondelete='RESTRICT',
@@ -226,24 +228,17 @@ class Payment(Workflow, ModelSQL, ModelView):
@fields.depends('kind')
def on_change_kind(self):
- return {
- 'line': None,
- }
+ self.line = None
@fields.depends('party')
def on_change_party(self):
- return {
- 'line': None,
- }
+ self.line = None
@fields.depends('line')
def on_change_line(self):
if self.line:
- return {
- 'date': self.line.maturity_date,
- 'amount': self.line.payment_amount,
- }
- return {}
+ self.date = self.line.maturity_date
+ self.amount = self.line.payment_amount
@classmethod
def delete(cls, payments):
@@ -313,7 +308,8 @@ class ProcessPayment(Wizard):
def __setup__(cls):
super(ProcessPayment, cls).__setup__()
cls._error_messages.update({
- 'overpay': 'The Payment "%s" overpays the Line "%s".',
+ 'overpay': 'The Payment "%(payment)s" overpays '
+ 'the Line "%(line)s".',
})
def _group_payment_key(self, payment):
@@ -332,7 +328,10 @@ class ProcessPayment(Wizard):
for payment in payments:
if payment.line and payment.line.payment_amount < 0:
self.raise_user_warning(str(payment),
- 'overpay', (payment.rec_name, payment.line.rec_name))
+ 'overpay', {
+ 'payment': payment.rec_name,
+ 'line': payment.line.rec_name,
+ })
groups = []
payments = sorted(payments, key=self._group_payment_key)
@@ -343,7 +342,6 @@ class ProcessPayment(Wizard):
group.save()
groups.append(group)
return group
- grouped_payments = list(grouped_payments)
Payment.process(list(grouped_payments), group)
return action, {
diff --git a/payment.xml b/payment.xml
index c66c1fe..55dcd6d 100644
--- a/payment.xml
+++ b/payment.xml
@@ -54,10 +54,19 @@ this repository contains the full copyright notices and license terms. -->
<field name="global_p" eval="True"/>
</record>
<record model="ir.rule" id="rule_payment_journal1">
- <field name="domain">[('company', '=', user.company.id if user.company else None)]</field>
+ <field name="domain"
+ eval="[('company', '=', Eval('user', {}).get('company', None))]"
+ pyson="1"/>
<field name="rule_group" ref="rule_group_payment_journal"/>
</record>
+ <record model="ir.model.access" id="access_payment_journal">
+ <field name="model" search="[('model', '=', 'account.payment.journal')]"/>
+ <field name="perm_read" eval="False"/>
+ <field name="perm_write" eval="False"/>
+ <field name="perm_create" eval="False"/>
+ <field name="perm_delete" eval="False"/>
+ </record>
<record model="ir.model.access" id="access_payment_journal_account_admin">
<field name="model" search="[('model', '=', 'account.payment.journal')]"/>
<field name="group" ref="account.group_account_admin"/>
@@ -109,10 +118,19 @@ this repository contains the full copyright notices and license terms. -->
<field name="global_p" eval="True"/>
</record>
<record model="ir.rule" id="rule_payment_group1">
- <field name="domain">[('company', '=', user.company.id if user.company else None)]</field>
+ <field name="domain"
+ eval="[('company', '=', Eval('user', {}).get('company', None))]"
+ pyson="1"/>
<field name="rule_group" ref="rule_group_payment_group"/>
</record>
+ <record model="ir.model.access" id="access_payment_group">
+ <field name="model" search="[('model', '=', 'account.payment.group')]"/>
+ <field name="perm_read" eval="False"/>
+ <field name="perm_write" eval="False"/>
+ <field name="perm_create" eval="False"/>
+ <field name="perm_delete" eval="False"/>
+ </record>
<record model="ir.model.access" id="access_payment_group_account_admin">
<field name="model" search="[('model', '=', 'account.payment.group')]"/>
<field name="group" ref="account.group_account_admin"/>
@@ -182,31 +200,31 @@ this repository contains the full copyright notices and license terms. -->
<record model="ir.action.act_window.domain" id="act_payment_form_domain_draft">
<field name="name">Draft</field>
<field name="sequence" eval="10"/>
- <field name="domain">[('state', '=', 'draft')]</field>
+ <field name="domain" eval="[('state', '=', 'draft')]" pyson="1"/>
<field name="act_window" ref="act_payment_form"/>
</record>
<record model="ir.action.act_window.domain" id="act_payment_form_domain_approved">
<field name="name">Approved</field>
<field name="sequence" eval="20"/>
- <field name="domain">[('state', '=', 'approved')]</field>
+ <field name="domain" eval="[('state', '=', 'approved')]" pyson="1"/>
<field name="act_window" ref="act_payment_form"/>
</record>
<record model="ir.action.act_window.domain" id="act_payment_form_domain_processing">
<field name="name">Processing</field>
<field name="sequence" eval="30"/>
- <field name="domain">[('state', '=', 'processing')]</field>
+ <field name="domain" eval="[('state', '=', 'processing')]" pyson="1"/>
<field name="act_window" ref="act_payment_form"/>
</record>
<record model="ir.action.act_window.domain" id="act_payment_form_domain_suceeded">
<field name="name">Succeeded</field>
<field name="sequence" eval="40"/>
- <field name="domain">[('state', '=', 'succeeded')]</field>
+ <field name="domain" eval="[('state', '=', 'succeeded')]" pyson="1"/>
<field name="act_window" ref="act_payment_form"/>
</record>
<record model="ir.action.act_window.domain" id="act_payment_form_domain_failed">
<field name="name">Failed</field>
<field name="sequence" eval="50"/>
- <field name="domain">[('state', '=', 'failed')]</field>
+ <field name="domain" eval="[('state', '=', 'failed')]" pyson="1"/>
<field name="act_window" ref="act_payment_form"/>
</record>
<record model="ir.action.act_window.domain" id="act_payment_form_domain_all">
@@ -224,14 +242,17 @@ this repository contains the full copyright notices and license terms. -->
<field name="global_p" eval="True"/>
</record>
<record model="ir.rule" id="rule_payment1">
- <field name="domain">[('company', '=', user.company.id if user.company else None)]</field>
+ <field name="domain"
+ eval="[('company', '=', Eval('user', {}).get('company', None))]"
+ pyson="1"/>
<field name="rule_group" ref="rule_group_payment"/>
</record>
<record model="ir.action.act_window" id="act_payment_form_line_relate">
<field name="name">Payments</field>
<field name="res_model">account.payment</field>
- <field name="domain">[('line', '=', Eval('active_id'))]</field>
+ <field name="domain"
+ eval="[('line', '=', Eval('active_id'))]" pyson="1"/>
</record>
<record model="ir.action.act_window.view"
id="act_payment_form_line_relate_view1">
@@ -255,7 +276,8 @@ this repository contains the full copyright notices and license terms. -->
<record model="ir.action.act_window" id="act_payment_form_group_open">
<field name="name">Payments</field>
<field name="res_model">account.payment</field>
- <field name="domain">[('group', '=', Eval('active_id'))]</field>
+ <field name="domain"
+ eval="[('group', '=', Eval('active_id'))]" pyson="1"/>
</record>
<record model="ir.action.act_window.view"
id="act_payment_form_group_open_view1">
@@ -276,6 +298,13 @@ this repository contains the full copyright notices and license terms. -->
<field name="action" ref="act_payment_form_group_open"/>
</record>
+ <record model="ir.model.access" id="access_payment">
+ <field name="model" search="[('model', '=', 'account.payment')]"/>
+ <field name="perm_read" eval="False"/>
+ <field name="perm_write" eval="False"/>
+ <field name="perm_create" eval="False"/>
+ <field name="perm_delete" eval="False"/>
+ </record>
<record model="ir.model.access" id="access_payment_account_admin">
<field name="model" search="[('model', '=', 'account.payment')]"/>
<field name="group" ref="account.group_account_admin"/>
diff --git a/setup.py b/setup.py
index 98dc55b..2c658dd 100644
--- a/setup.py
+++ b/setup.py
@@ -1,6 +1,6 @@
#!/usr/bin/env python
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from setuptools import setup
import re
@@ -41,7 +41,7 @@ if minor_version % 2:
'hg+http://hg.tryton.org/modules/%s#egg=%s-%s' % (
name[8:], name, version))
-requires = []
+requires = ['python-sql >= 0.4']
for dep in info.get('depends', []):
if not re.match(r'(ir|res|webdav)(\W|$)', dep):
requires.append(get_require_version('trytond_%s' % dep))
@@ -92,6 +92,8 @@ setup(name=name,
'Natural Language :: Spanish',
'Operating System :: OS Independent',
'Programming Language :: Python :: 2.7',
+ 'Programming Language :: Python :: Implementation :: CPython',
+ 'Programming Language :: Python :: Implementation :: PyPy',
'Topic :: Office/Business',
'Topic :: Office/Business :: Financial :: Accounting',
],
diff --git a/tests/__init__.py b/tests/__init__.py
index 9431450..6887e15 100644
--- a/tests/__init__.py
+++ b/tests/__init__.py
@@ -1,5 +1,5 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
from .test_account_payment import suite
diff --git a/tests/scenario_account_payment.rst b/tests/scenario_account_payment.rst
index 9cf27a6..1a1bb0f 100644
--- a/tests/scenario_account_payment.rst
+++ b/tests/scenario_account_payment.rst
@@ -4,11 +4,12 @@ Payment Scenario
Imports::
>>> import datetime
- >>> from dateutil.relativedelta import relativedelta
>>> from decimal import Decimal
- >>> from operator import attrgetter
>>> from proteus import config, Model, Wizard
- >>> today = datetime.date.today()
+ >>> from trytond.modules.company.tests.tools import create_company, \
+ ... get_company
+ >>> from trytond.modules.account.tests.tools import create_fiscalyear, \
+ ... create_chart, get_accounts
Create database::
@@ -25,76 +26,20 @@ Install account_payment::
Create company::
- >>> Currency = Model.get('currency.currency')
- >>> CurrencyRate = Model.get('currency.currency.rate')
- >>> currencies = Currency.find([('code', '=', 'USD')])
- >>> if not currencies:
- ... currency = Currency(name='US Dollar', symbol=u'$', code='USD',
- ... rounding=Decimal('0.01'), mon_grouping='[]',
- ... mon_decimal_point='.')
- ... currency.save()
- ... CurrencyRate(date=today + relativedelta(month=1, day=1),
- ... rate=Decimal('1.0'), currency=currency).save()
- ... else:
- ... currency, = currencies
- >>> Company = Model.get('company.company')
- >>> Party = Model.get('party.party')
- >>> company_config = Wizard('company.company.config')
- >>> company_config.execute('company')
- >>> company = company_config.form
- >>> party = Party(name='Dunder Mifflin')
- >>> party.save()
- >>> company.party = party
- >>> company.currency = currency
- >>> company_config.execute('add')
- >>> company, = Company.find([])
-
-Reload the context::
-
- >>> User = Model.get('res.user')
- >>> config._context = User.get_preferences(True, config.context)
+ >>> _ = create_company()
+ >>> company = get_company()
Create fiscal year::
- >>> FiscalYear = Model.get('account.fiscalyear')
- >>> Sequence = Model.get('ir.sequence')
- >>> SequenceStrict = Model.get('ir.sequence.strict')
- >>> fiscalyear = FiscalYear(name=str(today.year))
- >>> fiscalyear.start_date = today + relativedelta(month=1, day=1)
- >>> fiscalyear.end_date = today + relativedelta(month=12, day=31)
- >>> fiscalyear.company = company
- >>> post_move_seq = Sequence(name=str(today.year), code='account.move',
- ... company=company)
- >>> post_move_seq.save()
- >>> fiscalyear.post_move_sequence = post_move_seq
- >>> fiscalyear.save()
- >>> FiscalYear.create_period([fiscalyear.id], config.context)
+ >>> fiscalyear = create_fiscalyear(company)
+ >>> fiscalyear.click('create_period')
Create chart of accounts::
- >>> AccountTemplate = Model.get('account.account.template')
- >>> Account = Model.get('account.account')
- >>> account_template, = AccountTemplate.find([('parent', '=', None)])
- >>> create_chart = Wizard('account.create_chart')
- >>> create_chart.execute('account')
- >>> create_chart.form.account_template = account_template
- >>> create_chart.form.company = company
- >>> create_chart.execute('create_account')
- >>> receivable, = Account.find([
- ... ('kind', '=', 'receivable'),
- ... ('company', '=', company.id),
- ... ])
- >>> payable, = Account.find([
- ... ('kind', '=', 'payable'),
- ... ('company', '=', company.id),
- ... ])
- >>> expense, = Account.find([
- ... ('kind', '=', 'expense'),
- ... ('company', '=', company.id),
- ... ])
- >>> create_chart.form.account_receivable = receivable
- >>> create_chart.form.account_payable = payable
- >>> create_chart.execute('create_properties')
+ >>> _ = create_chart(company)
+ >>> accounts = get_accounts(company)
+ >>> payable = accounts['payable']
+
>>> Journal = Model.get('account.journal')
>>> expense, = Journal.find([('code', '=', 'EXP')])
diff --git a/tests/test_account_payment.py b/tests/test_account_payment.py
index 0560dfb..a3b8389 100644
--- a/tests/test_account_payment.py
+++ b/tests/test_account_payment.py
@@ -1,25 +1,15 @@
-#This file is part of Tryton. The COPYRIGHT file at the top level of
-#this repository contains the full copyright notices and license terms.
+# This file is part of Tryton. The COPYRIGHT file at the top level of
+# this repository contains the full copyright notices and license terms.
import unittest
import doctest
import trytond.tests.test_tryton
-from trytond.tests.test_tryton import test_view, test_depends
+from trytond.tests.test_tryton import ModuleTestCase
from trytond.tests.test_tryton import doctest_setup, doctest_teardown
-class AccountPaymentTestCase(unittest.TestCase):
+class AccountPaymentTestCase(ModuleTestCase):
'Test Account Payment module'
-
- def setUp(self):
- trytond.tests.test_tryton.install_module('account_payment')
-
- def test0005views(self):
- 'Test views'
- test_view('account_payment')
-
- def test0006depends(self):
- 'Test depends'
- test_depends()
+ module = 'account_payment'
def suite():
diff --git a/tryton.cfg b/tryton.cfg
index ab94b1b..cb31005 100644
--- a/tryton.cfg
+++ b/tryton.cfg
@@ -1,5 +1,5 @@
[tryton]
-version=3.4.1
+version=3.6.0
depends:
account
company
diff --git a/trytond_account_payment.egg-info/PKG-INFO b/trytond_account_payment.egg-info/PKG-INFO
index 8f40240..1b660e6 100644
--- a/trytond_account_payment.egg-info/PKG-INFO
+++ b/trytond_account_payment.egg-info/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond-account-payment
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for payment
Home-page: http://www.tryton.org/
Author: Tryton
Author-email: issue_tracker at tryton.org
License: GPL-3
-Download-URL: http://downloads.tryton.org/3.4/
+Download-URL: http://downloads.tryton.org/3.6/
Description: trytond_account_payment
=======================
@@ -64,5 +64,7 @@ Classifier: Natural Language :: Slovenian
Classifier: Natural Language :: Spanish
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2.7
+Classifier: Programming Language :: Python :: Implementation :: CPython
+Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Topic :: Office/Business
Classifier: Topic :: Office/Business :: Financial :: Accounting
diff --git a/trytond_account_payment.egg-info/requires.txt b/trytond_account_payment.egg-info/requires.txt
index b2a1ab7..3316a4a 100644
--- a/trytond_account_payment.egg-info/requires.txt
+++ b/trytond_account_payment.egg-info/requires.txt
@@ -1,5 +1,6 @@
-trytond_account >= 3.4, < 3.5
-trytond_company >= 3.4, < 3.5
-trytond_currency >= 3.4, < 3.5
-trytond_party >= 3.4, < 3.5
-trytond >= 3.4, < 3.5
\ No newline at end of file
+python-sql >= 0.4
+trytond_account >= 3.6, < 3.7
+trytond_company >= 3.6, < 3.7
+trytond_currency >= 3.6, < 3.7
+trytond_party >= 3.6, < 3.7
+trytond >= 3.6, < 3.7
\ No newline at end of file
--
tryton-modules-account-payment
More information about the tryton-debian-vcs
mailing list