2020-04-07 14:14:01 +02:00
|
|
|
From 6418d9ebc3b269a0246262f79c0bab367e39cc52 Mon Sep 17 00:00:00 2001
|
2019-10-25 17:02:59 +02:00
|
|
|
From: Alberto Planas <aplanas@gmail.com>
|
|
|
|
Date: Fri, 25 Oct 2019 15:43:16 +0200
|
|
|
|
Subject: [PATCH] Fix a wrong rebase in test_core.py (#180)
|
|
|
|
|
|
|
|
* core: ignore wrong product_name files
|
|
|
|
|
|
|
|
Some firmwares (like some NUC machines), do not provide valid
|
|
|
|
/sys/class/dmi/id/product_name strings. In those cases an
|
|
|
|
UnicodeDecodeError exception happens.
|
|
|
|
|
|
|
|
This patch ignore this kind of issue during the grains creation.
|
|
|
|
|
|
|
|
(cherry picked from commit 27b001bd5408359aa5dd219bfd900095ed592fe8)
|
|
|
|
|
|
|
|
* core: remove duplicate dead code
|
|
|
|
|
|
|
|
(cherry picked from commit bd0213bae00b737b24795bec3c030ebfe476e0d8)
|
|
|
|
---
|
2019-11-28 16:41:55 +01:00
|
|
|
salt/grains/core.py | 4 ++--
|
|
|
|
tests/unit/grains/test_core.py | 45 ------------------------------------------
|
2019-10-25 17:02:59 +02:00
|
|
|
2 files changed, 2 insertions(+), 47 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/salt/grains/core.py b/salt/grains/core.py
|
2020-04-07 14:14:01 +02:00
|
|
|
index 68c43482d3..20950988d9 100644
|
2019-10-25 17:02:59 +02:00
|
|
|
--- a/salt/grains/core.py
|
|
|
|
+++ b/salt/grains/core.py
|
2020-04-07 14:14:01 +02:00
|
|
|
@@ -1000,7 +1000,7 @@ def _virtual(osdata):
|
2019-10-25 17:02:59 +02:00
|
|
|
except UnicodeDecodeError:
|
|
|
|
# Some firmwares provide non-valid 'product_name'
|
|
|
|
# files, ignore them
|
|
|
|
- pass
|
|
|
|
+ log.debug('The content in /sys/devices/virtual/dmi/id/product_name is not valid')
|
|
|
|
except IOError:
|
|
|
|
pass
|
|
|
|
elif osdata['kernel'] == 'FreeBSD':
|
2020-04-07 14:14:01 +02:00
|
|
|
@@ -2568,7 +2568,7 @@ def _hw_data(osdata):
|
2019-10-25 17:02:59 +02:00
|
|
|
except UnicodeDecodeError:
|
|
|
|
# Some firmwares provide non-valid 'product_name'
|
|
|
|
# files, ignore them
|
|
|
|
- pass
|
|
|
|
+ log.debug('The content in /sys/devices/virtual/dmi/id/product_name is not valid')
|
|
|
|
except (IOError, OSError) as err:
|
|
|
|
# PermissionError is new to Python 3, but corresponds to the EACESS and
|
|
|
|
# EPERM error numbers. Use those instead here for PY2 compatibility.
|
|
|
|
diff --git a/tests/unit/grains/test_core.py b/tests/unit/grains/test_core.py
|
2020-04-07 14:14:01 +02:00
|
|
|
index c4731f667a..b4ed9379e5 100644
|
2019-10-25 17:02:59 +02:00
|
|
|
--- a/tests/unit/grains/test_core.py
|
|
|
|
+++ b/tests/unit/grains/test_core.py
|
2020-04-07 14:14:01 +02:00
|
|
|
@@ -1544,51 +1544,6 @@ class CoreGrainsTestCase(TestCase, LoaderModuleMockMixin):
|
|
|
|
self.assertIn('osfullname', os_grains)
|
|
|
|
self.assertEqual(os_grains.get('osfullname'), 'FreeBSD')
|
2019-10-25 17:02:59 +02:00
|
|
|
|
|
|
|
- @skipIf(not salt.utils.platform.is_linux(), 'System is not Linux')
|
|
|
|
- def test_kernelparams_return(self):
|
|
|
|
- expectations = [
|
|
|
|
- ('BOOT_IMAGE=/vmlinuz-3.10.0-693.2.2.el7.x86_64',
|
|
|
|
- {'kernelparams': [('BOOT_IMAGE', '/vmlinuz-3.10.0-693.2.2.el7.x86_64')]}),
|
|
|
|
- ('root=/dev/mapper/centos_daemon-root',
|
|
|
|
- {'kernelparams': [('root', '/dev/mapper/centos_daemon-root')]}),
|
|
|
|
- ('rhgb quiet ro',
|
|
|
|
- {'kernelparams': [('rhgb', None), ('quiet', None), ('ro', None)]}),
|
|
|
|
- ('param="value1"',
|
|
|
|
- {'kernelparams': [('param', 'value1')]}),
|
|
|
|
- ('param="value1 value2 value3"',
|
|
|
|
- {'kernelparams': [('param', 'value1 value2 value3')]}),
|
|
|
|
- ('param="value1 value2 value3" LANG="pl" ro',
|
|
|
|
- {'kernelparams': [('param', 'value1 value2 value3'), ('LANG', 'pl'), ('ro', None)]}),
|
|
|
|
- ('ipv6.disable=1',
|
|
|
|
- {'kernelparams': [('ipv6.disable', '1')]}),
|
|
|
|
- ('param="value1:value2:value3"',
|
|
|
|
- {'kernelparams': [('param', 'value1:value2:value3')]}),
|
|
|
|
- ('param="value1,value2,value3"',
|
|
|
|
- {'kernelparams': [('param', 'value1,value2,value3')]}),
|
|
|
|
- ('param="value1" param="value2" param="value3"',
|
|
|
|
- {'kernelparams': [('param', 'value1'), ('param', 'value2'), ('param', 'value3')]}),
|
|
|
|
- ]
|
|
|
|
-
|
|
|
|
- for cmdline, expectation in expectations:
|
|
|
|
- with patch('salt.utils.files.fopen', mock_open(read_data=cmdline)):
|
|
|
|
- self.assertEqual(core.kernelparams(), expectation)
|
|
|
|
-
|
|
|
|
- @skipIf(not salt.utils.platform.is_linux(), 'System is not Linux')
|
|
|
|
- @patch('os.path.exists')
|
|
|
|
- @patch('salt.utils.platform.is_proxy')
|
|
|
|
- def test__hw_data_linux_empty(self, is_proxy, exists):
|
|
|
|
- is_proxy.return_value = False
|
|
|
|
- exists.return_value = True
|
|
|
|
- with patch('salt.utils.files.fopen', mock_open(read_data='')):
|
|
|
|
- self.assertEqual(core._hw_data({'kernel': 'Linux'}), {
|
|
|
|
- 'biosreleasedate': '',
|
|
|
|
- 'biosversion': '',
|
|
|
|
- 'manufacturer': '',
|
|
|
|
- 'productname': '',
|
|
|
|
- 'serialnumber': '',
|
|
|
|
- 'uuid': ''
|
|
|
|
- })
|
|
|
|
-
|
|
|
|
@skipIf(not salt.utils.platform.is_linux(), 'System is not Linux')
|
|
|
|
@skipIf(six.PY2, 'UnicodeDecodeError is throw in Python 3')
|
|
|
|
@patch('os.path.exists')
|
|
|
|
--
|
2019-11-28 16:41:55 +01:00
|
|
|
2.16.4
|
2019-10-25 17:02:59 +02:00
|
|
|
|
|
|
|
|