lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <94b2afa4-fa22-ae96-3fff-203e5237d76f@redhat.com>
Date:   Fri, 22 Jun 2018 11:18:06 -0500
From:   Eric Sandeen <esandeen@...hat.com>
To:     Lukas Czerner <lczerner@...hat.com>, linux-ext4@...r.kernel.org
Subject: Re: [PATCH] tests: add raw/e2i/qcow2 image create/install test

On 4/11/18 7:24 AM, Lukas Czerner wrote:
> Test raw, qcow2 and e2i image format creation and e2i install. We
> iterate over ext2/ext3/ext4 file system type and 1k/2k/4k block sizes
> just to make sure. The test is fast enough so it's ok.
> 
> Signed-off-by: Lukas Czerner <lczerner@...hat.com>
> ---
>  tests/i_images/expect | 117 ++++++++++++++++++++++++++++++++++++++++++++++++++
>  tests/i_images/script |  76 ++++++++++++++++++++++++++++++++
>  2 files changed, 193 insertions(+)
>  create mode 100644 tests/i_images/expect
>  create mode 100644 tests/i_images/script
> 
> diff --git a/tests/i_images/expect b/tests/i_images/expect
> new file mode 100644
> index 0000000..c5097d1
> --- /dev/null
> +++ b/tests/i_images/expect
> @@ -0,0 +1,117 @@
> +Create ext2 file system with block size 1024
> +Create images
> +Verify raw and qcow crc
> +Dump metadata
> +Check metadata dump - raw
> +Check metadata dump - qcow2 to raw
> +Check metadata dump - e2i
> +Install image
> +Verify metadata dump
> +Create ext2 file system with block size 2014

2048 maybe?

...

+Check metadata dump - e2i
+41,45d40
+< Journal features:         (none)
+< Journal size:             1024k
+< Journal length:           1024
+< Journal sequence:         0x00000001
+< Journal start:            0

Is it expected to not have this info from the metadata dump?
I wonder if it'd be better to explicitly filter it out with a comment
about why, if so.  Just a thought.

> diff --git a/tests/i_images/script b/tests/i_images/script
> new file mode 100644
> index 0000000..45369ec
> --- /dev/null
> +++ b/tests/i_images/script
> @@ -0,0 +1,76 @@
> +test_description="create/install raw/qcow2/metadata images"
> +if test -x $E2IMAGE_EXE; then
> +
> +OUT=$test_name.log
> +EXP=$test_dir/expect
> +TMP=$(mktemp)
> +
> +rm -f ${TMP}* $OUT >/dev/null 2>&1
> +
> +(
> +for fstype in ext2 ext3 ext4; do
> +	for bs in 1024 2014 4096; do
                       ^2048 I bet ...

> +		ORIG_IMG=$test_name/orig_image_${bs}
> +		rm -f $ORIG_IMG
> +
> +		echo "Create $fstype file system with block size $bs"
> +		truncate -s10M $ORIG_IMG
> +		$MKE2FS -q -E lazy_itable_init=1 -t $fstype -F -o Linux -b $bs $ORIG_IMG

just curious, is "-o Linux" required? *shrug* I guess most tests do this, nvm.

would it be good to populate the fs a little, or is a freshly made fs enough?
(I know we could complicate this indefinitely, just wondering how far to go)

> +
> +		echo "Create images"
> +		$E2IMAGE $ORIG_IMG ${TMP}.e2i
> +		$E2IMAGE -r $ORIG_IMG ${TMP}.raw
> +		$E2IMAGE -Q $ORIG_IMG ${TMP}.qcow2
> +		$E2IMAGE -r ${TMP}.qcow2 ${TMP}.qcow2raw

should it also test

  +		$E2IMAGE -r ${TMP}.e2i ${TMP}.e2i2raw

for completeness?

> +
> +		$CRCSUM ${TMP}.raw  > ${TMP}.crc.raw
> +		$CRCSUM ${TMP}.qcow2raw  > ${TMP}.crc.qcow2raw
> +
> +		# Verify that raw image created from original fs and from qcow2 are
> +		# the same
> +		echo "Verify raw and qcow crc"
> +		diff ${TMP}.crc.raw ${TMP}.crc.qcow2raw
> +
> +		echo "Dump metadata"
> +		$DUMPE2FS $ORIG_IMG > ${TMP}.dump.orig
> +		$DUMPE2FS ${TMP}.raw > ${TMP}.dump.raw
> +		$DUMPE2FS ${TMP}.qcow2raw > ${TMP}.dump.qcow2raw
> +		$DUMPE2FS -i ${TMP}.e2i > ${TMP}.dump.e2i
> +
> +		# Check the metedata dumps
> +		echo "Check metadata dump - raw"
> +		diff ${TMP}.dump.orig ${TMP}.dump.raw
> +		echo "Check metadata dump - qcow2 to raw"
> +		diff ${TMP}.dump.orig ${TMP}.dump.qcow2raw
> +		echo "Check metadata dump - e2i"
> +		diff ${TMP}.dump.orig ${TMP}.dump.e2i
> +
> +		echo "Install image"
> +		cp $ORIG_IMG ${ORIG_IMG}.copy
> +		$E2IMAGE -I ${ORIG_IMG}.copy ${TMP}.e2i
> +		$DUMPE2FS ${ORIG_IMG} > ${TMP}.dump.copy
> +
> +		# Verify crc and meta dump

no CRC happening here that I can see...

> +		echo "Verify metadata dump"
> +		diff ${TMP}.dump.orig ${TMP}.dump.copy
> +
> +		rm -f ${ORIG_IMG}* ${TMP}.* >/dev/null 2>&1
> +	done
> +done
> +) 2>&1 | sed -f $cmd_dir/filter.sed >> $OUT 2>&1
> +
> +cmp -s $OUT $EXP
> +if [ $? -eq 0 ]; then
> +        echo "$test_name: $test_description: ok"
> +        touch $test_name.ok
> +else
> +        diff $DIFF_OPTS $EXP $OUT > $test_name.failed
> +        echo "$test_name: $test_description: failed"
> +fi
> +
> +rm -f ${TMP}* >/dev/null 2>&1
> +
> +else #if test -x $E2IMAGE_EXE; then
> +        echo "$test_name: $test_description: skipped"
> +fi
> +
> 

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ