You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-22 00:22:07 +03:00
118 lines
4.3 KiB
Python
118 lines
4.3 KiB
Python
import os
|
|
|
|
from cmapi_server.managers.process import MCSProcessManager
|
|
from cmapi_server.process_dispatchers.systemd import SystemdDispatcher
|
|
from cmapi_server.test.unittest_global import (
|
|
DDL_SERVICE, CONTROLLERNODE_SERVICE, SYSTEMCTL,
|
|
BaseProcessDispatcherCase
|
|
)
|
|
|
|
class SystemdTest(BaseProcessDispatcherCase):
|
|
|
|
def test_systemd_status_start(self):
|
|
os.system(f'{SYSTEMCTL} stop {DDL_SERVICE}')
|
|
self.assertFalse(
|
|
SystemdDispatcher.is_service_running(DDL_SERVICE)
|
|
)
|
|
self.assertTrue(SystemdDispatcher.start(DDL_SERVICE))
|
|
|
|
os.system(f'{SYSTEMCTL} stop {CONTROLLERNODE_SERVICE}')
|
|
self.assertFalse(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
result = SystemdDispatcher.start(CONTROLLERNODE_SERVICE)
|
|
self.assertTrue(result)
|
|
self.assertTrue(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
|
|
def test_systemd_status_stop(self):
|
|
os.system(f'{SYSTEMCTL} start {CONTROLLERNODE_SERVICE}')
|
|
self.assertTrue(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
self.assertTrue(SystemdDispatcher.stop(CONTROLLERNODE_SERVICE))
|
|
self.assertFalse(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
|
|
def test_systemd_status_restart(self):
|
|
os.system(f'{SYSTEMCTL} start {CONTROLLERNODE_SERVICE}')
|
|
self.assertTrue(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
self.assertTrue(SystemdDispatcher.restart(CONTROLLERNODE_SERVICE))
|
|
self.assertTrue(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
|
|
os.system(f'{SYSTEMCTL} stop {CONTROLLERNODE_SERVICE}')
|
|
self.assertFalse(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
self.assertTrue(SystemdDispatcher.restart(CONTROLLERNODE_SERVICE))
|
|
self.assertTrue(
|
|
SystemdDispatcher.is_service_running(CONTROLLERNODE_SERVICE)
|
|
)
|
|
|
|
|
|
class MCSProcessManagerTest(BaseProcessDispatcherCase):
|
|
|
|
def get_systemd_serv_name(self, service_name):
|
|
if service_name == 'mcs-workernode':
|
|
return f'{service_name}@1'
|
|
return service_name
|
|
|
|
def test_mcs_process_manager(self):
|
|
MCSProcessManager.detect('systemd', '')
|
|
for prog in MCSProcessManager._get_sorted_progs(True, True).values():
|
|
serv_name = self.get_systemd_serv_name(prog.service_name)
|
|
os.system(f'{SYSTEMCTL} stop {serv_name}')
|
|
self.assertIsNone(MCSProcessManager.start_node(True))
|
|
|
|
for prog in MCSProcessManager.mcs_progs.values():
|
|
serv_name = self.get_systemd_serv_name(prog.service_name)
|
|
if serv_name == 'mcs-storagemanager':
|
|
continue
|
|
self.assertTrue(
|
|
MCSProcessManager.process_dispatcher.is_service_running(
|
|
serv_name
|
|
)
|
|
)
|
|
|
|
self.assertIsNone(MCSProcessManager.stop_node(is_primary=True))
|
|
for prog in MCSProcessManager.mcs_progs.values():
|
|
serv_name = self.get_systemd_serv_name(prog.service_name)
|
|
self.assertFalse(
|
|
MCSProcessManager.process_dispatcher.is_service_running(
|
|
serv_name
|
|
)
|
|
)
|
|
self.assertEqual(len(MCSProcessManager.get_running_mcs_procs()), 0)
|
|
self.assertTrue(
|
|
MCSProcessManager.is_node_processes_ok(
|
|
is_primary=True, node_stopped=True
|
|
)
|
|
)
|
|
|
|
for prog in MCSProcessManager._get_sorted_progs(True).values():
|
|
serv_name = self.get_systemd_serv_name(prog.service_name)
|
|
os.system(f'{SYSTEMCTL} start {serv_name}')
|
|
|
|
for prog in MCSProcessManager.mcs_progs.values():
|
|
serv_name = self.get_systemd_serv_name(prog.service_name)
|
|
self.assertTrue(
|
|
MCSProcessManager.process_dispatcher.is_service_running(
|
|
serv_name
|
|
)
|
|
)
|
|
self.assertEqual(
|
|
len(MCSProcessManager.get_running_mcs_procs()),
|
|
len(MCSProcessManager.mcs_progs.keys())
|
|
)
|
|
self.assertTrue(
|
|
MCSProcessManager.is_node_processes_ok(
|
|
is_primary=True, node_stopped=False
|
|
)
|
|
)
|