Files
snapd/osutil/mount_linux.go
Ian Johnson d33346c0e6 osutil: don't export ProcSelfMountInfo, use mocked string
Many tests currently implicitly rely on reading state from /proc/self/mountinfo
through the system-key or other various aspects that care about what's mounted
on the system. These tests currently suffer from leaking state from the host
system that the unit test is being run on into the test, exposing us to a
problem where we may have false positives if these tests are run on systems with
the state present and the state was not properly mocked.

To alleviate this, we make LoadMountInfo take no arguments and panic if it was
not properly mocked during tests. The proper way to mock mountinfo now is to use
MockMountInfo(), which is now exported and will do the right thing.

This does mean we have to eliminate a test in osutil which was testing about the
filename argument to LoadMountInfo which no longer is possible.

Signed-off-by: Ian Johnson <ian.johnson@canonical.com>
2020-04-07 09:31:42 -05:00

35 lines
987 B
Go

// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2014-2016 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package osutil
// IsMounted checks if a given directory is a mount point.
func IsMounted(baseDir string) (bool, error) {
entries, err := LoadMountInfo()
if err != nil {
return false, err
}
for _, entry := range entries {
if baseDir == entry.MountDir {
return true, nil
}
}
return false, nil
}