You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-08-10 01:22:48 +03:00
* MCOL-5496: Merge CMAPI code to engine repo. [add] cmapi code to engine * MCOL-5496: Fix CI adding CMAPI steps. [fix] deb packages deps commands [add] several additional local variables [fix] packages url [fix] smoke step [fix] mtr step [fix] regression step [add] cmapipython, cmapibuild, cmapitest and cmapilog steps [fix] dockerfile step [fix] build step to include cmapi package on repodata creating [fix] multi_node_mtr step [fix] pkg step [add] cmapi steps to pipelines [fix] cmapi/CMakeLists.txt to prevent cmake byte-compile .py files for rpm packages [add] setup-repo.sh file [fix] now use packages from the repos in tests steps * Adding color 2 build script * Build script and logging scripts from develop * Remove test 222 from full regression, it is missing in 23.02 regression set --------- Co-authored-by: mariadb-AlanMologorsky <alan.mologorsky@mariadb.com> Co-authored-by: mariadb-RomanNavrotskiy <roman.navrotskiy@mariadb.com>
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
|
|
)
|
|
)
|