../imagex $@ > /dev/null
}
+__do_unmount() {
+ if ! fusermount -u $1; then
+ error "Failed to unmount \"$1\""
+ fi
+
+}
do_unmount() {
if mountpoint $1 &> /dev/null; then
- if ! fusermount -u $1; then
- error "Failed to unmount \"$1\""
- fi
+ __do_unmount $1
fi
}
-do_mount() {
- do_unmount $2
+__do_mount() {
options="$3"
if ! ntfs-3g ${options:+-o $options} $1 $2; then
error "Could not mount NTFS volume \"$1\" on \"$2\". Make sure ntfs-3g is installed."
fi
}
+do_mount() {
+ do_unmount $2
+ __do_mount $1 $2 $3
+}
+
do_mkntfs() {
if ! mkntfs --force --fast $1 &> /dev/null; then
error "Could not create NTFS volume on \"$1\". Make sure ntfs-3g / ntfsprogs are installed"
init() {
echo "Creating NTFS volumes and empty directories to use as mountpoints"
- dd if=/dev/zero of=in.ntfs bs=4096 count=1000 &> /dev/null
- dd if=/dev/zero of=out.ntfs bs=4096 count=1000 &> /dev/null
+ dd if=/dev/zero of=in.ntfs bs=4096 count=260 &> /dev/null
+ dd if=/dev/zero of=out.ntfs bs=4096 count=260 &> /dev/null
mkdir in.mnt out.mnt
do_mkntfs in.ntfs
do_mkntfs out.ntfs
+ do_mount in.ntfs in.mnt
}
cleanup() {
exit 1
}
-do_capture() {
- do_unmount in.mnt
+do_test() {
+ cd in.mnt
+ eval "$1"
+ cd ..
+ __do_unmount in.mnt
if ! imagex capture in.ntfs ntfs.wim; then
error "Failed to capture NTFS volume into a WIM"
fi
-}
-
-do_apply() {
- do_unmount out.mnt
- do_mkntfs out.ntfs
if ! imagex apply ntfs.wim 1 out.ntfs; then
error "Failed to apply WIM to NTFS volume"
fi
-}
-
-cmp_xattrs() {
- infile=$1
- outfile=$2
- xattr=$3
- #echo "Comparing xattr $xattr of $infile and $outfile"
- if test "$xattr" = "system.ntfs_times"; then
- headnum=24
- else
- headnum=1000000000
+ __do_mount in.ntfs in.mnt noatime
+ __do_mount out.ntfs out.mnt noatime
+ if [ -x /usr/bin/tree ]; then
+ tree in.mnt --inodes -F -s --noreport
fi
- if eval getfattr --only-values -h -d -n $xattr $infile 2>/dev/null\
- | head -c $headnum > in.xattr; then
- if eval getfattr --only-values -h -d -n $xattr $outfile 2>/dev/null\
- | head -c $headnum > out.xattr; then
- if ! cmp in.xattr out.xattr; then
- error "Extended attribute $xattr of $infile and $outfile differs"
- fi
- else
- error "$infile has extended attribute $xattr, but $outfile doesn't"
- fi
- else
- if eval getfattr --only-values -h -d -n $xattr $outfile 2>/dev/null\
- | head -c $headnum > out.xattr; then
- error "$outfile has extended attribute $xattr, but $infile doesn't"
+ if ! ./ntfs-cmp in.mnt out.mnt; then
+ if [ -x /usr/bin/tree ]; then
+ echo "Dumping tree of applied image"
+ tree out.mnt --inodes -F -s --noreport
+ error 'Information was lost or corrupted while capturing
+ and then applying a NTFS volume'
fi
fi
-}
-
-# Captures in.ntfs, applies it to out.ntfs, and diffs the result including
-# extended attributes
-do_capture_and_apply() {
- do_capture
- do_apply
- do_mount in.ntfs in.mnt ro
- do_mount out.ntfs out.mnt ro
- #if ! diff -r in.mnt out.mnt; then
- #error "Recursive diff of original NTFS volume with applied NTFS volume failed"
- #fi
- for infile in `find in.mnt`; do
- outfile=out.mnt${infile##in.mnt}
- #echo "Comparing xattrs of $infile and $outfile"
- if [ ! -L $infile -a ! -d $infile ]; then
- if ! cmp $infile $outfile; then
- error "Contents of $infile and $outfile differed"
- fi
- fi
- cmp_xattrs $infile $outfile system.ntfs_attrib
- cmp_xattrs $infile $outfile system.ntfs_reparse_data
- cmp_xattrs $infile $outfile system.ntfs_acl
- cmp_xattrs $infile $outfile system.ntfs_dos_name
- cmp_xattrs $infile $outfile system.ntfs_times
- done
-}
-
-build_ntfs() {
- do_unmount in.mnt
- do_mkntfs in.ntfs
- do_mount in.ntfs in.mnt
- ( cd in.mnt; eval "$1" )
-}
-
-do_test() {
- build_ntfs "$1"
- do_capture_and_apply
+ rm -rf out.mnt/* in.mnt/*
+ __do_unmount out.mnt
}
msg() {
echo "Testing image capture and application of $1"
init
msg "Empty NTFS volume"
-do_capture_and_apply
+do_test ""
msg "NTFS volume containing a single file"
do_test "echo 1 > file"
msg "NTFS volume containing file with DOS name"
do_test "echo 1 > file; setfattr -v file -n system.ntfs_dos_name file"
-msg "NTFS volume containing file with DOS name with hardlink in same directory"
-do_test "echo 1 > file; setfattr -v file -n system.ntfs_dos_name file; ln file link"
-
+msg "NTFS volume containing file with DOS name with alphabetically smaller hardlink in same directory"
+do_test "echo 1 > file; setfattr -v file -n system.ntfs_dos_name file; ln file aaa_link"
+
+msg "NTFS volume containing file with DOS name with alphabetically larger hardlink in same directory"
+do_test "echo 1 > file; setfattr -v file -n system.ntfs_dos_name file; ln file zzz_link"
+
+msg "NTFS volume containing file with long name and with DOS name with alphabetically smaller hardlink in same directory"
+do_test 'echo 1 > file_with_a_long_name;
+ setfattr -v "file~1" -n system.ntfs_dos_name file_with_a_long_name;
+ ln file_with_a_long_name aaa_link'
+
+msg "NTFS volume containing many nested directories"
+do_test 'mkdir dir; mkdir dir/subdir; mkdir dir/subdir/subdir2; mkdir dir/subdir/subdir3'
+
+msg "NTFS volume containing identical files and symlinks in subdirectory"
+do_test 'mkdir dir;
+ echo 888 > dir/file;
+ echo 888 > dir/idfile2;
+ ln -s ../dir dir/circle; ln -s file dir/filelink'
+
+msg "NTFS volume containing hard link group and identical files not hard linked"
+do_test 'echo 888 > file;
+ echo 888 > file2;
+ ln file link;
+ ln file link2;
+ echo 888 > file3'
+
+msg "NTFS volume containing file with named data stream"
+do_test 'echo 1 > file;
+ setfattr -n user.ads -v 2 file'
+
+msg "NTFS volume containing file with multiple named data streams"
+do_test 'echo 1 > file;
+ setfattr -n user.a -v 1 file;
+ setfattr -n user.aa -v 11 file;
+ setfattr -n user.aaa -v 111 file;
+ setfattr -n user.aaaa -v 1111 file'
+
+msg "NTFS volume containing file with multiple named data streams with same contents"
+do_test 'echo 1 > file;
+ setfattr -n user.a -v 1111 file;
+ setfattr -n user.aa -v 1111 file;
+ setfattr -n user.aaa -v 1111 file;
+ setfattr -n user.aaaa -v 1111 file;'
+
+msg "NTFS volume containing file with named data streams with same contents as other file"
+do_test 'echo -n > file;
+ setfattr -n user.a -v 1111 file;
+ echo -n 1111 > otherfile;'
+
+msg "NTFS volume containing file with empty named data stream and non-empty unnamed data stream"
+do_test 'echo 1 > file;
+ setfattr -n user.ads -v "" file;'
+
+msg "NTFS volume containing file with empty named data stream and empty unnamed data stream"
+do_test 'echo -n > file;
+ setfattr -n user.ads -v "" file;'
+
+msg "NTFS volume containing file with named data stream with hardlink"
+do_test 'echo 999 > file;
+ setfattr -n user.ads -v "888" file;
+ ln file link;'
+
+msg "NTFS volume containing file with named data stream with hardlink and DOS name"
+do_test 'echo 999 > file;
+ setfattr -n user.ads -v "888" file;
+ ln file link;
+ setfattr -v DOSNAME -n system.ntfs_dos_name file;'