[tryton-debian-vcs] tryton-modules-production branch upstream updated. upstream/3.4.1-1-g1f2ff15
Mathias Behrle
tryton-debian-vcs at alioth.debian.org
Thu Apr 23 16:04: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-production.git;a=commitdiff;h=upstream/3.4.1-1-g1f2ff15
commit 1f2ff15e3eaefe78d95863e0247678825f6c6f10
Author: Mathias Behrle <mathiasb at m9s.biz>
Date: Thu Apr 23 17:00:01 2015 +0200
Adding upstream version 3.6.0.
Signed-off-by: Mathias Behrle <mathiasb at m9s.biz>
diff --git a/CHANGELOG b/CHANGELOG
index 3c86c2e..7bf4160 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,6 +1,6 @@
-Version 3.4.1 - 2015-02-22
+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 d28253f..da93ca4 100644
--- a/PKG-INFO
+++ b/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond_production
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for production
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_production
==================
@@ -65,4 +65,6 @@ 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
diff --git a/__init__.py b/__init__.py
index 7e10c20..0540b43 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 .configuration import *
diff --git a/bom.py b/bom.py
index 7ce8a29..45e421a 100644
--- a/bom.py
+++ b/bom.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.model import ModelView, ModelSQL, fields
from trytond.wizard import Wizard, StateView, Button
from trytond.transaction import Transaction
@@ -87,18 +87,14 @@ class BOMInput(ModelSQL, ModelView):
@fields.depends('product', 'uom')
def on_change_product(self):
- res = {}
if self.product:
uoms = self.product.default_uom.category.uoms
if (not self.uom or self.uom not in uoms):
- res['uom'] = self.product.default_uom.id
- res['uom.rec_name'] = self.product.default_uom.rec_name
- res['unit_digits'] = self.product.default_uom.digits
+ self.uom = self.product.default_uom
+ self.unit_digits = self.product.default_uom.digits
else:
- res['uom'] = None
- res['uom.rec_name'] = ''
- res['unit_digits'] = 2
- return res
+ self.uom = None
+ self.unit_digits = 2
@fields.depends('product')
def on_change_with_uom_category(self, name=None):
@@ -227,7 +223,7 @@ class OpenBOMTree(Wizard):
start = StateView('production.bom.tree.open.start',
'production.bom_tree_open_start_view_form', [
Button('Cancel', 'end', 'tryton-cancel'),
- Button('Ok', 'tree', 'tryton-ok', True),
+ Button('OK', 'tree', 'tryton-ok', True),
])
tree = StateView('production.bom.tree.open.tree',
'production.bom_tree_open_tree_view_form', [
diff --git a/configuration.py b/configuration.py
index eb35e63..ac0588e 100644
--- a/configuration.py
+++ b/configuration.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.model import ModelView, ModelSQL, ModelSingleton, fields
from trytond.pyson import Eval
diff --git a/locale/bg_BG.po b/locale/bg_BG.po
index 6719634..0b26dd3 100644
--- a/locale/bg_BG.po
+++ b/locale/bg_BG.po
@@ -690,7 +690,7 @@ msgid "Wait"
msgstr "Очаквано"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Добре"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -702,7 +702,7 @@ msgid "Cancel"
msgstr "Отказ"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Добре"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/ca_ES.po b/locale/ca_ES.po
index eeaecd2..22c3ed9 100644
--- a/locale/ca_ES.po
+++ b/locale/ca_ES.po
@@ -453,12 +453,12 @@ msgstr "Arbre de la llista de materials"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_all"
msgid "All"
-msgstr "Tot"
+msgstr "Totes"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_assigned"
msgid "Assigned"
-msgstr "Reservat"
+msgstr "Reservada"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_draft"
@@ -574,7 +574,7 @@ msgstr "Cancel·lada"
msgctxt "selection:production,state:"
msgid "Done"
-msgstr "Realitzada"
+msgstr "Finalitzada"
msgctxt "selection:production,state:"
msgid "Draft"
@@ -654,7 +654,7 @@ msgstr "Cancel·la"
msgctxt "view:production:"
msgid "Done"
-msgstr "Realitzat"
+msgstr "Finalitza"
msgctxt "view:production:"
msgid "Draft"
@@ -677,6 +677,10 @@ msgid "Productions"
msgstr "Produccions"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Reestableix amb la LdM"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Executa"
@@ -685,7 +689,7 @@ msgid "Wait"
msgstr "En espera"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Accepta"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -697,7 +701,7 @@ msgid "Cancel"
msgstr "Cancel·la"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Accepta"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/cs_CZ.po b/locale/cs_CZ.po
index 7e96a5c..0f39587 100644
--- a/locale/cs_CZ.po
+++ b/locale/cs_CZ.po
@@ -681,7 +681,7 @@ msgid "Wait"
msgstr ""
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr ""
msgctxt "wizard_button:production.assign,failed,force:"
@@ -693,7 +693,7 @@ msgid "Cancel"
msgstr ""
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr ""
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/de_DE.po b/locale/de_DE.po
index 540021a..03428c9 100644
--- a/locale/de_DE.po
+++ b/locale/de_DE.po
@@ -676,6 +676,10 @@ msgid "Productions"
msgstr "Produktionen"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Auf Stückliste zurücksetzen"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Ausführen"
@@ -684,7 +688,7 @@ msgid "Wait"
msgstr "Warten"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "OK"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -696,7 +700,7 @@ msgid "Cancel"
msgstr "Abbrechen"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "OK"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/es_AR.po b/locale/es_AR.po
index 0799d59..1d5143f 100644
--- a/locale/es_AR.po
+++ b/locale/es_AR.po
@@ -152,7 +152,7 @@ msgstr "Estado"
msgctxt "field:production,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:production,uom:"
msgid "Uom"
@@ -164,7 +164,7 @@ msgstr "Categoría UdM"
msgctxt "field:production,warehouse:"
msgid "Warehouse"
-msgstr "Depósito"
+msgstr "Almacén"
msgctxt "field:production,write_date:"
msgid "Write Date"
@@ -256,7 +256,7 @@ msgstr "Nombre"
msgctxt "field:production.bom.input,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:production.bom.input,uom:"
msgid "Uom"
@@ -304,7 +304,7 @@ msgstr "Nombre"
msgctxt "field:production.bom.output,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:production.bom.output,uom:"
msgid "Uom"
@@ -340,7 +340,7 @@ msgstr "Cantidad"
msgctxt "field:production.bom.tree,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:production.bom.tree,uom:"
msgid "Uom"
@@ -368,7 +368,7 @@ msgstr "Cantidad"
msgctxt "field:production.bom.tree.open.start,unit_digits:"
msgid "Unit Digits"
-msgstr "Dígitos de unidad"
+msgstr "Decimales de unidad"
msgctxt "field:production.bom.tree.open.start,uom:"
msgid "Unit"
@@ -424,11 +424,11 @@ msgstr "Salida de producción"
msgctxt "model:ir.action,name:act_bom_form"
msgid "BOM"
-msgstr "LdM"
+msgstr "Lista de material"
msgctxt "model:ir.action,name:act_bom_list"
msgid "BOMs"
-msgstr "LdMs"
+msgstr "Lista de materiales"
msgctxt "model:ir.action,name:act_production_calendar"
msgid "Productions"
@@ -490,7 +490,7 @@ msgstr "Producción"
msgctxt "model:ir.ui.menu,name:menu_bom_list"
msgid "BOMs"
-msgstr "LdMs"
+msgstr "Lista de materiales"
msgctxt "model:ir.ui.menu,name:menu_configuration"
msgid "Configuration"
@@ -594,11 +594,11 @@ msgstr "En espera"
msgctxt "view:product.product-production.bom:"
msgid "Product - BOM"
-msgstr "Producto - LdM"
+msgstr "Producto - Lista de material"
msgctxt "view:product.product-production.bom:"
msgid "Product - BOMs"
-msgstr "Producto - LdMs"
+msgstr "Producto - Lista de materiales"
msgctxt "view:production.assign.failed:"
msgid "Unable to Assign"
@@ -610,31 +610,31 @@ msgstr "No se puede asignar estos productos:"
msgctxt "view:production.bom.input:"
msgid "BOM Inputs"
-msgstr "Entradas LdM"
+msgstr "Entradas lista de material"
msgctxt "view:production.bom.output:"
msgid "BOM Outputs"
-msgstr "Salidas LdM"
+msgstr "Salidas lista de material"
msgctxt "view:production.bom.tree.open.start:"
msgid "BOM Tree"
-msgstr "Árbol LdM"
+msgstr "Árbol lista de materiales"
msgctxt "view:production.bom.tree.open.tree:"
msgid "BOM Tree"
-msgstr "Árbol LdM"
+msgstr "Árbol lista de materiales"
msgctxt "view:production.bom.tree:"
msgid "BOM Tree"
-msgstr "Árbol LdM"
+msgstr "Árbol lista de materiales"
msgctxt "view:production.bom:"
msgid "BOM"
-msgstr "LdM"
+msgstr "Lista de material"
msgctxt "view:production.bom:"
msgid "BOMs"
-msgstr "LdMs"
+msgstr "Lista de materiales"
msgctxt "view:production.bom:"
msgid "Lines"
@@ -677,6 +677,10 @@ msgid "Productions"
msgstr "Producciones"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Restablecer a LdM"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Ejecutar"
@@ -685,7 +689,7 @@ msgid "Wait"
msgstr "Espera"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -697,7 +701,7 @@ msgid "Cancel"
msgstr "Cancelar"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/es_CO.po b/locale/es_CO.po
index 6f8dc82..befa86f 100644
--- a/locale/es_CO.po
+++ b/locale/es_CO.po
@@ -677,6 +677,10 @@ msgid "Productions"
msgstr "Producciones"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr ""
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Ejecutar"
@@ -685,7 +689,7 @@ msgid "Wait"
msgstr "Espera"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -697,7 +701,7 @@ msgid "Cancel"
msgstr "Cancelar"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/es_EC.po b/locale/es_EC.po
index 93ff511..e46b929 100644
--- a/locale/es_EC.po
+++ b/locale/es_EC.po
@@ -7,8 +7,8 @@ msgid ""
"You are trying to create a recursive BOM with product \"%s\" which is not "
"allowed."
msgstr ""
-"Está intentando crear una LDM recursiva con el producto \"%s\" que no está "
-"permitido."
+"Está intentando crear una LDM recursiva con el producto \"%s\" lo cual no "
+"está permitido."
msgctxt "error:production.bom.input:"
msgid "Product must be unique per BOM."
@@ -28,7 +28,7 @@ msgstr "El producto debe ser único por LDM."
msgctxt "error:production.bom.output:"
msgid "You can not create recursive BOMs."
-msgstr "No puede crear LDMs recursivas!"
+msgstr "No puede crear LDMs recursivas."
msgctxt "error:production.bom.output:"
msgid "product_bom_uniq"
@@ -52,11 +52,11 @@ msgstr "LDM"
msgctxt "field:product.product-production.bom,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:product.product-production.bom,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:product.product-production.bom,id:"
msgid "ID"
@@ -76,11 +76,11 @@ msgstr "Secuencia"
msgctxt "field:product.product-production.bom,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:product.product-production.bom,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:production,bom:"
msgid "BOM"
@@ -100,11 +100,11 @@ msgstr "Costo"
msgctxt "field:production,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:production,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:production,effective_date:"
msgid "Effective Date"
@@ -160,19 +160,19 @@ msgstr "UdM"
msgctxt "field:production,uom_category:"
msgid "Uom Category"
-msgstr "Categoría UdM"
+msgstr "Categoría de UdM"
msgctxt "field:production,warehouse:"
msgid "Warehouse"
-msgstr "Depósito"
+msgstr "Almacén"
msgctxt "field:production,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:production,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:production.assign.failed,id:"
msgid "ID"
@@ -188,11 +188,11 @@ msgstr "Activo"
msgctxt "field:production.bom,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:production.bom,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:production.bom,id:"
msgid "ID"
@@ -220,11 +220,11 @@ msgstr "Nombre"
msgctxt "field:production.bom,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:production.bom,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:production.bom.input,bom:"
msgid "BOM"
@@ -232,11 +232,11 @@ msgstr "LDM"
msgctxt "field:production.bom.input,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:production.bom.input,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:production.bom.input,id:"
msgid "ID"
@@ -264,15 +264,15 @@ msgstr "UdM"
msgctxt "field:production.bom.input,uom_category:"
msgid "Uom Category"
-msgstr "Categoría UdM"
+msgstr "Categoría de UdM"
msgctxt "field:production.bom.input,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:production.bom.input,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:production.bom.output,bom:"
msgid "BOM"
@@ -280,11 +280,11 @@ msgstr "LDM"
msgctxt "field:production.bom.output,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:production.bom.output,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:production.bom.output,id:"
msgid "ID"
@@ -312,15 +312,15 @@ msgstr "UdM"
msgctxt "field:production.bom.output,uom_category:"
msgid "Uom Category"
-msgstr "Categoría UdM"
+msgstr "Categoría de UdM"
msgctxt "field:production.bom.output,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:production.bom.output,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:production.bom.tree,childs:"
msgid "Childs"
@@ -376,7 +376,7 @@ msgstr "Unidad"
msgctxt "field:production.bom.tree.open.tree,bom_tree:"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt "field:production.bom.tree.open.tree,id:"
msgid "ID"
@@ -384,11 +384,11 @@ msgstr "ID"
msgctxt "field:production.configuration,create_date:"
msgid "Create Date"
-msgstr "Fecha de Creación"
+msgstr "Fecha de creación"
msgctxt "field:production.configuration,create_uid:"
msgid "Create User"
-msgstr "Creado por Usuario"
+msgstr "Creado por usuario"
msgctxt "field:production.configuration,id:"
msgid "ID"
@@ -404,11 +404,11 @@ msgstr "Nombre"
msgctxt "field:production.configuration,write_date:"
msgid "Write Date"
-msgstr "Fecha de Modificación"
+msgstr "Fecha de modificación"
msgctxt "field:production.configuration,write_uid:"
msgid "Write User"
-msgstr "Modificado por Usuario"
+msgstr "Modificado por usuario"
msgctxt "field:stock.location,production_location:"
msgid "Production"
@@ -448,7 +448,7 @@ msgstr "Asignar Producción"
msgctxt "model:ir.action,name:wizard_bom_tree_open"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_all"
@@ -458,7 +458,7 @@ msgstr "Todo"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_assigned"
msgid "Assigned"
-msgstr "Asignado"
+msgstr "Asignada"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_draft"
@@ -490,7 +490,7 @@ msgstr "Producción"
msgctxt "model:ir.ui.menu,name:menu_bom_list"
msgid "BOMs"
-msgstr "Listas de Materiales"
+msgstr "LDMs"
msgctxt "model:ir.ui.menu,name:menu_configuration"
msgid "Configuration"
@@ -538,7 +538,7 @@ msgstr "Salida de Lista de Materiales"
msgctxt "model:production.bom.tree,name:"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt "model:production.bom.tree.open.start,name:"
msgid "Open BOM Tree"
@@ -560,13 +560,14 @@ msgctxt "model:res.group,name:group_production_admin"
msgid "Production Administration"
msgstr "Administración de Producción"
+#, fuzzy
msgctxt "model:stock.location,name:location_production"
msgid "Production"
msgstr "Producción"
msgctxt "selection:production,state:"
msgid "Assigned"
-msgstr "Asignado"
+msgstr "Asignada"
msgctxt "selection:production,state:"
msgid "Canceled"
@@ -582,7 +583,7 @@ msgstr "Borrador"
msgctxt "selection:production,state:"
msgid "Request"
-msgstr "Solicitud"
+msgstr "Solicitada"
msgctxt "selection:production,state:"
msgid "Running"
@@ -610,23 +611,23 @@ msgstr "No se pueden asignar estos productos:"
msgctxt "view:production.bom.input:"
msgid "BOM Inputs"
-msgstr "Entradas LDM"
+msgstr "Entradas de LDM"
msgctxt "view:production.bom.output:"
msgid "BOM Outputs"
-msgstr "Salidas LDM"
+msgstr "Salidas de LDM"
msgctxt "view:production.bom.tree.open.start:"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt "view:production.bom.tree.open.tree:"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt "view:production.bom.tree:"
msgid "BOM Tree"
-msgstr "Árbol LDM"
+msgstr "Árbol de LDM"
msgctxt "view:production.bom:"
msgid "BOM"
@@ -654,7 +655,7 @@ msgstr "Cancelar"
msgctxt "view:production:"
msgid "Done"
-msgstr "Realizado"
+msgstr "Realizada"
msgctxt "view:production:"
msgid "Draft"
@@ -677,15 +678,19 @@ msgid "Productions"
msgstr "Producciones"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Restablecer a LDM"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Ejecutar"
msgctxt "view:production:"
msgid "Wait"
-msgstr "Espera"
+msgstr "En Espera"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -697,7 +702,7 @@ msgid "Cancel"
msgstr "Cancelar"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/es_ES.po b/locale/es_ES.po
index 17a49c1..c78006d 100644
--- a/locale/es_ES.po
+++ b/locale/es_ES.po
@@ -458,7 +458,7 @@ msgstr "Todo"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_assigned"
msgid "Assigned"
-msgstr "Reservado"
+msgstr "Reservada"
msgctxt ""
"model:ir.action.act_window.domain,name:act_production_list_domain_draft"
@@ -574,7 +574,7 @@ msgstr "Cancelada"
msgctxt "selection:production,state:"
msgid "Done"
-msgstr "Realizada"
+msgstr "Finalizada"
msgctxt "selection:production,state:"
msgid "Draft"
@@ -654,7 +654,7 @@ msgstr "Cancelar"
msgctxt "view:production:"
msgid "Done"
-msgstr "Realizado"
+msgstr "Finalizar"
msgctxt "view:production:"
msgid "Draft"
@@ -677,6 +677,10 @@ msgid "Productions"
msgstr "Producciones"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Reestrablecer con la LdM"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Ejecutar"
@@ -685,7 +689,7 @@ msgid "Wait"
msgstr "En espera"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -697,7 +701,7 @@ msgid "Cancel"
msgstr "Cancelar"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Aceptar"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/fr_FR.po b/locale/fr_FR.po
index 8c88e27..608aed8 100644
--- a/locale/fr_FR.po
+++ b/locale/fr_FR.po
@@ -677,6 +677,10 @@ msgid "Productions"
msgstr "Productions"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Réinitialiser à la nomenclature"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Lancer"
@@ -685,8 +689,8 @@ msgid "Wait"
msgstr "Attendre"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
-msgstr "Ok"
+msgid "OK"
+msgstr "OK"
msgctxt "wizard_button:production.assign,failed,force:"
msgid "Force Assign"
@@ -697,8 +701,8 @@ msgid "Cancel"
msgstr "Annuler"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
-msgstr "Ok"
+msgid "OK"
+msgstr "OK"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
msgid "Close"
diff --git a/locale/nl_NL.po b/locale/nl_NL.po
index de6fb5a..65543bf 100644
--- a/locale/nl_NL.po
+++ b/locale/nl_NL.po
@@ -729,7 +729,7 @@ msgstr ""
#, fuzzy
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Oké"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -743,7 +743,7 @@ msgstr "Annuleren"
#, fuzzy
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Oké"
#, fuzzy
diff --git a/locale/ru_RU.po b/locale/ru_RU.po
index a1df564..2e2fab2 100644
--- a/locale/ru_RU.po
+++ b/locale/ru_RU.po
@@ -683,7 +683,7 @@ msgid "Wait"
msgstr "Ожидают"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "Ок"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -695,7 +695,7 @@ msgid "Cancel"
msgstr "Отменить"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "Ок"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/locale/sl_SI.po b/locale/sl_SI.po
index 61440a1..6698994 100644
--- a/locale/sl_SI.po
+++ b/locale/sl_SI.po
@@ -675,6 +675,10 @@ msgid "Productions"
msgstr "Proizvodni nalogi"
msgctxt "view:production:"
+msgid "Reset to BOM"
+msgstr "Ponastavi na kosovnico"
+
+msgctxt "view:production:"
msgid "Run"
msgstr "Izvajanje"
@@ -683,7 +687,7 @@ msgid "Wait"
msgstr "Čakanje"
msgctxt "wizard_button:production.assign,failed,end:"
-msgid "Ok"
+msgid "OK"
msgstr "V redu"
msgctxt "wizard_button:production.assign,failed,force:"
@@ -695,7 +699,7 @@ msgid "Cancel"
msgstr "Prekliči"
msgctxt "wizard_button:production.bom.tree.open,start,tree:"
-msgid "Ok"
+msgid "OK"
msgstr "V redu"
msgctxt "wizard_button:production.bom.tree.open,tree,end:"
diff --git a/product.py b/product.py
index a0ad739..33bcb88 100644
--- a/product.py
+++ b/product.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.model import ModelView, ModelSQL, fields
from trytond.pyson import Eval, Get, If, Bool
from trytond.pool import PoolMeta
diff --git a/production.py b/production.py
index 2abade3..f8ca336 100644
--- a/production.py
+++ b/production.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 decimal import Decimal
from trytond.model import ModelView, ModelSQL, Workflow, fields
@@ -8,6 +8,8 @@ from trytond.pyson import Eval, Bool, If, Id
from trytond.pool import Pool
from trytond.transaction import Transaction
+from trytond.modules.product import price_digits
+
__all__ = ['Production', 'AssignFailed', 'Assign']
BOM_CHANGES = ['bom', 'product', 'quantity', 'uom', 'warehouse', 'location',
@@ -98,28 +100,30 @@ class Production(Workflow, ModelSQL, ModelView):
'invisible': ~Eval('product'),
},
depends=['unit_digits'])
- cost = fields.Function(fields.Numeric('Cost', digits=(16, 4),
+ cost = fields.Function(fields.Numeric('Cost', digits=price_digits,
readonly=True), 'get_cost')
inputs = fields.One2Many('stock.move', 'production_input', 'Inputs',
domain=[
('from_location', 'child_of', [Eval('warehouse')], 'parent'),
('to_location', '=', Eval('location')),
+ ('company', '=', Eval('company', -1)),
],
states={
'readonly': (~Eval('state').in_(['request', 'draft', 'waiting'])
| ~Eval('warehouse') | ~Eval('location')),
},
- depends=['warehouse', 'location'])
+ depends=['warehouse', 'location', 'company'])
outputs = fields.One2Many('stock.move', 'production_output', 'Outputs',
domain=[
('from_location', '=', Eval('location')),
('to_location', 'child_of', [Eval('warehouse')], 'parent'),
+ ('company', '=', Eval('company', -1)),
],
states={
'readonly': (Eval('state').in_(['done', 'cancel'])
| ~Eval('warehouse') | ~Eval('location')),
},
- depends=['warehouse', 'location'])
+ depends=['warehouse', 'location', 'company'])
state = fields.Selection([
('request', 'Request'),
('draft', 'Draft'),
@@ -168,6 +172,10 @@ class Production(Workflow, ModelSQL, ModelView):
'tryton-go-next',
'tryton-go-previous')),
},
+ 'reset_bom': {
+ 'invisible': (~Eval('bom')
+ | ~Eval('state').in_(['request', 'draft', 'waiting'])),
+ },
'wait': {
'invisible': ~Eval('state').in_(['draft', 'assigned',
'waiting', 'running']),
@@ -232,26 +240,12 @@ class Production(Workflow, ModelSQL, ModelView):
def _explode_move_values(self, from_location, to_location, company,
bom_io, quantity):
- pool = Pool()
- Move = pool.get('stock.move')
-
move = self._move(from_location, to_location, company,
bom_io.product, bom_io.uom, quantity)
move.from_location = from_location.id if from_location else None
move.to_location = to_location.id if to_location else None
move.unit_price_required = move.on_change_with_unit_price_required()
- values = {}
- for field_name, field in Move._fields.iteritems():
- try:
- value = getattr(move, field_name)
- except AttributeError:
- continue
- if value and field._type in ('many2one', 'one2one'):
- values[field_name] = value.id
- values[field_name + '.rec_name'] = value.rec_name
- else:
- values[field_name] = value
- return values
+ return move
def explode_bom(self):
pool = Pool()
@@ -259,20 +253,8 @@ class Production(Workflow, ModelSQL, ModelView):
Template = pool.get('product.template')
Product = pool.get('product.product')
if not (self.bom and self.product and self.uom):
- return {}
- inputs = {
- 'remove': [r.id for r in self.inputs or []],
- 'add': [],
- }
- outputs = {
- 'remove': [r.id for r in self.outputs or []],
- 'add': [],
- }
- changes = {
- 'inputs': inputs,
- 'outputs': outputs,
- 'cost': Decimal(0),
- }
+ return
+ self.cost = Decimal(0)
if self.warehouse:
storage_location = self.warehouse.storage_location
@@ -281,64 +263,55 @@ class Production(Workflow, ModelSQL, ModelView):
factor = self.bom.compute_factor(self.product, self.quantity or 0,
self.uom)
+ inputs = []
for input_ in self.bom.inputs:
quantity = input_.compute_quantity(factor)
- values = self._explode_move_values(storage_location, self.location,
+ move = self._explode_move_values(storage_location, self.location,
self.company, input_, quantity)
- if values:
- inputs['add'].append((-1, values))
+ if move:
+ inputs.append(move)
quantity = Uom.compute_qty(input_.uom, quantity,
input_.product.default_uom)
- changes['cost'] += (Decimal(str(quantity)) *
+ self.cost += (Decimal(str(quantity)) *
input_.product.cost_price)
+ self.inputs = inputs
if hasattr(Product, 'cost_price'):
digits = Product.cost_price.digits
else:
digits = Template.cost_price.digits
+ outputs = []
for output in self.bom.outputs:
quantity = output.compute_quantity(factor)
- values = self._explode_move_values(self.location, storage_location,
+ move = self._explode_move_values(self.location, storage_location,
self.company, output, quantity)
- if values:
- values['unit_price'] = Decimal(0)
- if output.product.id == values.get('product') and quantity:
- values['unit_price'] = Decimal(
- changes['cost'] / Decimal(str(quantity))
+ if move:
+ move.unit_price = Decimal(0)
+ if output.product == move.product and quantity:
+ move.unit_price = Decimal(
+ self.cost / Decimal(str(quantity))
).quantize(Decimal(str(10 ** -digits[1])))
- outputs['add'].append((-1, values))
- return changes
+ outputs.append(move)
+ self.outputs = outputs
@fields.depends('warehouse')
def on_change_warehouse(self):
- changes = {
- 'location': None,
- }
+ self.location = None
if self.warehouse:
- changes['location'] = self.warehouse.production_location.id
- return changes
+ self.location = self.warehouse.production_location
@fields.depends(*BOM_CHANGES)
def on_change_product(self):
- result = {}
if self.product:
uoms = self.product.default_uom.category.uoms
if (not self.uom or self.uom not in uoms):
- result['uom'] = self.product.default_uom.id
- result['uom.rec_name'] = self.product.default_uom.rec_name
- result['unit_digits'] = self.product.default_uom.digits
+ self.uom = self.product.default_uom
+ self.unit_digits = self.product.default_uom.digits
else:
- result['bom'] = None
- result['uom'] = None
- result['uom.rec_name'] = ''
- result['unit_digits'] = 2
-
- if 'uom' in result:
- self.uom = result['uom']
- if 'bom' in result:
- self.bom = result['bom']
- result.update(self.explode_bom())
- return result
+ self.bom = None
+ self.uom = None
+ self.unit_digits = 2
+ self.explode_bom()
@fields.depends('product')
def on_change_with_uom_category(self, name=None):
@@ -353,15 +326,19 @@ class Production(Workflow, ModelSQL, ModelView):
@fields.depends(*BOM_CHANGES)
def on_change_bom(self):
- return self.explode_bom()
+ self.explode_bom()
@fields.depends(*BOM_CHANGES)
def on_change_uom(self):
- return self.explode_bom()
+ self.explode_bom()
@fields.depends(*BOM_CHANGES)
def on_change_quantity(self):
- return self.explode_bom()
+ self.explode_bom()
+
+ @ModelView.button_change(*BOM_CHANGES)
+ def reset_bom(self):
+ self.explode_bom()
def get_cost(self, name):
cost = Decimal(0)
@@ -371,7 +348,9 @@ class Production(Workflow, ModelSQL, ModelView):
else:
cost_price = input_.product.cost_price
cost += (Decimal(str(input_.internal_quantity)) * cost_price)
- return cost
+
+ digits = self.__class__.cost.digits
+ return cost.quantize(Decimal(str(10 ** -digits[1])))
@fields.depends('inputs')
def on_change_with_cost(self):
@@ -610,7 +589,7 @@ class Assign(Wizard):
'group_stock_force_assignment').in_(
Eval('context', {}).get('groups', [])),
}),
- Button('Ok', 'end', 'tryton-ok', True),
+ Button('OK', 'end', 'tryton-ok', True),
])
force = StateTransition()
diff --git a/production.xml b/production.xml
index 62b119e..f926692 100644
--- a/production.xml
+++ b/production.xml
@@ -92,35 +92,35 @@ this repository contains the full copyright notices and license terms. -->
id="act_production_list_domain_requests">
<field name="name">Requests</field>
<field name="sequence" eval="10"/>
- <field name="domain">[('state', '=', 'request')]</field>
+ <field name="domain" eval="[('state', '=', 'request')]" pyson="1"/>
<field name="act_window" ref="act_production_list"/>
</record>
<record model="ir.action.act_window.domain"
id="act_production_list_domain_draft">
<field name="name">Draft</field>
<field name="sequence" eval="20"/>
- <field name="domain">[('state', '=', 'draft')]</field>
+ <field name="domain" eval="[('state', '=', 'draft')]" pyson="1"/>
<field name="act_window" ref="act_production_list"/>
</record>
<record model="ir.action.act_window.domain"
id="act_production_list_domain_waiting">
<field name="name">Waiting</field>
<field name="sequence" eval="30"/>
- <field name="domain">[('state', '=', 'waiting')]</field>
+ <field name="domain" eval="[('state', '=', 'waiting')]" pyson="1"/>
<field name="act_window" ref="act_production_list"/>
</record>
<record model="ir.action.act_window.domain"
id="act_production_list_domain_assigned">
<field name="name">Assigned</field>
<field name="sequence" eval="30"/>
- <field name="domain">[('state', '=', 'assigned')]</field>
+ <field name="domain" eval="[('state', '=', 'assigned')]" pyson="1"/>
<field name="act_window" ref="act_production_list"/>
</record>
<record model="ir.action.act_window.domain"
id="act_production_list_domain_running">
<field name="name">Running</field>
<field name="sequence" eval="30"/>
- <field name="domain">[('state', '=', 'running')]</field>
+ <field name="domain" eval="[('state', '=', 'running')]" pyson="1"/>
<field name="act_window" ref="act_production_list"/>
</record>
<record model="ir.action.act_window.domain"
@@ -194,7 +194,9 @@ this repository contains the full copyright notices and license terms. -->
<field name="global_p" eval="True"/>
</record>
<record model="ir.rule" id="rule_production">
- <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_production"/>
</record>
diff --git a/setup.py b/setup.py
index 6c4f259..448b01c 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
@@ -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',
],
license='GPL-3',
diff --git a/stock.py b/stock.py
index 0985784..71e3780 100644
--- a/stock.py
+++ b/stock.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.model import fields
from trytond.pyson import Eval
from trytond.pool import PoolMeta
diff --git a/tests/__init__.py b/tests/__init__.py
index e64267e..b968fe3 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_production import suite
diff --git a/tests/scenario_production.rst b/tests/scenario_production.rst
index 29fc30d..3d5eaf0 100644
--- a/tests/scenario_production.rst
+++ b/tests/scenario_production.rst
@@ -2,16 +2,15 @@
Production Scenario
===================
-=============
-General Setup
-=============
-
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.production.production import BOM_CHANGES
>>> today = datetime.date.today()
>>> yesterday = today - relativedelta(days=1)
@@ -23,35 +22,14 @@ Create database::
Install production Module::
>>> Module = Model.get('ir.module.module')
- >>> modules = Module.find([('name', '=', 'production')])
- >>> Module.install([x.id for x in modules], config.context)
+ >>> module, = Module.find([('name', '=', 'production')])
+ >>> module.click('install')
>>> Wizard('ir.module.module.install_upgrade').execute('upgrade')
Create company::
- >>> Currency = Model.get('currency.currency')
- >>> CurrencyRate = Model.get('currency.currency.rate')
- >>> 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
- >>> currencies = Currency.find([('code', '=', 'USD')])
- >>> if not currencies:
- ... currency = Currency(name='Euro', symbol=u'$', code='USD',
- ... rounding=Decimal('0.01'), mon_grouping='[3, 3, 0]',
- ... mon_decimal_point=',')
- ... currency.save()
- ... CurrencyRate(date=today + relativedelta(month=1, day=1),
- ... rate=Decimal('1.0'), currency=currency).save()
- ... else:
- ... currency, = currencies
- >>> company.currency = currency
- >>> company_config.execute('add')
- >>> company, = Company.find()
+ >>> _ = create_company()
+ >>> company = get_company()
Reload the context::
@@ -144,8 +122,7 @@ Create an Inventory::
>>> inventory.lines.append(inventory_line2)
>>> inventory_line2.product = component2
>>> inventory_line2.quantity = 6
- >>> inventory.save()
- >>> Inventory.confirm([inventory.id], config.context)
+ >>> inventory.click('confirm')
>>> inventory.state
u'done'
@@ -163,23 +140,33 @@ Make a production::
True
>>> production.cost
Decimal('25.0')
- >>> production.save()
- >>> Production.wait([production.id], config.context)
+ >>> production.click('wait')
>>> production.state
u'waiting'
- >>> Production.assign_try([production.id], config.context)
+
+Test reset bom button::
+
+ >>> for input in production.inputs:
+ ... input.quantity += 1
+ >>> production.click('reset_bom', change=BOM_CHANGES)
+ >>> sorted([i.quantity for i in production.inputs]) == [10, 300]
+ True
+ >>> output, = production.outputs
+ >>> output.quantity == 2
+ True
+
+Do the production::
+
+ >>> production.click('assign_try')
True
- >>> production.reload()
>>> all(i.state == 'assigned' for i in production.inputs)
True
- >>> Production.run([production.id], config.context)
- >>> production.reload()
+ >>> production.click('run')
>>> all(i.state == 'done' for i in production.inputs)
True
>>> len(set(i.effective_date == today for i in production.inputs))
1
- >>> Production.done([production.id], config.context)
- >>> production.reload()
+ >>> production.click('done')
>>> output, = production.outputs
>>> output.state
u'done'
@@ -199,7 +186,7 @@ Make a production with effective date yesterday::
>>> production.bom = bom
>>> production.quantity = 2
>>> production.click('wait')
- >>> Production.assign_try([production.id], config.context)
+ >>> production.click('assign_try')
True
>>> production.click('run')
>>> production.reload()
diff --git a/tests/test_production.py b/tests/test_production.py
index 4ae51cd..6f8bc89 100644
--- a/tests/test_production.py
+++ b/tests/test_production.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 ProductionTestCase(unittest.TestCase):
+class ProductionTestCase(ModuleTestCase):
'Test Production module'
-
- def setUp(self):
- trytond.tests.test_tryton.install_module('production')
-
- def test0005views(self):
- 'Test views'
- test_view('production')
-
- def test0006depends(self):
- 'Test depends'
- test_depends()
+ module = 'production'
def suite():
diff --git a/tryton.cfg b/tryton.cfg
index a07c766..f859a44 100644
--- a/tryton.cfg
+++ b/tryton.cfg
@@ -1,5 +1,5 @@
[tryton]
-version=3.4.1
+version=3.6.0
depends:
company
ir
diff --git a/trytond_production.egg-info/PKG-INFO b/trytond_production.egg-info/PKG-INFO
index c12f269..60e2657 100644
--- a/trytond_production.egg-info/PKG-INFO
+++ b/trytond_production.egg-info/PKG-INFO
@@ -1,12 +1,12 @@
Metadata-Version: 1.1
Name: trytond-production
-Version: 3.4.1
+Version: 3.6.0
Summary: Tryton module for production
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_production
==================
@@ -65,4 +65,6 @@ 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
diff --git a/trytond_production.egg-info/requires.txt b/trytond_production.egg-info/requires.txt
index e8d951f..aabd087 100644
--- a/trytond_production.egg-info/requires.txt
+++ b/trytond_production.egg-info/requires.txt
@@ -1,4 +1,4 @@
-trytond_company >= 3.4, < 3.5
-trytond_product >= 3.4, < 3.5
-trytond_stock >= 3.4, < 3.5
-trytond >= 3.4, < 3.5
\ No newline at end of file
+trytond_company >= 3.6, < 3.7
+trytond_product >= 3.6, < 3.7
+trytond_stock >= 3.6, < 3.7
+trytond >= 3.6, < 3.7
\ No newline at end of file
diff --git a/view/production_form.xml b/view/production_form.xml
index e80999b..658606d 100644
--- a/view/production_form.xml
+++ b/view/production_form.xml
@@ -38,10 +38,12 @@ this repository contains the full copyright notices and license terms. -->
<group col="4" colspan="4" id="state_buttons">
<label name="state"/>
<field name="state"/>
- <group col="6" colspan="2" id="buttons">
+ <group col="7" colspan="2" id="buttons">
<button name="cancel" string="Cancel"
icon="tryton-cancel"/>
<button name="draft" string="Draft"/>
+ <button name="reset_bom" string="Reset to BOM"
+ icon="tryton-clear"/>
<button name="wait" string="Wait"/>
<button name="assign_wizard" string="Assign"
icon="tryton-go-next"/>
--
tryton-modules-production
More information about the tryton-debian-vcs
mailing list