diff options
| author | Michael Vogt <mvo@ubuntu.com> | 2023-07-19 19:35:57 +0200 | 
|---|---|---|
| committer | Michael Vogt <mvo@ubuntu.com> | 2023-07-19 19:35:57 +0200 | 
| commit | c3d5df36c357d3d40ddecdbf00889153a7cd9037 (patch) | |
| tree | db9b9df9c6b710d6bae826c843424a31cf57ab49 | |
| parent | 9431b3f822846deec013c7449ff4de0b5c9b7b15 (diff) | |
systemd: fix incorrect err handling in ensureMountUnitFile()fix-systemd-ensure-file-state-wrong-err
The ensureMountUnitFile() was not handling errors from osutil.EnsureFileState() correctly. This commit fixes this and adds a unit test. 
| -rw-r--r-- | systemd/systemd.go | 4 | ||||
| -rw-r--r-- | systemd/systemd_test.go | 19 | 
2 files changed, 21 insertions, 2 deletions
| diff --git a/systemd/systemd.go b/systemd/systemd.go index 7bc92a46ca..48ca5f997e 100644 --- a/systemd/systemd.go +++ b/systemd/systemd.go @@ -1429,8 +1429,8 @@ func ensureMountUnitFile(u *MountUnitOptions) (mountUnitName string, modified mo 	if stateErr == osutil.ErrSameState { 	modified = mountUnchanged -	} else if err != nil { -	return "", mountUnchanged, err +	} else if stateErr != nil { +	return "", mountUnchanged, stateErr 	} 	return filepath.Base(mu), modified, nil diff --git a/systemd/systemd_test.go b/systemd/systemd_test.go index f177094f34..93e795417e 100644 --- a/systemd/systemd_test.go +++ b/systemd/systemd_test.go @@ -2411,3 +2411,22 @@ func (s *systemdErrorSuite) TestErrorStringNoSystemctl(c *C) { 	_, err := Version() 	c.Check(err, ErrorMatches, `systemctl command \[--version\] failed with: exec: "systemctl": executable file not found in \$PATH`)  } + +func (s *systemdErrorSuite) TestEnsureMountUnitFileEnsureFileStateErr(c *C) { +	dirs.SetRootDir(c.MkDir()) +	defer dirs.SetRootDir("") + +	restore := osutil.MockMountInfo("") +	defer restore() + +	mockSnapPath := filepath.Join(dirs.GlobalRootDir, "/var/lib/snappy/snaps/foo_1.0.snap") +	makeMockFile(c, mockSnapPath) + +	// trigger an error below by creating a directory with the +	// same name as the mount unit file +	err := os.MkdirAll(filepath.Join(dirs.GlobalRootDir, "/etc/systemd/system/snap-snapname-123.mount"), 0755) +	c.Assert(err, IsNil) + +	_, err = New(SystemMode, nil).EnsureMountUnitFile("foo", "42", mockSnapPath, "/snap/snapname/123", "squashfs") +	c.Assert(err, ErrorMatches, `rename .*/etc/systemd/system/snap-snapname-123.mount.* .*/etc/systemd/system/snap-snapname-123.mount: file exists`) +} | 
