[Bug 1997467] Re: Update 0.105-0ubuntu2~22.04.1 seems to cause regressions with snapd integration
Launchpad Bug Tracker
1997467 at bugs.launchpad.net
Mon Feb 13 14:08:26 UTC 2023
** Merge proposal linked:
https://code.launchpad.net/~danilogondolfo/netplan/+git/ubuntu/+merge/437205
** Merge proposal linked:
https://code.launchpad.net/~danilogondolfo/netplan/+git/ubuntu/+merge/437206
--
You received this bug notification because you are a member of Ubuntu
Sponsors Team, which is subscribed to the bug report.
https://bugs.launchpad.net/bugs/1997467
Title:
Update 0.105-0ubuntu2~22.04.1 seems to cause regressions with snapd
integration
Status in netplan:
Fix Released
Status in netplan.io package in Ubuntu:
Fix Released
Status in netplan.io source package in Jammy:
Confirmed
Status in netplan.io source package in Kinetic:
Confirmed
Status in netplan.io source package in Lunar:
Fix Released
Bug description:
[Impact]
This release contains an important bug-fix, related to the "netplan set" subcommand,
and we would like to make sure all of our supported customers have access to this improvement.
The notable changes in the package are:
* d/p/lp1997467: set only specific origin-hint if given (LP: #1997467)
* d/libnetplan0.symbols: Add netplan_parser_load_nullable_overrides() API
The issues addressed by this SRU are described below.
Some regressions were introduced on netplan.io 0.105 in the subcommand "netplan set".
Users who rely on "netplan set" as part of their workflows, such as snapd, were affected
by these issues. Snapd in particular was forced to rollback to netplan.io 0.104 to unblock
their customers.
Issue 1) Deletion of the origin-hint file on update
netplan set --origin-hint test "bridges.br54.dhcp4=false"
The command above will create the file /etc/netplan/test.yaml
The command below should update the file, but it will be deleted instead
netplan set --origin-hint test "bridges.br54.dhcp4=true"
Issue 2) Updates being ignored when --origin-hint is used
Updates on interfaces already defined in another file are ignored.
The command below should create a new file (in this case called 90-snapd-config.yaml)
containing the definition specified by its last parameter:
netplan set --origin-hint 90-snapd-config bridges.br54.dhcp4=false
Although, if the interface br54 is already defined in another file, netplan set will not
create the file 90-snapd-config.yaml.
[Test Plan]
The following development and SRU process was followed:
https://wiki.ubuntu.com/NetplanUpdates
Netplan contains an extensive integration test suite that is ran using
the SRU package for each releases. This test suite's results are available here:
http://autopkgtest.ubuntu.com/packages/n/netplan.io
* Steps to reproduce the issue
This bug is easily reproducible on netplan.io 0.105-0ubuntu2, which is
used by Kinetic and Jammy.
1) Launch a LXD Jammy instance (either VM or container):
lxc launch ubuntu:22.04 jammy-netplan
2) Access the new instance
lxc exec jammy-netplan bash
3) (Optional) Upgrade your packages
apt update && apt -y upgrade
4) Check the netplan.io version you have
dpkg --list | grep netplan.io
You should see "0.105-0ubuntu2", the version with this bug.
5) Create the file /etc/netplan/0-snapd-defaults.yaml
cat <<EOF > /etc/netplan/0-snapd-defaults.yaml
network:
version: 2
ethernets:
ens3:
addresses:
- "10.0.2.15/24"
dhcp4: false
routes:
- to: "default"
via: "10.0.2.2"
bridges:
br54:
dhcp4: true
EOF
6) Use "netplan set" to create a new file that will be used to change
the bridge configuration defined in the previous file
netplan set --origin-hint 90-snapd-config
network.bridges.br54.dhcp4=false
7) Checking the results
After running "netplan set" you should find a new file at /etc/netplan called 90-snapd-config.yaml
containing only the snippet "network.bridges.br54.dhcp4=false" set with netplan set. It looks like this:
# cat /etc/netplan/90-snapd-config.yaml
network:
version: 2
bridges:
br54:
dhcp4: false
If you are running the netplan.io version affected by this issue, you will not find the new file.
That is the main problem this SRU addresses.
8) Now add the PPA below which contains a netplan.io package with
patches for this issue
sudo add-apt-repository ppa:danilogondolfo/netplan.io
apt update
apt upgrade
9) Try netplan set again
netplan set --origin-hint 90-snapd-config
network.bridges.br54.dhcp4=false
After running "netplan set" the file /etc/netplan/90-snapd-config.yaml
will be generated.
A successful run is required before the proposed netplan package
can be let into -updates.
The netplan team will be in charge of attaching the artifacts and console
output of the appropriate run to the bug. Netplan team members will not
mark ‘verification-done’ until this has happened.
[Where problems could occur]
As this patch changes a small portion of code used by the netplan generator (and the "netplan generate" command),
an issue introduced by this change would potentially affect the network configuration generated when the system boots up.
In the worst scenario it would end up removing old configuration and not generating new one or missing some parts of it
preventing the system to have a working network connection.
The new package containing the fixes is available in Lunar for many days now and no issues like the aforementioned
ones were reported.
In order to mitigate the regression potential, the results of the
aforementioned integration tests are attached to this bug.
[Other Info]
There are remaining known bugs on "netplan set" that were detected recently but we confirmed they
are not regressions caused by this patch as they were already present in netplan. They are all
documented in LP: #2003727.
The issues addressed by this SRUs are the only ones causing real
impact to customers based on LP bug reports.
[Changelog]
Bug fixes:
- d/p/lp1997467: set only specific origin-hint if given (LP: #1997467)
Cherry-picked from upstream: https://github.com/canonical/netplan/pull/299
- d/libnetplan0.symbols: Add netplan_parser_load_nullable_overrides() API
==== Original report ====
Sorry that this is a bit unspecific right now, I will try to provide
more details ASAP.
We see failures in our nested core20-early-config test, e.g.
https://github.com/snapcore/snapd/actions/runs/3512986269/jobs/5885568960
The test fails in the following place:
"""
...
+ remote.exec 'sudo snap set system system.network.netplan.network.bridges.br54.dhcp4=false'
+ MATCH false
+ remote.exec sudo 'netplan get bridges.br54.dhcp4'
grep error: pattern not found, got:
true
"""
at this point the files look like this (sudo is now needed which was not before btw):
"""
$ sudo cat /etc/netplan/0-snapd-defaults.yaml
network:
version: 2
ethernets:
ens3:
addresses:
- "10.0.2.15/24"
dhcp4: false
routes:
- to: "default"
via: "10.0.2.2"
bridges:
br54:
dhcp4: true
$ sudo cat /etc/netplan/50-cloud-init.yaml
# This file is generated from information provided by the datasource. Changes
# to it will not persist across an instance reboot. To disable cloud-init's
# network configuration capabilities, write a file
# /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg with the following:
# network: {config: disabled}
network:
ethernets:
enp0s2:
dhcp4: true
match:
macaddress: '52:54:00:12:34:56'
set-name: enp0s2
version: 2
"""
When I manually run
$ sudo snap set system
system.network.netplan.network.bridges.br54.dhcp4=false
inside the VM I see no error but the file 0-snapd-defaults.yaml is unchanged and no
new file 90-snapd-config is created. The logic inside snapd is that the gadget defaults
are stored as 0-snapd-defaults and later changes are stored in 90-sanpd-config so that
the later config values win over the earlier ones.
Fwiw, this test is also run on a core20 system with netplan 104 and
there the same test works succesfully afaict.
To manage notifications about this bug go to:
https://bugs.launchpad.net/netplan/+bug/1997467/+subscriptions
More information about the Ubuntu-sponsors
mailing list