[IMP] remote_report_to_printer: black, isort, prettier

This commit is contained in:
Olga Marco
2021-06-17 16:57:44 +02:00
parent d9c59279a7
commit 70d06c60c4
10 changed files with 207 additions and 222 deletions

View File

@@ -2,18 +2,18 @@
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
{ {
'name': "Report to printer on remotes", "name": "Report to printer on remotes",
'version': '12.0.2.1.1', "version": "13.0.1.0.0",
'category': 'Generic Modules/Base', "category": "Generic Modules/Base",
'author': "Creu Blanca, Odoo Community Association (OCA)", "author": "Creu Blanca, Odoo Community Association (OCA)",
'website': 'http://www.github.com/OCA/report-print-send', "website": "http://www.github.com/OCA/report-print-send",
'license': 'AGPL-3', "license": "AGPL-3",
"depends": ['base_remote', 'base_report_to_printer'], "depends": ["base_remote", "base_report_to_printer"],
'data': [ "data": [
'data/printing_data.xml', "data/printing_data.xml",
'security/ir.model.access.csv', "security/ir.model.access.csv",
'views/res_remote_views.xml', "views/res_remote_views.xml",
'views/res_remote_printer_views.xml', "views/res_remote_printer_views.xml",
], ],
'installable': True, "installable": True,
} }

View File

@@ -1,11 +1,9 @@
<?xml version="1.0"?> <?xml version="1.0" ?>
<odoo noupdate="1"> <odoo noupdate="1">
<record model="printing.action" id="printing_action_remote"> <record model="printing.action" id="printing_action_remote">
<field name="name">Use Remote Defaults</field> <field name="name">Use Remote Defaults</field>
<field name="action_type">remote_default</field> <field name="action_type">remote_default</field>
</record> </record>
<record model="printing.action" id="printing_action_3"> <record model="printing.action" id="printing_action_3">
<field name="name">Use User Defaults</field> <field name="name">Use User Defaults</field>
<field name="action_type">user_default</field> <field name="action_type">user_default</field>

View File

@@ -5,18 +5,18 @@ from odoo import api, models
class IrActionsReport(models.Model): class IrActionsReport(models.Model):
_inherit = 'ir.actions.report' _inherit = "ir.actions.report"
@api.multi @api.multi
def _get_user_default_print_behaviour(self): def _get_user_default_print_behaviour(self):
res = super()._get_user_default_print_behaviour() res = super()._get_user_default_print_behaviour()
if res.get('action', 'unknown') == 'remote_default': if res.get("action", "unknown") == "remote_default":
res.update(self.remote.get_printer_behaviour()) res.update(self.remote.get_printer_behaviour())
return res return res
@api.multi @api.multi
def _get_report_default_print_behaviour(self): def _get_report_default_print_behaviour(self):
res = super()._get_report_default_print_behaviour() res = super()._get_report_default_print_behaviour()
if res.get('action', 'unknown') == 'remote_default': if res.get("action", "unknown") == "remote_default":
res.update(self.remote.get_printer_behaviour()) res.update(self.remote.get_printer_behaviour())
return res return res

View File

@@ -5,14 +5,12 @@ from odoo import api, fields, models
class PrintingAction(models.Model): class PrintingAction(models.Model):
_inherit = 'printing.action' _inherit = "printing.action"
@api.model @api.model
def _available_action_types(self): def _available_action_types(self):
res = super()._available_action_types() res = super()._available_action_types()
res.append(('remote_default', "Use remote's default")) res.append(("remote_default", "Use remote's default"))
return res return res
action_type = fields.Selection( action_type = fields.Selection(selection=_available_action_types,)
selection=_available_action_types,
)

View File

@@ -4,25 +4,24 @@ from odoo import api, fields, models
class ResRemote(models.Model): class ResRemote(models.Model):
_inherit = 'res.remote' _inherit = "res.remote"
remote_printer_ids = fields.One2many( remote_printer_ids = fields.One2many(
'res.remote.printer', "res.remote.printer", inverse_name="remote_id",
inverse_name='remote_id',
) )
@api.multi @api.multi
def get_printer_behaviour(self): def get_printer_behaviour(self):
self.ensure_one() self.ensure_one()
printer_usage = self.env.context.get('printer_usage', 'standard') printer_usage = self.env.context.get("printer_usage", "standard")
printers = self.remote.remote_printer_ids.filtered( printers = self.remote.remote_printer_ids.filtered(
lambda r: r.printer_usage == printer_usage lambda r: r.printer_usage == printer_usage
).sorted(key='is_default', reverse=True) ).sorted(key="is_default", reverse=True)
if printers: if printers:
printer = printers[0] printer = printers[0]
return { return {
'action': 'server', "action": "server",
'printer': printer.printer_id, "printer": printer.printer_id,
'tray': printer.printer_tray_id.system_name "tray": printer.printer_tray_id.system_name,
} }
return {'action': 'client'} return {"action": "client"}

View File

@@ -1,49 +1,41 @@
# Copyright (c) 2018 Creu Blanca # Copyright (c) 2018 Creu Blanca
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo import api, fields, models, _ from odoo import _, api, fields, models
from odoo.exceptions import ValidationError from odoo.exceptions import ValidationError
class ResRemotePrinter(models.Model): class ResRemotePrinter(models.Model):
_name = 'res.remote.printer' _name = "res.remote.printer"
_description = 'Remote Printer' _description = "Remote Printer"
remote_id = fields.Many2one( remote_id = fields.Many2one("res.remote", ondelete="cascade", readonly=True,)
'res.remote', printer_id = fields.Many2one("printing.printer", ondelete="cascade",)
ondelete='cascade',
readonly=True,
)
printer_id = fields.Many2one(
'printing.printer',
ondelete='cascade',
)
printer_tray_id = fields.Many2one( printer_tray_id = fields.Many2one(
'printing.tray', "printing.tray", ondelete="cascade", domain="[('printer_id', '=', printer_id)]",
ondelete='cascade',
domain="[('printer_id', '=', printer_id)]",
) )
is_default = fields.Boolean(default=False) is_default = fields.Boolean(default=False)
printer_usage = fields.Selection([ printer_usage = fields.Selection([("standard", "Standard")], default="standard")
('standard', 'Standard')
], default='standard')
_sql_constraints = [ _sql_constraints = [
('unique_printer_remote_usage', (
'unique(remote_id,printer_id,printer_usage)', "unique_printer_remote_usage",
'A Remote cannot have the same printer for the same usage') "unique(remote_id,printer_id,printer_usage)",
"A Remote cannot have the same printer for the same usage",
)
] ]
@api.onchange('printer_id') @api.onchange("printer_id")
def _onchange_printing_printer_id(self): def _onchange_printing_printer_id(self):
""" Reset the tray when the printer is changed """ """ Reset the tray when the printer is changed """
self.printer_tray_id = False self.printer_tray_id = False
@api.multi @api.multi
@api.constrains('remote_id', 'printer_usage', 'is_default') @api.constrains("remote_id", "printer_usage", "is_default")
def _check_remote_usage(self): def _check_remote_usage(self):
for rec in self.filtered(lambda r: r.is_default): for rec in self.filtered(lambda r: r.is_default):
if rec.remote_id.remote_printer_ids.filtered( if rec.remote_id.remote_printer_ids.filtered(
lambda r: r != rec and r.is_default lambda r: r != rec
and r.is_default
and r.printer_usage == rec.printer_usage and r.printer_usage == rec.printer_usage
): ):
raise ValidationError(_('Only one default printer is allowed')) raise ValidationError(_("Only one default printer is allowed"))

View File

@@ -1,106 +1,89 @@
# Copyright (c) 2018 Creu Blanca # Copyright (c) 2018 Creu Blanca
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo.tests.common import TransactionCase
from mock import patch from mock import patch
from odoo.tests.common import TransactionCase
class TestRemotePrinter(TransactionCase): class TestRemotePrinter(TransactionCase):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
name = 'testing_remote_server' name = "testing_remote_server"
self.remote = self.env['res.remote'].search([('name', '=', name)]) self.remote = self.env["res.remote"].search([("name", "=", name)])
if not self.remote: if not self.remote:
self.remote = self.env['res.remote'].create({ self.remote = self.env["res.remote"].create(
'name': name, {"name": name, "ip": "127.0.0.1"}
'ip': '127.0.0.1', )
}) self.server = self.env["printing.server"].create(
self.server = self.env['printing.server'].create({ {"name": "Server", "address": "localhost", "port": 631}
'name': 'Server', )
'address': 'localhost', self.printer_1 = self.env["printing.printer"].create(
'port': 631, {"name": "Printer 1", "system_name": "P1", "server_id": self.server.id}
}) )
self.printer_1 = self.env['printing.printer'].create({ self.remote_printer = self.env["res.remote.printer"].create(
'name': 'Printer 1', {
'system_name': 'P1', "remote_id": self.remote.id,
'server_id': self.server.id, "printer_id": self.printer_1.id,
}) "is_default": True,
self.remote_printer = self.env['res.remote.printer'].create({ }
'remote_id': self.remote.id, )
'printer_id': self.printer_1.id, self.Model = self.env["ir.actions.report"]
'is_default': True, self.report = self.env["ir.actions.report"].search([], limit=1)
})
self.Model = self.env['ir.actions.report']
self.report = self.env['ir.actions.report'].search([], limit=1)
def test_behaviour_user_remote_values(self): def test_behaviour_user_remote_values(self):
report = self.Model.search([], limit=1) report = self.Model.search([], limit=1)
self.env.user.printing_action = 'remote_default' self.env.user.printing_action = "remote_default"
with patch( with patch("odoo.addons.base_remote.models.base.Base.remote", new=self.remote):
'odoo.addons.base_remote.models.base.Base.remote', new=self.remote
):
behaviour = report.behaviour() behaviour = report.behaviour()
self.assertEqual(behaviour, { self.assertEqual(
'action': 'client', behaviour, {"action": "client", "printer": self.printer_1, "tray": False}
'printer': self.printer_1, )
'tray': False,
})
def test_behaviour_report_values(self): def test_behaviour_report_values(self):
report = self.Model.search([], limit=1) report = self.Model.search([], limit=1)
self.env.user.printing_action = 'client' self.env.user.printing_action = "client"
report.property_printing_action_id = self.browse_ref( report.property_printing_action_id = self.browse_ref(
'remote_report_to_printer.printing_action_remote' "remote_report_to_printer.printing_action_remote"
) )
with patch( with patch("odoo.addons.base_remote.models.base.Base.remote", new=self.remote):
'odoo.addons.base_remote.models.base.Base.remote', new=self.remote
):
behaviour = report.behaviour() behaviour = report.behaviour()
self.assertDictEqual(behaviour, { self.assertDictEqual(
'action': 'server', behaviour, {"action": "server", "printer": self.printer_1, "tray": False}
'printer': self.printer_1, )
'tray': False,
})
def test_behaviour_user_action(self): def test_behaviour_user_action(self):
report = self.Model.search([], limit=1) report = self.Model.search([], limit=1)
self.env.user.printing_action = 'remote_default' self.env.user.printing_action = "remote_default"
report.property_printing_action_id = self.browse_ref( report.property_printing_action_id = self.browse_ref(
'remote_report_to_printer.printing_action_3' "remote_report_to_printer.printing_action_3"
) )
with patch( with patch("odoo.addons.base_remote.models.base.Base.remote", new=self.remote):
'odoo.addons.base_remote.models.base.Base.remote', new=self.remote
):
behaviour = report.behaviour() behaviour = report.behaviour()
self.assertEqual(behaviour, { self.assertEqual(
'action': 'server', behaviour, {"action": "server", "printer": self.printer_1, "tray": False}
'printer': self.printer_1, )
'tray': False,
})
def test_behaviour_default_action(self): def test_behaviour_default_action(self):
report = self.Model.search([], limit=1) report = self.Model.search([], limit=1)
self.env.user.printing_action = 'client' self.env.user.printing_action = "client"
with patch( with patch("odoo.addons.base_remote.models.base.Base.remote", new=self.remote):
'odoo.addons.base_remote.models.base.Base.remote', new=self.remote
):
behaviour = report.behaviour() behaviour = report.behaviour()
self.assertEqual(behaviour, { self.assertEqual(
'action': 'client', behaviour,
'printer': self.env['printing.printer'], {
'tray': False, "action": "client",
}) "printer": self.env["printing.printer"],
"tray": False,
},
)
def test_behaviour_no_printers(self): def test_behaviour_no_printers(self):
self.remote_printer.unlink() self.remote_printer.unlink()
report = self.Model.search([], limit=1) report = self.Model.search([], limit=1)
self.env.user.printing_action = 'remote_default' self.env.user.printing_action = "remote_default"
report.property_printing_action_id = self.browse_ref( report.property_printing_action_id = self.browse_ref(
'remote_report_to_printer.printing_action_3' "remote_report_to_printer.printing_action_3"
) )
with patch( with patch("odoo.addons.base_remote.models.base.Base.remote", new=self.remote):
'odoo.addons.base_remote.models.base.Base.remote',
new=self.remote
):
behaviour = report.behaviour() behaviour = report.behaviour()
self.assertEqual(behaviour['action'], 'client') self.assertEqual(behaviour["action"], "client")

View File

@@ -1,115 +1,130 @@
# Copyright (c) 2018 Creu Blanca # Copyright (c) 2018 Creu Blanca
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo.exceptions import AccessError, ValidationError
from odoo.tests.common import TransactionCase from odoo.tests.common import TransactionCase
from odoo.exceptions import ValidationError
from odoo.exceptions import AccessError
class TestRemotePrinter(TransactionCase): class TestRemotePrinter(TransactionCase):
def setUp(self): def setUp(self):
super().setUp() super().setUp()
self.system_user_group = self.env.ref('base.group_system') self.system_user_group = self.env.ref("base.group_system")
self.user_group = self.env.ref('base.group_user') self.user_group = self.env.ref("base.group_user")
self.printer_manager = self._create_user('printer_manager', self.printer_manager = self._create_user(
self.system_user_group.id) "printer_manager", self.system_user_group.id
self.printer_user = self._create_user('printer_user', )
self.user_group.id) self.printer_user = self._create_user("printer_user", self.user_group.id)
name = 'testing_remote_server' name = "testing_remote_server"
self.remote = self.env['res.remote'].search([('name', '=', name)]) self.remote = self.env["res.remote"].search([("name", "=", name)])
if not self.remote: if not self.remote:
self.remote = self.env['res.remote'].create({ self.remote = self.env["res.remote"].create(
'name': name, {"name": name, "ip": "127.0.0.1"}
'ip': '127.0.0.1', )
}) self.server = self.env["printing.server"].create(
self.server = self.env['printing.server'].create({ {"name": "Server", "address": "localhost", "port": 631}
'name': 'Server', )
'address': 'localhost', self.printer_1 = self.env["printing.printer"].create(
'port': 631, {"name": "Printer 1", "system_name": "P1", "server_id": self.server.id}
}) )
self.printer_1 = self.env['printing.printer'].create({ self.printer_2 = self.env["printing.printer"].create(
'name': 'Printer 1', {"name": "Printer 2", "system_name": "P2", "server_id": self.server.id}
'system_name': 'P1', )
'server_id': self.server.id, self.tray_1 = self.env["printing.tray"].create(
}) {"name": "Tray", "system_name": "P2", "printer_id": self.printer_1.id}
self.printer_2 = self.env['printing.printer'].create({ )
'name': 'Printer 2',
'system_name': 'P2',
'server_id': self.server.id,
})
self.tray_1 = self.env['printing.tray'].create({
'name': 'Tray',
'system_name': 'P2',
'printer_id': self.printer_1.id,
})
def _create_user(self, name, group_ids): def _create_user(self, name, group_ids):
return self.env['res.users'].with_context( return (
{'no_reset_password': True}).create( self.env["res.users"]
{'name': name, .with_context({"no_reset_password": True})
'password': 'demo', .create(
'login': name, {
'email': '@'.join([name, '@test.com']), "name": name,
'groups_id': [(6, 0, [group_ids])] "password": "demo",
}) "login": name,
"email": "@".join([name, "@test.com"]),
"groups_id": [(6, 0, [group_ids])],
}
)
)
def test_constrain(self): def test_constrain(self):
self.env['res.remote.printer'].sudo(self.printer_manager).create({ self.env["res.remote.printer"].sudo(self.printer_manager).create(
'remote_id': self.remote.id, {
'printer_id': self.printer_1.id, "remote_id": self.remote.id,
'is_default': True, "printer_id": self.printer_1.id,
}) "is_default": True,
}
)
with self.assertRaises(ValidationError): with self.assertRaises(ValidationError):
self.env['res.remote.printer'].create({ self.env["res.remote.printer"].create(
'remote_id': self.remote.id, {
'printer_id': self.printer_2.id, "remote_id": self.remote.id,
'is_default': True, "printer_id": self.printer_2.id,
}) "is_default": True,
}
)
def test_onchange_printer(self): def test_onchange_printer(self):
remote_printer = self.env['res.remote.printer'].sudo( remote_printer = (
self.printer_manager).create({ self.env["res.remote.printer"]
'remote_id': self.remote.id, .sudo(self.printer_manager)
'printer_id': self.printer_1.id, .create(
'printer_tray_id': self.tray_1.id, {
}) "remote_id": self.remote.id,
"printer_id": self.printer_1.id,
"printer_tray_id": self.tray_1.id,
}
)
)
self.assertTrue(remote_printer.printer_tray_id) self.assertTrue(remote_printer.printer_tray_id)
remote_printer.printer_id = self.printer_2 remote_printer.printer_id = self.printer_2
remote_printer._onchange_printing_printer_id() remote_printer._onchange_printing_printer_id()
self.assertFalse(remote_printer.printer_tray_id) self.assertFalse(remote_printer.printer_tray_id)
def test_permissions_delete_manager(self): def test_permissions_delete_manager(self):
printer = self.env['res.remote.printer'].sudo( printer = (
self.printer_manager).create({ self.env["res.remote.printer"]
'remote_id': self.remote.id, .sudo(self.printer_manager)
'printer_id': self.printer_1.id, .create(
'is_default': True, {
"remote_id": self.remote.id,
"printer_id": self.printer_1.id,
"is_default": True,
} }
) )
)
printer.sudo(self.printer_manager).unlink() printer.sudo(self.printer_manager).unlink()
printer = self.env['res.remote.printer'].search([ printer = self.env["res.remote.printer"].search(
('remote_id', '=', self.remote.id), [
('printer_id', '=', self.printer_1.id)], limit=1) ("remote_id", "=", self.remote.id),
self.assertEquals(printer, self.env['res.remote.printer']) ("printer_id", "=", self.printer_1.id),
],
limit=1,
)
self.assertEquals(printer, self.env["res.remote.printer"])
def test_permissions_delete_user(self): def test_permissions_delete_user(self):
printer = self.env['res.remote.printer'].sudo( printer = (
self.printer_manager).create({ self.env["res.remote.printer"]
'remote_id': self.remote.id, .sudo(self.printer_manager)
'printer_id': self.printer_1.id, .create(
'is_default': True, {
"remote_id": self.remote.id,
"printer_id": self.printer_1.id,
"is_default": True,
} }
) )
)
with self.assertRaises(AccessError): with self.assertRaises(AccessError):
printer.sudo(self.printer_user).unlink() printer.sudo(self.printer_user).unlink()
def test_permissions_create_user(self): def test_permissions_create_user(self):
with self.assertRaises(AccessError): with self.assertRaises(AccessError):
self.env['res.remote.printer'].sudo( self.env["res.remote.printer"].sudo(self.printer_user).create(
self.printer_user).create({ {
'remote_id': self.remote.id, "remote_id": self.remote.id,
'printer_id': self.printer_1.id, "printer_id": self.printer_1.id,
'is_default': True, "is_default": True,
} }
) )

View File

@@ -7,11 +7,11 @@
<form string="Remote Printer"> <form string="Remote Printer">
<sheet> <sheet>
<group> <group>
<field name="printer_id"/> <field name="printer_id" />
<field name="printer_tray_id"/> <field name="printer_tray_id" />
<field name="printer_usage"/> <field name="printer_usage" />
<field name="is_default"/> <field name="is_default" />
<field name="remote_id"/> <field name="remote_id" />
</group> </group>
</sheet> </sheet>
</form> </form>
@@ -22,11 +22,11 @@
<field name="model">res.remote.printer</field> <field name="model">res.remote.printer</field>
<field name="arch" type="xml"> <field name="arch" type="xml">
<tree string="Remote Printers" editable="bottom"> <tree string="Remote Printers" editable="bottom">
<field name="printer_id"/> <field name="printer_id" />
<field name="printer_tray_id"/> <field name="printer_tray_id" />
<field name="is_default"/> <field name="is_default" />
<field name="printer_usage"/> <field name="printer_usage" />
<field name="remote_id" invisible="1"/> <field name="remote_id" invisible="1" />
</tree> </tree>
</field> </field>
</record> </record>

View File

@@ -3,11 +3,11 @@
<record id="res_remote_form" model="ir.ui.view"> <record id="res_remote_form" model="ir.ui.view">
<field name="name">res.remote.form</field> <field name="name">res.remote.form</field>
<field name="model">res.remote</field> <field name="model">res.remote</field>
<field name="inherit_id" ref="base_remote.res_remote_form"/> <field name="inherit_id" ref="base_remote.res_remote_form" />
<field name="arch" type="xml"> <field name="arch" type="xml">
<notebook position="inside"> <notebook position="inside">
<page name="printers" string="Printers"> <page name="printers" string="Printers">
<field name="remote_printer_ids"/> <field name="remote_printer_ids" />
</page> </page>
</notebook> </notebook>
</field> </field>