From: Jeff Liu <jeff.liu@oracle.com>
To: xfs@oss.sgi.com
Subject: [PATCH v2] xfstests: improve test 286 for repeated unwritten/hole extents.
Date: Tue, 03 Jul 2012 23:41:10 +0800 [thread overview]
Message-ID: <4FF31296.8050406@oracle.com> (raw)
v2->v1.
* Drop the diff of seq.full.
Signed-off-by: Jie Liu <jeff.liu@oracle.com>
---
286 | 87
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 86 insertions(+), 1 deletions(-)
diff --git a/286 b/286
index 03c343f..75b2151 100644
--- a/286
+++ b/286
@@ -105,10 +105,95 @@ test02()
cmp $src $dest || _fail "TEST02: file bytes check failed"
}
-rm -f $seq.full
+# seek_copy_test_03 - tests file with unwritten with data, repeated
unwritten
+# without data, as well as data extents mapping.
+# verify results:
+# 1. file size is identical.
+# 2. perform cmp(1) to compare SRC and DEST file byte by byte.
+test03()
+{
+ rm -rf $src $dest
+
+ write_cmd="-c \"truncate 200m\""
+
+ #
+ # Firstly, make the file with allocated && reserved extents
+ # mapping without real data wrote.
+ #
+ for i in $(seq 0 10 180); do
+ offset=$(($((10 << 20)) + $i * $((1 << 20))))
+ write_cmd="$write_cmd -c \"falloc $offset 10m\""
+ done
+
+ #
+ # Secondly, write data to some unwritten extents, hence we
+ # have a test file will extents mapping as:
+ # |data|multiple unwritten_without_data|data| repeat...
+ for i in $(seq 0 60 180); do
+ offset=$(($((20 << 20)) + $i * $((1 << 20))))
+ write_cmd="$write_cmd -c \"pwrite $offset 10m\""
+ done
+
+ echo "*** test03() create sparse file ***" >>$seq.full
+ eval ${XFS_IO_PROG} -F -f "${write_cmd}" $src >>$seq.full 2>&1 ||
+ _fail "create sparse file failed!"
+ echo "*** test03() create sparse file done ***" >>$seq.full
+ echo >>$seq.full
+ $here/src/seek_copy_test $src $dest
+ test $(stat --printf "%s" $src) = $(stat --printf "%s" $dest) ||
+ _fail "TEST03: file size check failed"
+
+ cmp $src $dest || _fail "TEST03: file bytes check failed"
+}
+
+# seek_copy_test_04 - tests file with hole, repeated unwritten
+# without data, as well as data extents mapping.
+# verify results:
+# 1. file size is identical.
+# 2. perform cmp(1) to compare SRC and DEST file byte by byte.
+test04()
+{
+ rm -rf $src $dest
+
+ write_cmd="-c \"truncate 200m\""
+
+ #
+ # Firstly, make the file with allocated && reserved extents
+ # mapping without real data wrote.
+ #
+ for i in $(seq 30 30 180); do
+ offset=$(($((30 << 20)) + $i * $((1 << 20))))
+ write_cmd="$write_cmd -c \"falloc $offset 5m\""
+ done
+
+ #
+ # Secondly, write data to some unwritten extents, hence we
+ # have a test file will extents mapping as:
+ # |hole|multiple unwritten_without_data|hole|data| repeat...
+ for i in $(seq 30 90 180); do
+ offset=$(($((30 << 20)) + $i * $((1 << 20))))
+ write_cmd="$write_cmd -c \"pwrite $offset 2m\""
+ done
+
+ echo "*** test04() create sparse file ***" >>$seq.full
+ eval ${XFS_IO_PROG} -F -f "${write_cmd}" $src >>$seq.full 2>&1 ||
+ _fail "create sparse file failed!"
+ echo "*** test04() create sparse file done ***" >>$seq.full
+ echo >>$seq.full
+ $here/src/seek_copy_test $src $dest
+
+ test $(stat --printf "%s" $src) = $(stat --printf "%s" $dest) ||
+ _fail "TEST04: file size check failed"
+
+ cmp $src $dest || _fail "TEST04: file bytes check failed"
+}
+
+rm -f $seq.full
test01
test02
+test03
+test04
status=0
exit
--
1.7.9
_______________________________________________
xfs mailing list
xfs@oss.sgi.com
http://oss.sgi.com/mailman/listinfo/xfs
next reply other threads:[~2012-07-03 15:41 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-03 15:41 Jeff Liu [this message]
2012-07-09 15:18 ` [PATCH v2] xfstests: improve test 286 for repeated unwritten/hole extents Mark Tinguely
2012-07-17 7:18 ` Christoph Hellwig
2012-09-24 21:24 ` Mark Tinguely
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4FF31296.8050406@oracle.com \
--to=jeff.liu@oracle.com \
--cc=xfs@oss.sgi.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox