[tryton-debian-vcs] tryton-modules-account-dunning-letter branch debian updated. debian/3.4.1-1-2-g8215cdb
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Thu Apr 23 16:01:14 UTC 2015
The following commit has been merged in the debian branch:
https://alioth.debian.org/plugins/scmgit/cgi-bin/gitweb.cgi/?p=tryton/tryton-modules-account-dunning-letter.git;a=commitdiff;h=debian/3.4.1-1-2-g8215cdb
commit 8215cdb82f573be8af481cb37cbc4bf89c359178
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Thu Apr 23 16:59:49 2015 +0200
Merging upstream version 3.6.0.
diff --git a/CHANGELOG b/CHANGELOG
index 796da36..1b06dc3 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,6 +1,6 @@
-Version 3.4.1 - 2015-03-02
+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)
diff --git a/PKG-INFO b/PKG-INFO
index 5439a37..5088a33 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond_account_dunning_letter
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for account dunning letter
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_dunning_letter
==============================
@@ -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 95ebfc3..554c027 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 .dunning import *
diff --git a/dunning.py b/dunning.py
index ff313a7..295df9f 100644
--- a/dunning.py
+++ b/dunning.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 operator import attrgetter
from itertools import groupby, chain
@@ -45,7 +45,9 @@ class Letter(CompanyReport):
__name__ = 'account.dunning.letter'
@classmethod
- def parse(cls, report, records, data, localcontext):
+ def get_context(cls, records, data):
+ report_context = super(Letter, cls).get_context(records, data)
+
pool = Pool()
Date = pool.get('ir.date')
@@ -72,11 +74,11 @@ class Letter(CompanyReport):
continue
letters[party] = PartyLetter(dunnings=current_dunnings,
payments=current_payments)
- localcontext['letters'] = letters
- localcontext['today'] = Date.today()
- localcontext['get_payment_amount'] = cls.get_payment_amount
- localcontext['get_payment_currency'] = cls.get_payment_currency
- return super(Letter, cls).parse(report, records, data, localcontext)
+ report_context['letters'] = letters
+ report_context['today'] = Date.today()
+ report_context['get_payment_amount'] = cls.get_payment_amount
+ report_context['get_payment_currency'] = cls.get_payment_currency
+ return report_context
@staticmethod
def get_party_letter():
@@ -126,14 +128,13 @@ class Letter(CompanyReport):
@staticmethod
def get_payment_amount(payment):
if payment.amount_second_currency:
- return payment.amount_second_currency.copy_sign(
- payment.credit - payment.debit)
+ return -payment.amount_second_currency
else:
return payment.credit - payment.debit
@staticmethod
def get_payment_currency(payment):
- if payment.amount_second_currency:
+ if payment.second_currency:
return payment.second_currency
else:
return payment.account.company.currency
diff --git a/letter.odt b/letter.odt
index 313b03a..5f5f83f 100644
Binary files a/letter.odt and b/letter.odt differ
diff --git a/locale/de_DE.po b/locale/de_DE.po
index f8dd7fa..25c6c6a 100644
--- a/locale/de_DE.po
+++ b/locale/de_DE.po
@@ -4,7 +4,7 @@ msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:account.dunning.level,print_on_letter:"
msgid "Print on Letter"
-msgstr "Auf Mahnschreiben drucken"
+msgstr "Auf Mahnschreiben andrucken"
msgctxt "model:ir.action,name:report_letter"
msgid "Dunning Letter"
diff --git a/locale/es_EC.po b/locale/es_EC.po
index ccfb6da..ab85bcf 100644
--- a/locale/es_EC.po
+++ b/locale/es_EC.po
@@ -4,15 +4,15 @@ msgstr "Content-Type: text/plain; charset=utf-8\n"
msgctxt "field:account.dunning.level,print_on_letter:"
msgid "Print on Letter"
-msgstr "Imprimir en una Carta"
+msgstr "Imprimir en una carta"
msgctxt "model:ir.action,name:report_letter"
msgid "Dunning Letter"
-msgstr "Carta de Cobro"
+msgstr "Carta de cobro"
msgctxt "odt:account.dunning.letter:"
msgid "Amount"
-msgstr "Valor"
+msgstr "Importe"
msgctxt "odt:account.dunning.letter:"
msgid "Date"
@@ -28,7 +28,7 @@ msgstr "Descripción"
msgctxt "odt:account.dunning.letter:"
msgid "Due Date"
-msgstr "Fecha de Vencimiento"
+msgstr "Fecha de vencimiento"
msgctxt "odt:account.dunning.letter:"
msgid "E-Mail:"
@@ -36,7 +36,7 @@ msgstr "Correo electrónico:"
msgctxt "odt:account.dunning.letter:"
msgid "Pending Payments Received"
-msgstr "Pagos Pendientes Recibidos"
+msgstr "Pagos pendientes recibidos"
msgctxt "odt:account.dunning.letter:"
msgid "Phone:"
@@ -48,7 +48,7 @@ msgstr "Referencia"
msgctxt "odt:account.dunning.letter:"
msgid "Reminder Notice"
-msgstr "Aviso Recordatorio"
+msgstr "Aviso recordatorio"
msgctxt "odt:account.dunning.letter:"
msgid "VAT Number:"
diff --git a/setup.py b/setup.py
index f51cfa8..455139b 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
@@ -47,7 +47,7 @@ for dep in info.get('depends', []):
requires.append(get_require_version('trytond_%s' % dep))
requires.append(get_require_version('trytond'))
-tests_require = []
+tests_require = [get_require_version('proteus')]
dependency_links = []
if minor_version % 2:
# Add development index for testing with proteus
@@ -91,6 +91,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 f1b3bee..e1241c6 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_dunning_letter import suite
diff --git a/tests/scenario_account_dunning_letter.rst b/tests/scenario_account_dunning_letter.rst
new file mode 100644
index 0000000..affe96a
--- /dev/null
+++ b/tests/scenario_account_dunning_letter.rst
@@ -0,0 +1,182 @@
+========================
+Account Dunning Scenario
+========================
+
+Imports::
+
+ >>> import datetime
+ >>> from dateutil.relativedelta import relativedelta
+ >>> from decimal import Decimal
+ >>> from proteus import config, Model, Wizard
+ >>> from trytond.modules.company.tests.tools import create_company, \
+ ... get_company
+ >>> from trytond.modules.account.tests.tools import create_fiscalyear, \
+ ... create_chart, get_accounts
+ >>> today = datetime.date.today()
+
+Create database::
+
+ >>> config = config.set_trytond()
+ >>> config.pool.test = True
+
+Install account_dunning_letter::
+
+ >>> Module = Model.get('ir.module.module')
+ >>> module, = Module.find([
+ ... ('name', '=', 'account_dunning_letter'),
+ ... ])
+ >>> module.click('install')
+ >>> Wizard('ir.module.module.install_upgrade').execute('upgrade')
+
+Create company::
+
+ >>> _ = create_company()
+ >>> company = get_company()
+
+Reload the context::
+
+ >>> User = Model.get('res.user')
+ >>> Group = Model.get('res.group')
+ >>> config._context = User.get_preferences(True, config.context)
+
+Create account admin user::
+
+ >>> account_admin_user = User()
+ >>> account_admin_user.name = 'Account Admin'
+ >>> account_admin_user.login = 'account_admin'
+ >>> account_admin_group, = Group.find([
+ ... ('name', '=', 'Account Administration'),
+ ... ])
+ >>> account_admin_user.groups.append(account_admin_group)
+ >>> account_admin_user.save()
+
+Create account user::
+
+ >>> account_user = User()
+ >>> account_user.name = 'Account'
+ >>> account_user.login = 'account'
+ >>> account_group, = Group.find([
+ ... ('name', '=', 'Account'),
+ ... ])
+ >>> account_user.groups.append(account_group)
+ >>> account_user.save()
+
+Create dunning user::
+
+ >>> dunning_user = User()
+ >>> dunning_user.name = 'Dunning'
+ >>> dunning_user.login = 'dunning'
+ >>> dunning_group, = Group.find([('name', '=', 'Dunning')])
+ >>> dunning_user.groups.append(dunning_group)
+ >>> dunning_user.save()
+
+Create fiscal year::
+
+ >>> fiscalyear = create_fiscalyear(company)
+ >>> fiscalyear.click('create_period')
+ >>> period = fiscalyear.periods[0]
+
+Create chart of accounts::
+
+ >>> _ = create_chart(company)
+ >>> accounts = get_accounts(company)
+ >>> receivable = accounts['receivable']
+ >>> revenue = accounts['revenue']
+ >>> cash = accounts['cash']
+
+Create dunning procedure::
+
+ >>> config.user = account_admin_user.id
+ >>> Procedure = Model.get('account.dunning.procedure')
+ >>> procedure = Procedure(name='Procedure')
+ >>> level = procedure.levels.new()
+ >>> level.sequence = 1
+ >>> level.days = 5
+ >>> level = procedure.levels.new()
+ >>> level.sequence = 2
+ >>> level.days = 20
+ >>> level = procedure.levels.new()
+ >>> level.sequence = 3
+ >>> level.days = 40
+ >>> procedure.save()
+
+Create parties::
+
+ >>> Party = Model.get('party.party')
+ >>> customer = Party(name='Customer')
+ >>> customer.dunning_procedure = procedure
+ >>> customer.save()
+
+Create some moves::
+
+ >>> config.user = account_user.id
+ >>> Journal = Model.get('account.journal')
+ >>> Move = Model.get('account.move')
+ >>> journal_revenue, = Journal.find([
+ ... ('code', '=', 'REV'),
+ ... ])
+ >>> journal_cash, = Journal.find([
+ ... ('code', '=', 'CASH'),
+ ... ])
+ >>> move = Move()
+ >>> move.period = period
+ >>> move.journal = journal_revenue
+ >>> move.date = period.start_date
+ >>> line = move.lines.new()
+ >>> line.account = revenue
+ >>> line.credit = Decimal(100)
+ >>> line = move.lines.new()
+ >>> line.account = receivable
+ >>> line.debit = Decimal(100)
+ >>> line.party = customer
+ >>> line.maturity_date = period.start_date
+ >>> move.save()
+ >>> reconcile1, = [l for l in move.lines if l.account == receivable]
+ >>> move = Move()
+ >>> move.period = period
+ >>> move.journal = journal_cash
+ >>> move.date = period.start_date
+ >>> line = move.lines.new()
+ >>> line.account = cash
+ >>> line.debit = Decimal(100)
+ >>> line = move.lines.new()
+ >>> line.account = receivable
+ >>> line.credit = Decimal(100)
+ >>> line.party = customer
+ >>> move.save()
+ >>> reconcile2, = [l for l in move.lines if l.account == receivable]
+ >>> reconcile_lines = Wizard('account.move.reconcile_lines',
+ ... [reconcile1, reconcile2])
+ >>> move = Move()
+ >>> move.period = period
+ >>> move.journal = journal_revenue
+ >>> move.date = period.start_date
+ >>> line = move.lines.new()
+ >>> line.account = revenue
+ >>> line.credit = Decimal(100)
+ >>> line = move.lines.new()
+ >>> line.account = receivable
+ >>> line.debit = Decimal(100)
+ >>> line.party = customer
+ >>> line.maturity_date = period.start_date
+ >>> move.save()
+ >>> dunning_line, = [l for l in move.lines if l.account == receivable]
+
+Create dunnings::
+
+ >>> config.user = dunning_user.id
+ >>> Dunning = Model.get('account.dunning')
+ >>> create_dunning = Wizard('account.dunning.create')
+ >>> create_dunning.form.date = period.start_date + relativedelta(days=5)
+ >>> create_dunning.execute('create_')
+ >>> dunning, = Dunning.find([])
+
+Process dunning::
+
+ >>> process_dunning = Wizard('account.dunning.process',
+ ... [dunning])
+ >>> process_dunning.execute('process')
+ >>> dunning.reload()
+ >>> dunning.state
+ u'done'
+
diff --git a/tests/test_account_dunning_letter.py b/tests/test_account_dunning_letter.py
index edf0093..1c72aa3 100644
--- a/tests/test_account_dunning_letter.py
+++ b/tests/test_account_dunning_letter.py
@@ -1,27 +1,22 @@
-#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 AccountDunningLetterTestCase(unittest.TestCase):
+class AccountDunningLetterTestCase(ModuleTestCase):
'Test AccountDunningLetter module'
-
- def setUp(self):
- trytond.tests.test_tryton.install_module('account_dunning_letter')
-
- def test0005views(self):
- 'Test views'
- test_view('account_dunning_letter')
-
- def test0006depends(self):
- 'Test depends'
- test_depends()
+ module = 'account_dunning_letter'
def suite():
suite = trytond.tests.test_tryton.suite()
suite.addTests(unittest.TestLoader().loadTestsFromTestCase(
AccountDunningLetterTestCase))
+ suite.addTests(doctest.DocFileSuite('scenario_account_dunning_letter.rst',
+ setUp=doctest_setup, tearDown=doctest_teardown, encoding='utf-8',
+ optionflags=doctest.REPORT_ONLY_FIRST_FAILURE))
return suite
diff --git a/tryton.cfg b/tryton.cfg
index fcce38e..af15a24 100644
--- a/tryton.cfg
+++ b/tryton.cfg
@@ -1,5 +1,5 @@
[tryton]
-version=3.4.1
+version=3.6.0
depends:
account
account_dunning
diff --git a/trytond_account_dunning_letter.egg-info/PKG-INFO b/trytond_account_dunning_letter.egg-info/PKG-INFO
index d78f05b..1a10341 100644
--- a/trytond_account_dunning_letter.egg-info/PKG-INFO
+++ b/trytond_account_dunning_letter.egg-info/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond-account-dunning-letter
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for account dunning letter
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_dunning_letter
==============================
@@ -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_dunning_letter.egg-info/SOURCES.txt b/trytond_account_dunning_letter.egg-info/SOURCES.txt
index 3ec9f08..6a68dee 100644
--- a/trytond_account_dunning_letter.egg-info/SOURCES.txt
+++ b/trytond_account_dunning_letter.egg-info/SOURCES.txt
@@ -34,6 +34,7 @@ locale/es_EC.po
locale/es_ES.po
locale/fr_FR.po
locale/sl_SI.po
+tests/scenario_account_dunning_letter.rst
trytond_account_dunning_letter.egg-info/PKG-INFO
trytond_account_dunning_letter.egg-info/SOURCES.txt
trytond_account_dunning_letter.egg-info/dependency_links.txt
diff --git a/trytond_account_dunning_letter.egg-info/requires.txt b/trytond_account_dunning_letter.egg-info/requires.txt
index 01483c4..b5d8770 100644
--- a/trytond_account_dunning_letter.egg-info/requires.txt
+++ b/trytond_account_dunning_letter.egg-info/requires.txt
@@ -1,5 +1,5 @@
-trytond_account >= 3.4, < 3.5
-trytond_account_dunning >= 3.4, < 3.5
-trytond_company >= 3.4, < 3.5
-trytond_party >= 3.4, < 3.5
-trytond >= 3.4, < 3.5
\ No newline at end of file
+trytond_account >= 3.6, < 3.7
+trytond_account_dunning >= 3.6, < 3.7
+trytond_company >= 3.6, < 3.7
+trytond_party >= 3.6, < 3.7
+trytond >= 3.6, < 3.7
\ No newline at end of file
--
tryton-modules-account-dunning-letter
More information about the tryton-debian-vcs
mailing list