2019-11-28 16:41:55 +01:00
|
|
|
From a8f289c4eb03c051d8ffc60eed28985f3b49d921 Mon Sep 17 00:00:00 2001
|
2019-06-14 14:50:01 +02:00
|
|
|
From: =?UTF-8?q?Pablo=20Su=C3=A1rez=20Hern=C3=A1ndez?=
|
|
|
|
<psuarezhernandez@suse.com>
|
|
|
|
Date: Wed, 29 May 2019 11:03:16 +0100
|
|
|
|
Subject: [PATCH] Do not break repo files with multiple line values on
|
|
|
|
yumpkg (bsc#1135360)
|
|
|
|
|
|
|
|
---
|
2019-11-28 16:41:55 +01:00
|
|
|
salt/modules/yumpkg.py | 16 +++++++++---
|
|
|
|
tests/integration/modules/test_pkg.py | 48 +++++++++++++++++++++++++++++++++++
|
2019-06-14 14:50:01 +02:00
|
|
|
2 files changed, 60 insertions(+), 4 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/salt/modules/yumpkg.py b/salt/modules/yumpkg.py
|
|
|
|
index 5ec3835574..3a4fe47a45 100644
|
|
|
|
--- a/salt/modules/yumpkg.py
|
|
|
|
+++ b/salt/modules/yumpkg.py
|
|
|
|
@@ -2763,7 +2763,12 @@ def del_repo(repo, basedir=None, **kwargs): # pylint: disable=W0613
|
|
|
|
del filerepos[stanza]['comments']
|
|
|
|
content += '\n[{0}]'.format(stanza)
|
|
|
|
for line in filerepos[stanza]:
|
|
|
|
- content += '\n{0}={1}'.format(line, filerepos[stanza][line])
|
|
|
|
+ # A whitespace is needed at the begining of the new line in order
|
|
|
|
+ # to avoid breaking multiple line values allowed on repo files.
|
|
|
|
+ value = filerepos[stanza][line]
|
|
|
|
+ if isinstance(value, six.string_types) and '\n' in value:
|
|
|
|
+ value = '\n '.join(value.split('\n'))
|
|
|
|
+ content += '\n{0}={1}'.format(line, value)
|
|
|
|
content += '\n{0}\n'.format(comments)
|
|
|
|
|
|
|
|
with salt.utils.files.fopen(repofile, 'w') as fileout:
|
|
|
|
@@ -2898,11 +2903,14 @@ def mod_repo(repo, basedir=None, **kwargs):
|
|
|
|
)
|
|
|
|
content += '[{0}]\n'.format(stanza)
|
|
|
|
for line in six.iterkeys(filerepos[stanza]):
|
|
|
|
+ # A whitespace is needed at the begining of the new line in order
|
|
|
|
+ # to avoid breaking multiple line values allowed on repo files.
|
|
|
|
+ value = filerepos[stanza][line]
|
|
|
|
+ if isinstance(value, six.string_types) and '\n' in value:
|
|
|
|
+ value = '\n '.join(value.split('\n'))
|
|
|
|
content += '{0}={1}\n'.format(
|
|
|
|
line,
|
|
|
|
- filerepos[stanza][line]
|
|
|
|
- if not isinstance(filerepos[stanza][line], bool)
|
|
|
|
- else _bool_to_str(filerepos[stanza][line])
|
|
|
|
+ value if not isinstance(value, bool) else _bool_to_str(value)
|
|
|
|
)
|
|
|
|
content += comments + '\n'
|
|
|
|
|
|
|
|
diff --git a/tests/integration/modules/test_pkg.py b/tests/integration/modules/test_pkg.py
|
2019-11-28 16:41:55 +01:00
|
|
|
index 66ac3cfb61..7204428eca 100644
|
2019-06-14 14:50:01 +02:00
|
|
|
--- a/tests/integration/modules/test_pkg.py
|
|
|
|
+++ b/tests/integration/modules/test_pkg.py
|
2019-11-28 16:41:55 +01:00
|
|
|
@@ -136,6 +136,54 @@ class PkgModuleTest(ModuleCase, SaltReturnAssertsMixin):
|
2019-06-14 14:50:01 +02:00
|
|
|
if repo is not None:
|
|
|
|
self.run_function('pkg.del_repo', [repo])
|
|
|
|
|
|
|
|
+ def test_mod_del_repo_multiline_values(self):
|
|
|
|
+ '''
|
|
|
|
+ test modifying and deleting a software repository defined with multiline values
|
|
|
|
+ '''
|
|
|
|
+ os_grain = self.run_function('grains.item', ['os'])['os']
|
|
|
|
+ repo = None
|
|
|
|
+ try:
|
|
|
|
+ if os_grain in ['CentOS', 'RedHat', 'SUSE']:
|
|
|
|
+ my_baseurl = 'http://my.fake.repo/foo/bar/\n http://my.fake.repo.alt/foo/bar/'
|
|
|
|
+ expected_get_repo_baseurl = 'http://my.fake.repo/foo/bar/\nhttp://my.fake.repo.alt/foo/bar/'
|
|
|
|
+ major_release = int(
|
|
|
|
+ self.run_function(
|
|
|
|
+ 'grains.item',
|
|
|
|
+ ['osmajorrelease']
|
|
|
|
+ )['osmajorrelease']
|
|
|
|
+ )
|
|
|
|
+ repo = 'fakerepo'
|
|
|
|
+ name = 'Fake repo for RHEL/CentOS/SUSE'
|
|
|
|
+ baseurl = my_baseurl
|
|
|
|
+ gpgkey = 'https://my.fake.repo/foo/bar/MY-GPG-KEY.pub'
|
|
|
|
+ failovermethod = 'priority'
|
|
|
|
+ gpgcheck = 1
|
|
|
|
+ enabled = 1
|
|
|
|
+ ret = self.run_function(
|
|
|
|
+ 'pkg.mod_repo',
|
|
|
|
+ [repo],
|
|
|
|
+ name=name,
|
|
|
|
+ baseurl=baseurl,
|
|
|
|
+ gpgkey=gpgkey,
|
|
|
|
+ gpgcheck=gpgcheck,
|
|
|
|
+ enabled=enabled,
|
|
|
|
+ failovermethod=failovermethod,
|
|
|
|
+ )
|
|
|
|
+ # return data from pkg.mod_repo contains the file modified at
|
|
|
|
+ # the top level, so use next(iter(ret)) to get that key
|
|
|
|
+ self.assertNotEqual(ret, {})
|
|
|
|
+ repo_info = ret[next(iter(ret))]
|
|
|
|
+ self.assertIn(repo, repo_info)
|
|
|
|
+ self.assertEqual(repo_info[repo]['baseurl'], my_baseurl)
|
|
|
|
+ ret = self.run_function('pkg.get_repo', [repo])
|
|
|
|
+ self.assertEqual(ret['baseurl'], expected_get_repo_baseurl)
|
|
|
|
+ self.run_function('pkg.mod_repo', [repo])
|
|
|
|
+ ret = self.run_function('pkg.get_repo', [repo])
|
|
|
|
+ self.assertEqual(ret['baseurl'], expected_get_repo_baseurl)
|
|
|
|
+ finally:
|
|
|
|
+ if repo is not None:
|
|
|
|
+ self.run_function('pkg.del_repo', [repo])
|
|
|
|
+
|
|
|
|
@requires_salt_modules('pkg.owner')
|
|
|
|
def test_owner(self):
|
|
|
|
'''
|
|
|
|
--
|
2019-11-28 16:41:55 +01:00
|
|
|
2.16.4
|
2019-06-14 14:50:01 +02:00
|
|
|
|
|
|
|
|