From 19c37befe4d0e2991dba3cad8e1968a3d35b7256 Mon Sep 17 00:00:00 2001 From: shayancanonical <99665202+shayancanonical@users.noreply.github.com> Date: Wed, 6 Dec 2023 07:37:16 -0500 Subject: [PATCH] Set up logrotate when upgrading + account for logrotate's systemd timer (#365) * Set up logrotate when upgrading + account for logrotate's systemd timer * Address PR feedback + fix failing unittest --- src/mysql_vm_helpers.py | 5 ++++- src/upgrade.py | 1 + tests/unit/test_upgrade.py | 3 +++ 3 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/mysql_vm_helpers.py b/src/mysql_vm_helpers.py index a732fd14c..7e476dfb8 100644 --- a/src/mysql_vm_helpers.py +++ b/src/mysql_vm_helpers.py @@ -257,7 +257,10 @@ def setup_logrotate_and_cron(self) -> None: with open("/etc/logrotate.d/flush_mysql_logs", "w") as file: file.write(rendered) - cron = "* * * * * root logrotate -f /etc/logrotate.d/flush_mysql_logs\n" + cron = ( + "* 1-23 * * * root logrotate -f /etc/logrotate.d/flush_mysql_logs\n" + "1-59 0 * * * root logrotate -f /etc/logrotate.d/flush_mysql_logs\n" + ) with open("/etc/cron.d/flush_mysql_logs", "w") as file: file.write(cron) diff --git a/src/upgrade.py b/src/upgrade.py index 882293c31..21b5a03cf 100644 --- a/src/upgrade.py +++ b/src/upgrade.py @@ -185,6 +185,7 @@ def _on_upgrade_granted(self, event: UpgradeGrantedEvent) -> None: self._check_server_upgradeability() self.charm.unit.status = MaintenanceStatus("starting services...") self.charm._mysql.start_mysqld() + self.charm._mysql.setup_logrotate_and_cron() except VersionError: logger.exception("Failed to upgrade MySQL dependencies") self.set_unit_failed() diff --git a/tests/unit/test_upgrade.py b/tests/unit/test_upgrade.py index dd4aa5d0a..047e14543 100644 --- a/tests/unit/test_upgrade.py +++ b/tests/unit/test_upgrade.py @@ -137,8 +137,10 @@ def test_pre_upgrade_prepare( @patch("mysql_vm_helpers.MySQL.start_mysqld") @patch("upgrade.MySQLVMUpgrade._check_server_upgradeability") @patch("mysql_vm_helpers.MySQL.is_instance_in_cluster", return_value=True) + @patch("mysql_vm_helpers.MySQL.setup_logrotate_and_cron", return_value=True) def test_upgrade_granted( self, + mock_setup_logrotate_and_cron, mock_is_instance_in_cluster, mock_check_server_upgradeability, mock_start_mysqld, @@ -165,6 +167,7 @@ def test_upgrade_granted( mock_stop_mysqld.assert_called_once() mock_install_workload.assert_called_once() mock_get_mysql_version.assert_called_once() + mock_setup_logrotate_and_cron.assert_called_once() self.harness.update_relation_data( self.upgrade_relation_id, "mysql/0", {"state": "upgrading"}