From 7b9c2a101fb6198eb58062669bb857f3f763c02dd4ef1a25ae9aa9de17a9d8a0 Mon Sep 17 00:00:00 2001 From: Robert Schweikert Date: Mon, 23 Sep 2019 13:07:29 +0000 Subject: [PATCH 1/4] - Follow up to (bsc#1144363) - In this implementation the "name" is not yet an attribute, use get() to obtain the value from a dict. Source code version confusion. OBS-URL: https://build.opensuse.org/package/show/Cloud:Tools/cloud-init?expand=0&rev=145 --- cloud-init-trigger-udev.patch | 2 +- cloud-init.changes | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/cloud-init-trigger-udev.patch b/cloud-init-trigger-udev.patch index 538e161..4431385 100644 --- a/cloud-init-trigger-udev.patch +++ b/cloud-init-trigger-udev.patch @@ -27,7 +27,7 @@ + # before they are all setup. Settle if that is the case. + for iface in network_state.iter_interfaces( + renderer.filter_by_physical): -+ path = net.sys_dev_path(iface.name) ++ path = net.sys_dev_path(iface.get('name')) + if not os.path.exists(path): + util.udevadm_settle(path, 5) + break diff --git a/cloud-init.changes b/cloud-init.changes index 64e902e..99abc3a 100644 --- a/cloud-init.changes +++ b/cloud-init.changes @@ -1,3 +1,10 @@ +------------------------------------------------------------------- +Mon Sep 23 13:05:03 UTC 2019 - Robert Schweikert + +- Follow up to (bsc#1144363) + - In this implementation the "name" is not yet an attribute, use + get() to obtain the value from a dict. Source code version confusion. + ------------------------------------------------------------------- Mon Aug 19 16:46:35 UTC 2019 - Robert Schweikert From fcf843e6dd9aecafd7019877b73e0d12f433f2a6e45f9f8f04e71ff5cddf3b53 Mon Sep 17 00:00:00 2001 From: Robert Schweikert Date: Tue, 24 Sep 2019 19:32:45 +0000 Subject: [PATCH 2/4] - Add cloud-init-noresolv-merge-no-dns-data.diff - Avoid writing resolv.conf if the network configuration contains no dns entries. OBS-URL: https://build.opensuse.org/package/show/Cloud:Tools/cloud-init?expand=0&rev=146 --- cloud-init-noresolv-merge-no-dns-data.diff | 68 ++++++++++++++++++++++ cloud-init.changes | 7 +++ cloud-init.spec | 5 +- 3 files changed, 79 insertions(+), 1 deletion(-) create mode 100644 cloud-init-noresolv-merge-no-dns-data.diff diff --git a/cloud-init-noresolv-merge-no-dns-data.diff b/cloud-init-noresolv-merge-no-dns-data.diff new file mode 100644 index 0000000..02a8b6f --- /dev/null +++ b/cloud-init-noresolv-merge-no-dns-data.diff @@ -0,0 +1,68 @@ +diff --git a/cloudinit/net/sysconfig.py b/cloudinit/net/sysconfig.py +index be5dede..1708990 100644 +--- a/cloudinit/net/sysconfig.py ++++ b/cloudinit/net/sysconfig.py +@@ -578,6 +578,10 @@ class Renderer(renderer.Renderer): + + @staticmethod + def _render_dns(network_state, existing_dns_path=None): ++ # skip writing resolv.conf if network_state doesn't include any input. ++ if not any([len(network_state.dns_nameservers), ++ len(network_state.dns_searchdomains)]): ++ return None + content = resolv_conf.ResolvConf("") + if existing_dns_path and os.path.isfile(existing_dns_path): + content = resolv_conf.ResolvConf(util.load_file(existing_dns_path)) +@@ -585,8 +589,6 @@ class Renderer(renderer.Renderer): + content.add_nameserver(nameserver) + for searchdomain in network_state.dns_searchdomains: + content.add_search_domain(searchdomain) +- if not str(content): +- return None + header = _make_header(';') + content_str = str(content) + if not content_str.startswith(header): +diff --git a/tests/unittests/test_net.py b/tests/unittests/test_net.py +index e578992..82eb18f 100644 +--- a/tests/unittests/test_net.py ++++ b/tests/unittests/test_net.py +@@ -2701,6 +2701,10 @@ USERCTL=no + ns = network_state.parse_net_config_data(CONFIG_V1_EXPLICIT_LOOPBACK) + render_dir = self.tmp_path("render") + os.makedirs(render_dir) ++ # write an etc/resolv.conf and expect it to not be modified ++ resolvconf = os.path.join(render_dir, 'etc/resolv.conf') ++ content = "# Original Content" ++ util.write_file(resolvconf, content) + renderer = self._get_renderer() + renderer.render_network_state(ns, target=render_dir) + found = dir2dict(render_dir) +@@ -2718,6 +2722,8 @@ TYPE=Ethernet + USERCTL=no + """ + self.assertEqual(expected, found[nspath + 'ifcfg-eth0']) ++ # a dhcp only config should not modify resolv.conf ++ self.assertEqual(content, found['/etc/resolv.conf']) + + def test_bond_config(self): + expected_name = 'expected_sysconfig_rhel' +@@ -3202,6 +3208,10 @@ USERCTL=no + ns = network_state.parse_net_config_data(CONFIG_V1_EXPLICIT_LOOPBACK) + render_dir = self.tmp_path("render") + os.makedirs(render_dir) ++ # write an etc/resolv.conf and expect it to not be modified ++ resolvconf = os.path.join(render_dir, 'etc/resolv.conf') ++ content = "# Original Content" ++ util.write_file(resolvconf, content) + renderer = self._get_renderer() + renderer.render_network_state(ns, target=render_dir) + found = dir2dict(render_dir) +@@ -3219,6 +3229,8 @@ TYPE=Ethernet + USERCTL=no + """ + self.assertEqual(expected, found[nspath + 'ifcfg-eth0']) ++ # a dhcp only config should not modify resolv.conf ++ self.assertEqual(content, found['/etc/resolv.conf']) + + def test_bond_config(self): + expected_name = 'expected_sysconfig_opensuse' diff --git a/cloud-init.changes b/cloud-init.changes index 99abc3a..2e5f14e 100644 --- a/cloud-init.changes +++ b/cloud-init.changes @@ -1,3 +1,10 @@ +------------------------------------------------------------------- +Tue Sep 24 18:46:00 UTC 2019 - Robert Schweikert + +- Add cloud-init-noresolv-merge-no-dns-data.diff + - Avoid writing resolv.conf if the network configuration contains no + dns entries. + ------------------------------------------------------------------- Mon Sep 23 13:05:03 UTC 2019 - Robert Schweikert diff --git a/cloud-init.spec b/cloud-init.spec index 59a1115..020121a 100644 --- a/cloud-init.spec +++ b/cloud-init.spec @@ -46,8 +46,10 @@ Patch43: cloud-init-write-routes.patch Patch47: cloud-init-trigger-udev.patch # FIXME (lp#1669875) patch by mvoelker@launchpad Patch48: cloud-init-detect-nova.diff -# FIXME (lp##1821102) +# FIXME (lp#1821102) Patch49: cloud-init-add-static-routes.diff +# FIXME (lp#1843634) +Patch50: cloud-init-noresolv-merge-no-dns-data.diff BuildRequires: fdupes BuildRequires: filesystem @@ -193,6 +195,7 @@ Documentation and examples for cloud-init tools %patch47 %patch48 -p1 %patch49 -p1 +%patch50 -p1 %build %if 0%{?suse_version} && 0%{?suse_version} <= 1315 From 4977fc7a3b8f197c1cc6002e7b00835dff2903e8c1a2b28e48b8899cb0e5e4f0 Mon Sep 17 00:00:00 2001 From: Robert Schweikert Date: Tue, 24 Sep 2019 19:53:38 +0000 Subject: [PATCH 3/4] - Add cloud-init-after-wicked.patch - Change the service order, the cloud-init service wants to run after networking is started OBS-URL: https://build.opensuse.org/package/show/Cloud:Tools/cloud-init?expand=0&rev=147 --- cloud-init-after-wicked.patch | 13 +++++++++++++ cloud-init.changes | 7 +++++++ cloud-init.spec | 3 +++ 3 files changed, 23 insertions(+) create mode 100644 cloud-init-after-wicked.patch diff --git a/cloud-init-after-wicked.patch b/cloud-init-after-wicked.patch new file mode 100644 index 0000000..4c08a41 --- /dev/null +++ b/cloud-init-after-wicked.patch @@ -0,0 +1,13 @@ +Index: cloud-init-19.1/systemd/cloud-init.service.tmpl +=================================================================== +--- cloud-init-19.1.orig/systemd/cloud-init.service.tmpl ++++ cloud-init-19.1/systemd/cloud-init.service.tmpl +@@ -14,7 +14,7 @@ After=networking.service + After=network.service + {% endif %} + {% if variant in ["suse"] %} +-Before=wicked.service ++After=wicked.service + # setting hostname via hostnamectl depends on dbus, which otherwise + # would not be guaranteed at this point. + After=dbus.service diff --git a/cloud-init.changes b/cloud-init.changes index 2e5f14e..4710502 100644 --- a/cloud-init.changes +++ b/cloud-init.changes @@ -1,3 +1,10 @@ +------------------------------------------------------------------- +Tue Sep 24 19:50:33 UTC 2019 - Robert Schweikert + +- Add cloud-init-after-wicked.patch + - Change the service order, the cloud-init service wants to run after + networking is started + ------------------------------------------------------------------- Tue Sep 24 18:46:00 UTC 2019 - Robert Schweikert diff --git a/cloud-init.spec b/cloud-init.spec index 020121a..f4a1159 100644 --- a/cloud-init.spec +++ b/cloud-init.spec @@ -50,6 +50,8 @@ Patch48: cloud-init-detect-nova.diff Patch49: cloud-init-add-static-routes.diff # FIXME (lp#1843634) Patch50: cloud-init-noresolv-merge-no-dns-data.diff +# FIXME +Patch51: cloud-init-after-wicked.patch BuildRequires: fdupes BuildRequires: filesystem @@ -196,6 +198,7 @@ Documentation and examples for cloud-init tools %patch48 -p1 %patch49 -p1 %patch50 -p1 +%patch51 -p1 %build %if 0%{?suse_version} && 0%{?suse_version} <= 1315 From eb8686803a0e5b2547ef82fb51c4758b32efad17fe5425f9dc077abf9f5fa9a4 Mon Sep 17 00:00:00 2001 From: Robert Schweikert Date: Thu, 26 Sep 2019 10:33:25 +0000 Subject: [PATCH 4/4] - Follow up to update cloud-init-trigger-udev.patch (bsc#1144363) OBS-URL: https://build.opensuse.org/package/show/Cloud:Tools/cloud-init?expand=0&rev=148 --- cloud-init.changes | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cloud-init.changes b/cloud-init.changes index 4710502..28abbc3 100644 --- a/cloud-init.changes +++ b/cloud-init.changes @@ -15,7 +15,7 @@ Tue Sep 24 18:46:00 UTC 2019 - Robert Schweikert ------------------------------------------------------------------- Mon Sep 23 13:05:03 UTC 2019 - Robert Schweikert -- Follow up to (bsc#1144363) +- Follow up to update cloud-init-trigger-udev.patch (bsc#1144363) - In this implementation the "name" is not yet an attribute, use get() to obtain the value from a dict. Source code version confusion.