summaryrefslogtreecommitdiff
path: root/vmdebootstrap
diff options
context:
space:
mode:
authorNeil Williams <codehelp@debian.org>2016-01-23 15:59:31 +0000
committerNeil Williams <codehelp@debian.org>2016-01-23 16:37:51 +0000
commit57ed283dc22e650e87293854cea6f5a4e4fa9e6c (patch)
tree20e7a5fef631c1474d7cf0e7fa65a1381dab38c9 /vmdebootstrap
parent99e7836b7d1ac552dbd5ec3e170fd62022d07493 (diff)
downloadvmdebootstrap-57ed283dc22e650e87293854cea6f5a4e4fa9e6c.tar.gz
Support btrfs filesystem
Sunil Mohan Adapa <sunil@medhas.org> - Do not pass errors=remount-ro mount flag for btrfs filesystems. Btrfs has this behavior by default and does not support the flag. - Add test scenario for btrfs. Check filesystem type and fstab entry. - Expand ext4 test to check for expected fstab entry. https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=741223
Diffstat (limited to 'vmdebootstrap')
-rw-r--r--vmdebootstrap/filesystem.py15
1 files changed, 13 insertions, 2 deletions
diff --git a/vmdebootstrap/filesystem.py b/vmdebootstrap/filesystem.py
index d17663e..0898de9 100644
--- a/vmdebootstrap/filesystem.py
+++ b/vmdebootstrap/filesystem.py
@@ -164,14 +164,25 @@ class Filesystem(Base):
fstab = os.path.join(str(rootdir), 'etc', 'fstab')
with open(fstab, 'w') as fstab:
fstab.write('proc /proc proc defaults 0 0\n')
- fstab.write('%s / %s errors=remount-ro 0 1\n' % (rootdevstr, roottype))
+ fstab.write('%s / %s %s 0 1\n' %
+ (rootdevstr, roottype, self.get_mount_flags(roottype)))
if bootdevstr:
- fstab.write('%s /boot %s errors=remount-ro 0 2\n' % (bootdevstr, boottype))
+ fstab.write('%s /boot %s %s 0 2\n' %
+ (bootdevstr, boottype, self.get_mount_flags(boottype)))
if self.settings['swap'] > 0:
fstab.write("/dev/sda3 swap swap defaults 0 0\n")
elif self.settings['swap'] > 0:
fstab.write("/dev/sda2 swap swap defaults 0 0\n")
+ @staticmethod
+ def get_mount_flags(fstype):
+ """Return the fstab mount flags for a given file system type."""
+ flags = ['errors=remount-ro']
+ if fstype == 'btrfs':
+ flags = []
+
+ return ','.join(flags) or 'defaults'
+
def squash_rootfs(self):
"""
Run squashfs on the rootfs within the image.