From 86ec1b63f90bcf534292f3ddd9da9749c00d84ba Mon Sep 17 00:00:00 2001 From: Karel Zak Date: Tue, 27 Feb 2007 15:59:04 +0100 Subject: [PATCH] tests: add mkfs.cramfs tests This test shows that actual mkfs.cramfs is ugly due MAXENTRIES (100) limit. Signed-off-by: Karel Zak --- tests/Makefile.am | 3 +- tests/commands.sh.in | 1 + tests/ts-cramfs-mkfs | 114 +++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 117 insertions(+), 1 deletion(-) create mode 100755 tests/ts-cramfs-mkfs diff --git a/tests/Makefile.am b/tests/Makefile.am index 2be9c4b7..e448994e 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -14,7 +14,8 @@ EXTRA_DIST = expected/* \ ts-ipcs.sh \ ts-mkswap-doit \ ts-mount-paths \ - ts-namei-logic + ts-namei-logic \ + ts-cramfs-mkfs distclean-local: rm -rf output diff diff --git a/tests/commands.sh.in b/tests/commands.sh.in index 866c3947..435446b3 100644 --- a/tests/commands.sh.in +++ b/tests/commands.sh.in @@ -12,6 +12,7 @@ TS_CMD_SWAPOFF=${TS_CMD_SWAPOFF:-"$TOPDIR/mount/swapoff"} TS_CMD_LOSETUP=${TS_CMD_LOSETUP:-"$TOPDIR/mount/losetup"} TS_CMD_MKSWAP=${TS_CMD_MKSWAP:-"$TOPDIR/disk-utils/mkswap"} +TS_CMD_MKCRAMFS=${TS_CMD_MKCRAMFS:-"$TOPDIR/disk-utils/mkfs.cramfs"} TS_CMD_IPCS=${TS_CMD_IPCS:-"$TOPDIR/sys-utils/ipcs"} diff --git a/tests/ts-cramfs-mkfs b/tests/ts-cramfs-mkfs new file mode 100755 index 00000000..c1e63385 --- /dev/null +++ b/tests/ts-cramfs-mkfs @@ -0,0 +1,114 @@ +#!/bin/bash + +# +# Copyright (C) 2007 Karel Zak +# +# This file is part of util-linux-ng. +# +# This file is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License. +# +# This file 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. +# + +# Test cramfs + +. commands.sh +. functions.sh + +TS_COMPONENT="mkfs.cramfs" +TS_DESC="mkfs" + +ts_init + +if [ $UID != 0 ]; then + ts_skip "not root permissions" +fi + +set -o pipefail + + +touch $TS_OUTPUT + +IMAGE="$TS_OUTDIR/cramfs-loop.img" +IMAGE_DATA="$TS_OUTDIR/cramfs-data" +IMAGE_RE=$( echo $IMAGE | sed 's:/:\\/:g' ) +LABEL="testCramfs" +MOUNTPOINT="$TS_OUTDIR/cramfs-mnt" + +HLIMIT=110 + +echo "create mountpoint dir" >> $TS_OUTPUT +if [ ! -d "$MOUNTPOINT" ]; then + mkdir -p $MOUNTPOINT +fi + +echo "generate data" >> $TS_OUTPUT +if [ ! -d "$IMAGE_DATA" ]; then + mkdir -p $IMAGE_DATA + for d in `seq 0 $HLIMIT`; do + DIRNAME="$IMAGE_DATA/$(printf "dir-%03d" $d)" + mkdir -p $DIRNAME + for f in `seq 0 $HLIMIT`; do + FILENAME="$DIRNAME/$(printf "data.%03d" $f)" + printf "data in %03d-%03d" $d $f >> $FILENAME + done + done +fi + +echo "list checksums from original data" >> $TS_OUTPUT +find $IMAGE_DATA -type f -exec md5sum {} \; >> $TS_OUTPUT +echo >> $TS_OUTPUT + +echo "create cramfs image" >> $TS_OUTPUT +$TS_CMD_MKCRAMFS -n $LABEL $IMAGE_DATA $IMAGE 2>&1 >> $TS_OUTPUT + +if [ ! -s "$IMAGE" ]; then + echo "Cannot create $IMAGE" >> $TS_OUTPUT + ts_finalize +fi + +echo "count MD5 from the image" >> $TS_OUTPUT +md5sum $IMAGE 2>&1 >> $TS_OUTPUT +echo >> $TS_OUTPUT + +echo "create loop device from image" >> $TS_OUTPUT +DEVICE=$( $TS_CMD_LOSETUP -f ) +$TS_CMD_LOSETUP $DEVICE $IMAGE 2>&1 >> $TS_OUTPUT + + +echo "check the image" >> $TS_OUTPUT +blkid -c /dev/null -w /dev/null -s TYPE $DEVICE 2>&1 | grep -q 'TYPE="cramfs"' 2>&1 >> $TS_OUTPUT + +if [ "$?" != "0" ]; then + echo "Cannot found cramfs on $DEVICE" >> $TS_OUTPUT + ts_finalize +fi + +echo "mount the image" >> $TS_OUTPUT +$TS_CMD_MOUNT -L $LABEL $MOUNTPOINT 2>&1 >> $TS_OUTPUT + +# check it +grep -q $DEVICE /proc/mounts + +if [ "$?" != "0" ]; then + echo "Cannot found $DEVICE in /proc/mounts" >> $TS_OUTPUT +fi + +echo "list the image" >> $TS_OUTPUT +ls -laR $MOUNTPOINT >> $TS_OUTPUT +echo >> $TS_OUTPUT + +echo "list checksums from new data" >> $TS_OUTPUT +find $MOUNTPOINT -type f -exec md5sum {} \; >> $TS_OUTPUT +echo >> $TS_OUTPUT + +echo "umount the image" >> $TS_OUTPUT +$TS_CMD_UMOUNT $DEVICE +$TS_CMD_LOSETUP -d $DEVICE 2>&1 >> $TS_OUTPUT +ts_finalize + -- 2.39.5