salt/tests/unit/modules/test_deb_postgres.py
Vincas Dargis cf2d1632a9
Add advanced initdb options support in postgres_cluster.present
Some optional PostgreSQL database cluster options, such as data
checksuming mode, can only be set upon initialization.

Update state and execution modules to support these permanent options.
2020-04-21 12:20:36 -07:00

186 lines
6.3 KiB
Python

# -*- coding: utf-8 -*-
# Import python libs
from __future__ import absolute_import, print_function, unicode_literals
import salt.modules.deb_postgres as deb_postgres
# Import salt libs
from salt.ext import six
# Import Salt Testing libs
from tests.support.mixins import LoaderModuleMockMixin
from tests.support.mock import Mock, patch
from tests.support.unit import TestCase
LSCLUSTER = """\
8.4 main 5432 online postgres /srv/8.4/main \
/var/log/postgresql/postgresql-8.4-main.log
9.1 main 5433 online postgres /srv/9.1/main \
/var/log/postgresql/postgresql-9.1-main.log
"""
class PostgresClusterTestCase(TestCase, LoaderModuleMockMixin):
def setup_loader_modules(self):
self.cmd_run_all_mock = Mock(return_value={"stdout": LSCLUSTER})
self.addCleanup(delattr, self, "cmd_run_all_mock")
patcher = patch(
"salt.utils.path.which", Mock(return_value="/usr/bin/pg_createcluster")
)
patcher.start()
self.addCleanup(patcher.stop)
return {
deb_postgres: {
"__salt__": {
"config.option": Mock(),
"cmd.run_all": self.cmd_run_all_mock,
"file.chown": Mock(),
"file.remove": Mock(),
}
}
}
def test_cluster_create(self):
deb_postgres.cluster_create(
"9.3",
"main",
port="5432",
locale="fr_FR",
encoding="UTF-8",
datadir="/opt/postgresql",
)
cmdstr = (
"/usr/bin/pg_createcluster "
"--port 5432 --locale fr_FR --encoding UTF-8 "
"--datadir /opt/postgresql "
"9.3 main"
)
self.assertEqual(cmdstr, self.cmd_run_all_mock.call_args[0][0])
def test_cluster_create_with_initdb_options(self):
deb_postgres.cluster_create(
"11",
"main",
port="5432",
locale="fr_FR",
encoding="UTF-8",
datadir="/opt/postgresql",
allow_group_access=True,
data_checksums=True,
wal_segsize="32",
)
cmdstr = (
"/usr/bin/pg_createcluster "
"--port 5432 --locale fr_FR --encoding UTF-8 "
"--datadir /opt/postgresql "
"11 main "
"-- "
"--allow-group-access "
"--data-checksums "
"--wal-segsize 32"
)
self.assertEqual(cmdstr, self.cmd_run_all_mock.call_args[0][0])
# XXX version should be a string but from cmdline you get a float
# def test_cluster_create_with_float(self):
# self.assertRaises(AssertionError, deb_postgres.cluster_create,
# (9.3,'main',),
# dict(port='5432',
# locale='fr_FR',
# encoding='UTF-8',
# datadir='/opt/postgresql'))
class PostgresLsClusterTestCase(TestCase, LoaderModuleMockMixin):
def setup_loader_modules(self):
self.cmd_run_all_mock = Mock(return_value={"stdout": LSCLUSTER})
self.addCleanup(delattr, self, "cmd_run_all_mock")
patcher = patch(
"salt.utils.path.which", Mock(return_value="/usr/bin/pg_lsclusters")
)
patcher.start()
self.addCleanup(patcher.stop)
return {
deb_postgres: {
"__salt__": {
"config.option": Mock(),
"cmd.run_all": self.cmd_run_all_mock,
"file.chown": Mock(),
"file.remove": Mock(),
}
}
}
def test_parse_pg_lsclusters(self):
stdout = LSCLUSTER
self.maxDiff = None
self.assertDictEqual(
{
("8.4/main"): {
"port": 5432,
"status": "online",
"user": "postgres",
"datadir": "/srv/8.4/main",
"log": "/var/log/postgresql/postgresql-8.4-main.log",
},
("9.1/main"): {
"port": 5433,
"status": "online",
"user": "postgres",
"datadir": "/srv/9.1/main",
"log": "/var/log/postgresql/postgresql-9.1-main.log",
},
},
deb_postgres._parse_pg_lscluster(stdout),
)
def test_cluster_list(self):
return_list = deb_postgres.cluster_list()
self.assertEqual(
"/usr/bin/pg_lsclusters --no-header", self.cmd_run_all_mock.call_args[0][0]
)
if six.PY2:
# Python 3 returns iterable views (dict_keys in this case) on
# dict.keys() calls instead of lists. We should only perform
# this check in Python 2.
self.assertIsInstance(return_list, list)
return_dict = deb_postgres.cluster_list(verbose=True)
self.assertIsInstance(return_dict, dict)
def test_cluster_exists(self):
self.assertTrue(deb_postgres.cluster_exists("8.4") is True)
self.assertTrue(deb_postgres.cluster_exists("8.4", "main") is True)
self.assertFalse(deb_postgres.cluster_exists("3.4", "main"))
class PostgresDeleteClusterTestCase(TestCase, LoaderModuleMockMixin):
def setup_loader_modules(self):
self.cmd_run_all_mock = Mock(return_value={"stdout": LSCLUSTER})
self.addCleanup(delattr, self, "cmd_run_all_mock")
patcher = patch(
"salt.utils.path.which", Mock(return_value="/usr/bin/pg_dropcluster")
)
patcher.start()
self.addCleanup(patcher.stop)
return {
deb_postgres: {
"__salt__": {
"config.option": Mock(),
"cmd.run_all": self.cmd_run_all_mock,
"file.chown": Mock(),
"file.remove": Mock(),
}
}
}
def test_cluster_delete(self):
deb_postgres.cluster_remove("9.3", "main")
self.assertEqual(
"/usr/bin/pg_dropcluster 9.3 main", self.cmd_run_all_mock.call_args[0][0]
)
deb_postgres.cluster_remove("9.3", "main", stop=True)
self.assertEqual(
"/usr/bin/pg_dropcluster --stop 9.3 main",
self.cmd_run_all_mock.call_args[0][0],
)