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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.