1
0
mirror of https://github.com/mariadb-corporation/mariadb-columnstore-engine.git synced 2025-07-22 00:22:07 +03:00
Files
mariadb-columnstore-engine/cmapi/cmapi_server/test/test_mcs_process_operations.py
mariadb-AlanMologorsky a079a2c944 MCOL-5496: Merge CMAPI code to engine repo.
[add] cmapi code to engine
2023-06-07 10:00:16 +03:00

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
)
)