summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ironic/conf/pxe.py2
-rw-r--r--ironic/drivers/modules/iscsi_deploy.py3
-rw-r--r--ironic/tests/unit/drivers/modules/test_iscsi_deploy.py26
-rw-r--r--releasenotes/notes/fix-instance-master-path-config-fa524c907a7888e5.yaml6
4 files changed, 35 insertions, 2 deletions
diff --git a/ironic/conf/pxe.py b/ironic/conf/pxe.py
index 1a2454327..43f2a7b09 100644
--- a/ironic/conf/pxe.py
+++ b/ironic/conf/pxe.py
@@ -36,7 +36,7 @@ opts = [
default='/var/lib/ironic/master_images',
help=_('On the ironic-conductor node, directory where master '
'instance images are stored on disk. '
- 'Setting to <None> disables image caching.')),
+ 'Setting to the empty string disables image caching.')),
cfg.IntOpt('image_cache_size',
default=20480,
help=_('Maximum size (in MiB) of cache for master images, '
diff --git a/ironic/drivers/modules/iscsi_deploy.py b/ironic/drivers/modules/iscsi_deploy.py
index e0121f2af..bddba54e8 100644
--- a/ironic/drivers/modules/iscsi_deploy.py
+++ b/ironic/drivers/modules/iscsi_deploy.py
@@ -48,8 +48,9 @@ DISK_LAYOUT_PARAMS = ('root_gb', 'swap_mb', 'ephemeral_gb')
class InstanceImageCache(image_cache.ImageCache):
def __init__(self):
+ master_path = CONF.pxe.instance_master_path or None
super(self.__class__, self).__init__(
- CONF.pxe.instance_master_path,
+ master_path,
# MiB -> B
cache_size=CONF.pxe.image_cache_size * 1024 * 1024,
# min -> sec
diff --git a/ironic/tests/unit/drivers/modules/test_iscsi_deploy.py b/ironic/tests/unit/drivers/modules/test_iscsi_deploy.py
index 4ecc1c390..efa64d8a8 100644
--- a/ironic/tests/unit/drivers/modules/test_iscsi_deploy.py
+++ b/ironic/tests/unit/drivers/modules/test_iscsi_deploy.py
@@ -1035,3 +1035,29 @@ class CleanUpFullFlowTestCase(db_base.DbTestCase):
+ self.files):
self.assertFalse(os.path.exists(path),
'%s is not expected to exist' % path)
+
+
+class InstanceImageCacheTestCase(db_base.DbTestCase):
+ @mock.patch.object(fileutils, 'ensure_tree')
+ def test_with_master_path(self, mock_ensure_tree):
+ self.config(instance_master_path='/fake/path', group='pxe')
+ self.config(image_cache_size=500, group='pxe')
+ self.config(image_cache_ttl=30, group='pxe')
+
+ cache = iscsi_deploy.InstanceImageCache()
+
+ mock_ensure_tree.assert_called_once_with('/fake/path')
+ self.assertEqual(500 * 1024 * 1024, cache._cache_size)
+ self.assertEqual(30 * 60, cache._cache_ttl)
+
+ @mock.patch.object(fileutils, 'ensure_tree')
+ def test_without_master_path(self, mock_ensure_tree):
+ self.config(instance_master_path='', group='pxe')
+ self.config(image_cache_size=500, group='pxe')
+ self.config(image_cache_ttl=30, group='pxe')
+
+ cache = iscsi_deploy.InstanceImageCache()
+
+ mock_ensure_tree.assert_not_called()
+ self.assertEqual(500 * 1024 * 1024, cache._cache_size)
+ self.assertEqual(30 * 60, cache._cache_ttl)
diff --git a/releasenotes/notes/fix-instance-master-path-config-fa524c907a7888e5.yaml b/releasenotes/notes/fix-instance-master-path-config-fa524c907a7888e5.yaml
new file mode 100644
index 000000000..4184a4cd7
--- /dev/null
+++ b/releasenotes/notes/fix-instance-master-path-config-fa524c907a7888e5.yaml
@@ -0,0 +1,6 @@
+---
+fixes:
+ - |
+ Fixes an issue where the master instance image cache could not be disabled.
+ The configuration option ``[pxe]/instance_master_path`` may now be set to
+ the empty string to disable the cache.