From 7eb04b86ed003bc1dc0736c2631bada5132218c5 Mon Sep 17 00:00:00 2001 From: Thomas Waldmann Date: Tue, 4 Apr 2023 23:22:30 +0200 Subject: [PATCH] mount: improve mountpoint error msgs, see #7496 saying "must be a writable directory" can distract from the real root cause as seen in #7496. so we better first check if the mountpoint is an existing directory and if not, just tell that. after that, we check permissions and if they are not like required, tell that. --- src/borg/archiver/mount_cmds.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/borg/archiver/mount_cmds.py b/src/borg/archiver/mount_cmds.py index a9209424f..5445cfd03 100644 --- a/src/borg/archiver/mount_cmds.py +++ b/src/borg/archiver/mount_cmds.py @@ -24,8 +24,12 @@ def do_mount(self, args): self.print_error("borg mount not available: no FUSE support, BORG_FUSE_IMPL=%s." % BORG_FUSE_IMPL) return self.exit_code - if not os.path.isdir(args.mountpoint) or not os.access(args.mountpoint, os.R_OK | os.W_OK | os.X_OK): - self.print_error("%s: Mountpoint must be a writable directory" % args.mountpoint) + if not os.path.isdir(args.mountpoint): + self.print_error(f"{args.mountpoint}: Mountpoint must be an **existing directory**") + return self.exit_code + + if not os.access(args.mountpoint, os.R_OK | os.W_OK | os.X_OK): + self.print_error(f"{args.mountpoint}: Mountpoint must be a **writable** directory") return self.exit_code return self._do_mount(args)