update unit_test with patch
update functional-test
This commit is contained in:
@@ -46,9 +46,10 @@ options:
|
|||||||
Number of attempts to mount NFS shares before raising an error.
|
Number of attempts to mount NFS shares before raising an error.
|
||||||
At least one attempt will be made to mount an NFS share, regardless
|
At least one attempt will be made to mount an NFS share, regardless
|
||||||
of the value specified.
|
of the value specified.
|
||||||
|
|
||||||
nfs-snapshot-support:
|
nfs-snapshot-support:
|
||||||
type: boolean
|
type: boolean
|
||||||
default: False
|
default: True
|
||||||
description: |
|
description: |
|
||||||
Enable support for snapshots on the NFS driver.
|
Enable support for snapshots on the NFS driver.
|
||||||
Platforms using libvirt <1.2.7 will encounter issues with this feature.
|
Platforms using libvirt <1.2.7 will encounter issues with this feature.
|
||||||
|
|||||||
17
src/charm.py
17
src/charm.py
@@ -19,6 +19,7 @@ from ops.main import main
|
|||||||
from ops.model import ActiveStatus, BlockedStatus
|
from ops.model import ActiveStatus, BlockedStatus
|
||||||
from ops_openstack.plugins.classes import CinderStoragePluginCharm
|
from ops_openstack.plugins.classes import CinderStoragePluginCharm
|
||||||
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import io
|
import io
|
||||||
import shutil
|
import shutil
|
||||||
@@ -35,6 +36,13 @@ def _check_config(charm_config):
|
|||||||
return ActiveStatus("Unit is ready")
|
return ActiveStatus("Unit is ready")
|
||||||
|
|
||||||
|
|
||||||
|
def _write_config(data, path):
|
||||||
|
with open(path, "w+") as file:
|
||||||
|
file.write(data)
|
||||||
|
os.chmod(path, 0o640)
|
||||||
|
shutil.chown(path, user="root", group="cinder")
|
||||||
|
|
||||||
|
|
||||||
class CharmCinderNFSCharm(CinderStoragePluginCharm):
|
class CharmCinderNFSCharm(CinderStoragePluginCharm):
|
||||||
"""Charm the Cinder NFS driver."""
|
"""Charm the Cinder NFS driver."""
|
||||||
|
|
||||||
@@ -72,16 +80,13 @@ class CharmCinderNFSCharm(CinderStoragePluginCharm):
|
|||||||
value = self.framework.model.app.name
|
value = self.framework.model.app.name
|
||||||
|
|
||||||
if key == "nfs-shares":
|
if key == "nfs-shares":
|
||||||
nfs_shares = os.linesep.join([s for s in value.splitlines() if s])
|
nfs_shares = os.linesep.join([s for s in value.splitlines()
|
||||||
|
if s])
|
||||||
buff = io.StringIO(nfs_shares)
|
buff = io.StringIO(nfs_shares)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if key == "nfs-shares-config":
|
if key == "nfs-shares-config":
|
||||||
path = value
|
_write_config(buff.getvalue(), value)
|
||||||
with open(path, "w+") as f:
|
|
||||||
print(buff.getvalue(), file=f)
|
|
||||||
os.chmod(path, 0o640)
|
|
||||||
shutil.chown(path, user="root", group="cinder")
|
|
||||||
|
|
||||||
options.append((key.replace("-", "_"), value))
|
options.append((key.replace("-", "_"), value))
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
charm_name: cinder-three-par
|
charm_name: cinder-nfs
|
||||||
|
|
||||||
target_deploy_status:
|
target_deploy_status:
|
||||||
cinder:
|
cinder:
|
||||||
@@ -6,7 +6,7 @@ target_deploy_status:
|
|||||||
workload-status-message-prefix: "Missing relations:"
|
workload-status-message-prefix: "Missing relations:"
|
||||||
|
|
||||||
tests:
|
tests:
|
||||||
- tests.tests_cinder_three_par.CinderThreeParTest
|
- tests.tests_cinder_nfs.CinderNFSTest
|
||||||
|
|
||||||
configure: []
|
configure: []
|
||||||
gate_bundles:
|
gate_bundles:
|
||||||
|
|||||||
@@ -13,63 +13,102 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
import unittest
|
import unittest
|
||||||
|
from unittest.mock import patch
|
||||||
import json
|
import json
|
||||||
|
|
||||||
from ops.model import Relation, BlockedStatus, ActiveStatus
|
from ops.model import Relation, BlockedStatus
|
||||||
from ops.testing import Harness
|
from ops.testing import Harness
|
||||||
from src.charm import CharmCinderNFSCharm
|
from src.charm import CharmCinderNFSCharm
|
||||||
|
from src.charm import _write_config
|
||||||
|
|
||||||
|
|
||||||
class TestCharm(unittest.TestCase):
|
class TestCharm(unittest.TestCase):
|
||||||
maxDiff = None
|
maxDiff = None
|
||||||
|
|
||||||
def setUp(self):
|
@patch("src.charm.shutil.chown")
|
||||||
|
@patch("src.charm.os.chmod")
|
||||||
|
@patch("src.charm.open", new_callable=unittest.mock.mock_open)
|
||||||
|
def setUp(self, mock_open, mock_chmod, mock_chown):
|
||||||
self.harness = Harness(CharmCinderNFSCharm)
|
self.harness = Harness(CharmCinderNFSCharm)
|
||||||
self.addCleanup(self.harness.cleanup)
|
self.addCleanup(self.harness.cleanup)
|
||||||
self.harness.begin()
|
self.harness.begin()
|
||||||
self.harness.set_leader(True)
|
self.harness.set_leader(True)
|
||||||
self.model = self.harness.model
|
self.model = self.harness.model
|
||||||
self.storage_backend = self.harness.add_relation("storage-backend", "cinder")
|
self.storage_backend = self.harness.add_relation("storage-backend",
|
||||||
|
"cinder")
|
||||||
self.harness.add_relation_unit(self.storage_backend, "cinder/0")
|
self.harness.add_relation_unit(self.storage_backend, "cinder/0")
|
||||||
self.harness.update_config(
|
self.harness.update_config(
|
||||||
{
|
{
|
||||||
"volume-backend-name": "cinder-nfs",
|
"volume-backend-name": "cinder-nfs",
|
||||||
"nfs-shares": "172.18.18.61:/srv/test",
|
"nfs-shares": "172.18.18.61:/srv/test",
|
||||||
|
"nfs-shares-config": "/test/nfs_shares",
|
||||||
"nfs-mount-point-base": "/var/lib/cinder/nfs",
|
"nfs-mount-point-base": "/var/lib/cinder/nfs",
|
||||||
"nfs-mount-options": "vers=3",
|
"nfs-mount-options": "vers=3",
|
||||||
"nfs-mount-attempts": 3,
|
"nfs-mount-attempts": 3,
|
||||||
|
"nfs-snapshot-support": True,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
def _get_sub_conf(self):
|
def _get_sub_conf(self):
|
||||||
|
# return relation data
|
||||||
rel = self.model.get_relation("storage-backend", 0)
|
rel = self.model.get_relation("storage-backend", 0)
|
||||||
self.assertIsInstance(rel, Relation)
|
self.assertIsInstance(rel, Relation)
|
||||||
rdata = rel.data[self.model.unit]
|
rdata = rel.data[self.model.unit]
|
||||||
rdata = json.loads(rdata["subordinate_configuration"])
|
rdata = json.loads(rdata["subordinate_configuration"])
|
||||||
return dict(
|
return dict(
|
||||||
rdata["cinder"]["/etc/cinder/cinder.conf"]["sections"]["cinder-nfs"]
|
(rdata["cinder"]["/etc/cinder/cinder.conf"]["sections"]
|
||||||
|
["cinder-nfs"])
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@patch("src.charm.shutil.chown")
|
||||||
|
@patch("src.charm.os.chmod")
|
||||||
|
@patch("src.charm.open", new_callable=unittest.mock.mock_open)
|
||||||
|
def test_write_config(self, mock_open, mock_chmod, mock_chown):
|
||||||
|
path = "/etc/cinder/nfs-shares"
|
||||||
|
data = "172.17.17.61:/srv/test"
|
||||||
|
permission = 0o640
|
||||||
|
|
||||||
|
_write_config(data, path)
|
||||||
|
|
||||||
|
mock_open.assert_called_once_with(path, "w+")
|
||||||
|
mock_open().write.assert_called_once_with(data)
|
||||||
|
mock_chmod.assert_called_once_with(path, permission)
|
||||||
|
mock_chown.assert_called_once_with(path, user="root", group="cinder")
|
||||||
|
|
||||||
def test_backend_name_in_data(self):
|
def test_backend_name_in_data(self):
|
||||||
rel = self.model.get_relation("storage-backend", 0)
|
rel = self.model.get_relation("storage-backend", 0)
|
||||||
rdata = rel.data[self.model.unit]
|
rdata = rel.data[self.model.unit]
|
||||||
self.assertEqual(rdata["backend_name"], "cinder-nfs")
|
self.assertEqual(rdata["backend_name"], "cinder-nfs")
|
||||||
|
|
||||||
def test_config_changed(self):
|
@patch("src.charm.shutil.chown")
|
||||||
|
@patch("src.charm.os.chmod")
|
||||||
|
@patch("src.charm.open", new_callable=unittest.mock.mock_open)
|
||||||
|
def test_config_changed(self, mock_open, mock_chmod, mock_chown):
|
||||||
|
shares_config = "/tmp/nfs-shares"
|
||||||
|
mount_point_base = "/var/lib/cinder/nfsmount"
|
||||||
|
mount_options = "vers=4.1,proto=tcp,retry=4"
|
||||||
|
mount_attempts = 4
|
||||||
self.harness.update_config(
|
self.harness.update_config(
|
||||||
{
|
{
|
||||||
"nfs-mount-point-base": "/var/lib/cinder/nfsmount",
|
"nfs-shares-config": shares_config,
|
||||||
"nfs-mount-options": "vers=4.1,proto=tcp,retry=4,",
|
"nfs-mount-point-base": mount_point_base,
|
||||||
"nfs-mount-attempts": 4,
|
"nfs-mount-options": mount_options,
|
||||||
|
"nfs-mount-attempts": mount_attempts,
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
self._get_sub_conf(),
|
self._get_sub_conf(),
|
||||||
{
|
{
|
||||||
|
"nfs_shares_config": shares_config,
|
||||||
|
"nfs_mount_point_base": mount_point_base,
|
||||||
|
"nfs_mount_options": mount_options,
|
||||||
|
"nfs_mount_attempts": mount_attempts,
|
||||||
|
# default value
|
||||||
|
"volume_backend_name": "cinder-nfs",
|
||||||
"volume_driver": "cinder.volume.drivers.nfs.NfsDriver",
|
"volume_driver": "cinder.volume.drivers.nfs.NfsDriver",
|
||||||
"nfs_mount_point_base": "/var/lib/cinder/nfsmount",
|
"nfs_sparsed_volumes": True,
|
||||||
"nfs_mount_options": "vers=4.1,proto=tcp,retry=4,",
|
"nfs_snapshot_support": True,
|
||||||
"nfs_mount_attempts": 4,
|
"nfs_qcow2_volumes": False,
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -79,20 +118,13 @@ class TestCharm(unittest.TestCase):
|
|||||||
message = self.harness.charm.unit.status.message
|
message = self.harness.charm.unit.status.message
|
||||||
self.assertIn("NFS shares not configured", message)
|
self.assertIn("NFS shares not configured", message)
|
||||||
|
|
||||||
def test_status_with_mandatory_config(self):
|
@patch("src.charm.shutil.chown")
|
||||||
self.assertEqual(self.harness.charm.unit.status.message, "Unit is ready")
|
@patch("src.charm.os.chmod")
|
||||||
self.assertIsInstance(self.harness.charm.unit.status, ActiveStatus)
|
@patch("src.charm.open", new_callable=unittest.mock.mock_open)
|
||||||
self.harness.update_config(
|
def test_volume_backend_name_config(self, mock_open, mock_chmod,
|
||||||
unset=["nfs-shares-config"],
|
mock_chown):
|
||||||
)
|
self.assertEqual(self._get_sub_conf().get("volume_backend_name"),
|
||||||
self.assertEqual(
|
"cinder-nfs")
|
||||||
self.harness.charm.unit.status.message,
|
|
||||||
"Missing option(s): nfs-shares-config",
|
|
||||||
)
|
|
||||||
self.assertIsInstance(self.harness.charm.unit.status, BlockedStatus)
|
|
||||||
|
|
||||||
def test_volume_backend_name_config(self):
|
|
||||||
self.assertEqual(self._get_sub_conf().get("volume_backend_name"), "cinder-nfs")
|
|
||||||
|
|
||||||
self.harness.update_config(
|
self.harness.update_config(
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user