[MIG] auto_backup: Migration to 17.0
parent
8b2728e20a
commit
72121cc6b4
|
@ -107,8 +107,9 @@ Known issues / Roadmap
|
|||
- On larger databases, it is possible that backups will die due to Odoo
|
||||
server settings. In order to circumvent this without frivolously
|
||||
changing settings, you need to run the backup from outside of the main
|
||||
Odoo instance. How to do this is outlined in `this blog
|
||||
post <https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/>`__.
|
||||
Odoo instance. How to do this (for version 9.0) was outlined in `this
|
||||
blog
|
||||
post <https://web.archive.org/web/20240805225230/https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/>`__.
|
||||
- Backups won't work if list_db=False is configured in the instance.
|
||||
|
||||
Bug Tracker
|
||||
|
|
|
@ -6,7 +6,7 @@
|
|||
{
|
||||
"name": "Database Auto-Backup",
|
||||
"summary": "Backups database",
|
||||
"version": "16.0.1.0.0",
|
||||
"version": "17.0.1.0.0",
|
||||
"author": "Yenthe Van Ginneken, "
|
||||
"Agile Business Group, "
|
||||
"Grupo ESOC Ingenieria de Servicios, "
|
||||
|
|
|
@ -216,8 +216,7 @@ class DbBackup(models.Model):
|
|||
_logger.exception("Database backup failed: %s", self.name)
|
||||
escaped_tb = tools.html_escape(traceback.format_exc())
|
||||
self.message_post( # pylint: disable=translation-required
|
||||
body="<p>%s</p><pre>%s</pre>"
|
||||
% (_("Database backup failed."), escaped_tb),
|
||||
body=f"<p>{_('Database backup failed.')}</p><pre>{escaped_tb}</pre>",
|
||||
subtype_id=self.env.ref("auto_backup.mail_message_subtype_failure").id,
|
||||
)
|
||||
else:
|
||||
|
@ -264,8 +263,8 @@ class DbBackup(models.Model):
|
|||
_logger.exception("Cleanup of old database backups failed: %s")
|
||||
escaped_tb = tools.html_escape(traceback.format_exc())
|
||||
self.message_post( # pylint: disable=translation-required
|
||||
body="<p>%s</p><pre>%s</pre>"
|
||||
% (_("Cleanup of old database backups failed."), escaped_tb),
|
||||
body=f"<p>{_('Cleanup of old database backups failed.')}</p>"
|
||||
f"<pre>{escaped_tb}</pre>",
|
||||
subtype_id=self.env.ref("auto_backup.failure").id,
|
||||
)
|
||||
else:
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
- On larger databases, it is possible that backups will die due to Odoo
|
||||
server settings. In order to circumvent this without frivolously
|
||||
changing settings, you need to run the backup from outside of the main
|
||||
Odoo instance. How to do this is outlined in [this blog
|
||||
post](https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/).
|
||||
Odoo instance. How to do this (for version 9.0) was outlined in [this blog
|
||||
post](https://web.archive.org/web/20240805225230/https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/).
|
||||
- Backups won't work if list_db=False is configured in the instance.
|
||||
|
|
|
@ -462,7 +462,8 @@ manually execute the selected processes.</p>
|
|||
<li>On larger databases, it is possible that backups will die due to Odoo
|
||||
server settings. In order to circumvent this without frivolously
|
||||
changing settings, you need to run the backup from outside of the main
|
||||
Odoo instance. How to do this is outlined in <a class="reference external" href="https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/">this blog
|
||||
Odoo instance. How to do this (for version 9.0) was outlined in <a class="reference external" href="https://web.archive.org/web/20240805225230/https://blog.laslabs.com/2016/10/running-python-scripts-within-odoos-environment/">this
|
||||
blog
|
||||
post</a>.</li>
|
||||
<li>Backups won’t work if list_db=False is configured in the instance.</li>
|
||||
</ul>
|
||||
|
|
|
@ -12,7 +12,8 @@ from unittest.mock import PropertyMock, patch
|
|||
|
||||
from odoo import tools
|
||||
from odoo.exceptions import UserError
|
||||
from odoo.tests import common
|
||||
|
||||
from odoo.addons.base.tests.common import BaseCommon
|
||||
|
||||
_logger = logging.getLogger(__name__)
|
||||
try:
|
||||
|
@ -27,13 +28,14 @@ class_name = "%s.DbBackup" % model
|
|||
|
||||
class TestConnectionException(pysftp.ConnectionException):
|
||||
def __init__(self):
|
||||
super(TestConnectionException, self).__init__("test", "test")
|
||||
super().__init__("test", "test")
|
||||
|
||||
|
||||
class TestDbBackup(common.TransactionCase):
|
||||
def setUp(self):
|
||||
super(TestDbBackup, self).setUp()
|
||||
self.Model = self.env["db.backup"]
|
||||
class TestDbBackup(BaseCommon):
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
super().setUpClass()
|
||||
cls.Model = cls.env["db.backup"]
|
||||
|
||||
@contextmanager
|
||||
def mock_assets(self):
|
||||
|
@ -77,13 +79,7 @@ class TestDbBackup(common.TransactionCase):
|
|||
"""It should create proper SFTP URI"""
|
||||
rec_id = self.new_record()
|
||||
self.assertEqual(
|
||||
"sftp://%(user)s@%(host)s:%(port)s%(folder)s"
|
||||
% {
|
||||
"user": self.vals["sftp_user"],
|
||||
"host": self.vals["sftp_host"],
|
||||
"port": self.vals["sftp_port"],
|
||||
"folder": self.vals["folder"],
|
||||
},
|
||||
f"sftp://{self.vals['sftp_user']}@{self.vals['sftp_host']}:{self.vals['sftp_port']}{self.vals['folder']}",
|
||||
rec_id.name,
|
||||
)
|
||||
|
||||
|
|
|
@ -12,6 +12,7 @@
|
|||
class="oe_highlight"
|
||||
/>
|
||||
</header>
|
||||
<sheet>
|
||||
<div class="oe_title">
|
||||
<h1>
|
||||
<field name="name" />
|
||||
|
@ -23,7 +24,7 @@
|
|||
<field name="method" />
|
||||
<field name="backup_format" />
|
||||
</group>
|
||||
<div attrs="{'invisible': [('method', '!=', 'sftp')]}">
|
||||
<div invisible="method != 'sftp'">
|
||||
<div class="bg-warning">
|
||||
<h3>Warning:</h3>
|
||||
Use SFTP with caution! This writes files to external servers under the path you specify.
|
||||
|
@ -56,6 +57,12 @@
|
|||
>Set the scheduler to active and fill in how often you want backups generated.</li>
|
||||
</ol>
|
||||
</div>
|
||||
</sheet>
|
||||
<!-- Chatter -->
|
||||
<div class="oe_chatter">
|
||||
<field name="message_follower_ids" groups="base.group_user" />
|
||||
<field name="message_ids" />
|
||||
</div>
|
||||
</form>
|
||||
</field>
|
||||
</record>
|
||||
|
|
Loading…
Reference in New Issue