aboutsummaryrefslogtreecommitdiff
path: root/testsuite
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2007-03-07 22:02:23 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2007-03-07 22:02:23 +0000
commitab9eef21a57c23567505e8fbceb8e5ea76306ce1 (patch)
tree800845b64d0e9a204743656c4d267cc6c9917cde /testsuite
parent8e858e2700651a0e973169b579622cd3dcd0defd (diff)
downloadbusybox-w32-ab9eef21a57c23567505e8fbceb8e5ea76306ce1.tar.gz
busybox-w32-ab9eef21a57c23567505e8fbceb8e5ea76306ce1.tar.bz2
busybox-w32-ab9eef21a57c23567505e8fbceb8e5ea76306ce1.zip
bunzip2/gunzip/uncompress/unlzma: merge into common code -
fix few corner cases, reduce size by 450 bytes. Update testsuite.
Diffstat (limited to 'testsuite')
-rwxr-xr-xtestsuite/bunzip2.tests84
-rwxr-xr-xtestsuite/bzcat.tests49
-rwxr-xr-xtestsuite/gunzip.tests3
3 files changed, 136 insertions, 0 deletions
diff --git a/testsuite/bunzip2.tests b/testsuite/bunzip2.tests
new file mode 100755
index 000000000..83c365d75
--- /dev/null
+++ b/testsuite/bunzip2.tests
@@ -0,0 +1,84 @@
1#!/bin/sh
2
3if test "${0##*/}" = "gunzip.tests"; then
4 unpack=gunzip
5 ext=gz
6elif test "${0##*/}" = "bunzip2.tests"; then
7 unpack=bunzip2
8 ext=bz2
9else
10 echo "WTF? argv0='$0'"
11 exit 1
12fi
13
14bb="busybox "
15
16unset LC_ALL
17unset LC_MESSAGES
18unset LANG
19unset LANGUAGE
20
21hello_gz() {
22 # Gzipped "HELLO\n"
23 #_________________________ vvv vvv vvv vvv - mtime
24 echo -ne "\x1f\x8b\x08\x00\x85\x1d\xef\x45\x02\x03\xf3\x70\xf5\xf1\xf1\xe7"
25 echo -ne "\x02\x00\x6e\xd7\xac\xfd\x06\x00\x00\x00"
26}
27
28hello_bz2() {
29 # Bzipped "HELLO\n"
30 echo -ne "\x42\x5a\x68\x39\x31\x41\x59\x26\x53\x59\x5b\xb8\xe8\xa3\x00\x00"
31 echo -ne "\x01\x44\x00\x00\x10\x02\x44\xa0\x00\x30\xcd\x00\xc3\x46\x29\x97"
32 echo -ne "\x17\x72\x45\x38\x50\x90\x5b\xb8\xe8\xa3"
33}
34
35prep() {
36 rm -f t*
37 hello_$ext >t1.$ext
38 hello_$ext >t2.$ext
39}
40
41check() {
42 eval $2 >t_actual 2>&1
43 if echo -ne "$expected" | cmp - t_actual; then
44 echo "$1: PASS"
45 else
46 echo "$1: FAIL"
47 fi
48}
49
50mkdir testdir 2>/dev/null
51(
52cd testdir || { echo "cannot cd testdir!"; exit 1; }
53
54expected="$unpack: z: No such file or directory
551
56HELLO
57"
58prep; check "$unpack: doesnt exist" "${bb}$unpack z t1.$ext; echo \$?; cat t1"
59
60
61expected="$unpack: t.zz: unknown suffix - ignored
621
63HELLO
64"
65prep; >t.zz; check "$unpack: unknown suffix" "${bb}$unpack t.zz t1.$ext; echo \$?; cat t1"
66
67
68# In this case file "t1" exists, and we skip t1.gz and unpack t2.gz
69expected="$unpack: t1: File exists
701
71HELLO
72"
73prep; >t1; check "$unpack: already exists" "${bb}$unpack t1.$ext t2.$ext; echo \$?; cat t1 t2"
74
75
76# From old testsuite
77expected="HELLO\n0\n"
78prep; check "$unpack: stream unpack" "cat t1.$ext | ${bb}$unpack; echo $?"
79
80expected="ok\n"
81prep; check "$unpack: delete src" "${bb}$unpack t2.$ext; test ! -f t2.$ext && echo ok"
82
83)
84rm -rf testdir \ No newline at end of file
diff --git a/testsuite/bzcat.tests b/testsuite/bzcat.tests
new file mode 100755
index 000000000..16fa3c248
--- /dev/null
+++ b/testsuite/bzcat.tests
@@ -0,0 +1,49 @@
1#!/bin/sh
2
3ext=bz2
4
5bb="busybox "
6
7unset LC_ALL
8unset LC_MESSAGES
9unset LANG
10unset LANGUAGE
11
12hello_gz() {
13 # Gzipped "HELLO\n"
14 #_________________________ vvv vvv vvv vvv - mtime
15 echo -ne "\x1f\x8b\x08\x00\x85\x1d\xef\x45\x02\x03\xf3\x70\xf5\xf1\xf1\xe7"
16 echo -ne "\x02\x00\x6e\xd7\xac\xfd\x06\x00\x00\x00"
17}
18
19hello_bz2() {
20 # Bzipped "HELLO\n"
21 echo -ne "\x42\x5a\x68\x39\x31\x41\x59\x26\x53\x59\x5b\xb8\xe8\xa3\x00\x00"
22 echo -ne "\x01\x44\x00\x00\x10\x02\x44\xa0\x00\x30\xcd\x00\xc3\x46\x29\x97"
23 echo -ne "\x17\x72\x45\x38\x50\x90\x5b\xb8\xe8\xa3"
24}
25
26prep() {
27 rm -f t*
28 hello_$ext >t1.$ext
29 hello_$ext >t2.$ext
30}
31
32check() {
33 eval $2 >t_actual 2>&1
34 if echo -ne "$expected" | cmp - t_actual; then
35 echo "$1: PASS"
36 else
37 echo "$1: FAIL"
38 fi
39}
40
41mkdir testdir 2>/dev/null
42(
43cd testdir || { echo "cannot cd testdir!"; exit 1; }
44
45expected="HELLO\nok\n"
46prep; check "bzcat: dont delete src" "${bb}bzcat t2.bz2; test -f t2.bz2 && echo ok"
47
48)
49rm -rf testdir
diff --git a/testsuite/gunzip.tests b/testsuite/gunzip.tests
new file mode 100755
index 000000000..d7810044f
--- /dev/null
+++ b/testsuite/gunzip.tests
@@ -0,0 +1,3 @@
1#!/bin/sh
2
3. bunzip2.tests