summaryrefslogtreecommitdiffstats
path: root/t-func/deb-split.at
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-06 00:45:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-06 00:45:20 +0000
commit9a08cbfcc1ef900a04580f35afe2a4592d7d6030 (patch)
tree004cc7027bca2f2c0bcb5806527c8e0c48df2d6e /t-func/deb-split.at
parentInitial commit. (diff)
downloaddpkg-upstream/1.19.8.tar.xz
dpkg-upstream/1.19.8.zip
Adding upstream version 1.19.8.upstream/1.19.8upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--t-func/deb-split.at89
1 files changed, 89 insertions, 0 deletions
diff --git a/t-func/deb-split.at b/t-func/deb-split.at
new file mode 100644
index 0000000..20a3519
--- /dev/null
+++ b/t-func/deb-split.at
@@ -0,0 +1,89 @@
+AT_TESTED([dpkg-split])
+
+AT_SETUP([dpkg-split options])
+AT_KEYWORDS([dpkg-split command-line])
+AT_CHECK([dpkg-split --help], [], [ignore])
+AT_CLEANUP
+
+AT_SETUP([dpkg-split .deb format])
+AT_KEYWORDS([dpkg-split deb-split])
+
+DPKG_GEN_CONTROL([pkg-split])
+DPKG_MOD_CONTROL([pkg-split],
+ [s/^Description:.*$/& - normal package to be split/])
+AT_CHECK([
+# Initialize the template package
+chmod -R u+w pkg-split
+# XXX: Some environments set SIGPIPE to ignore which we cannot reset, and 'yes'
+# does check print error conditions, so we ignore its error message here.
+yes 2>/dev/null | dd of=pkg-split/data-file bs=1024 count=1024 status=none
+find pkg-split | xargs touch -t 197001010100.00
+dpkg-deb --root-owner-group -Znone -b pkg-split >/dev/null
+])
+
+AT_CHECK([
+# Test splitting a package (in 3 parts: 400 KiB + 400 KiB + 224 KiB)
+dpkg-split -S 400 -s pkg-split.deb pkg-split-part
+test -f pkg-split-part.1of3.deb
+test -f pkg-split-part.2of3.deb
+test -f pkg-split-part.3of3.deb
+], [], [Splitting package pkg-split into 3 parts: 1 2 3 done
+])
+
+DEB_SPLIT_MD5SUM=c669258de88761bf90ad6621bdffd6f1
+DEB_SPLIT_LENGTH=1065152
+
+AT_CHECK_UNQUOTED([
+# Test getting information about the split parts (parsing verification)
+dpkg-split -I pkg-split-part.1of3.deb
+dpkg-split -I pkg-split-part.2of3.deb
+dpkg-split -I pkg-split-part.3of3.deb
+], [], [pkg-split-part.1of3.deb:
+ Part format version: 2.1
+ Part of package: pkg-split
+ ... version: 0.0-1
+ ... architecture: all
+ ... MD5 checksum: $DEB_SPLIT_MD5SUM
+ ... length: $DEB_SPLIT_LENGTH bytes
+ ... split every: 408576 bytes
+ Part number: 1/3
+ Part length: 408576 bytes
+ Part offset: 0 bytes
+ Part file size (used portion): 408780 bytes
+
+pkg-split-part.2of3.deb:
+ Part format version: 2.1
+ Part of package: pkg-split
+ ... version: 0.0-1
+ ... architecture: all
+ ... MD5 checksum: $DEB_SPLIT_MD5SUM
+ ... length: $DEB_SPLIT_LENGTH bytes
+ ... split every: 408576 bytes
+ Part number: 2/3
+ Part length: 408576 bytes
+ Part offset: 408576 bytes
+ Part file size (used portion): 408780 bytes
+
+pkg-split-part.3of3.deb:
+ Part format version: 2.1
+ Part of package: pkg-split
+ ... version: 0.0-1
+ ... architecture: all
+ ... MD5 checksum: $DEB_SPLIT_MD5SUM
+ ... length: $DEB_SPLIT_LENGTH bytes
+ ... split every: 408576 bytes
+ Part number: 3/3
+ Part length: 248000 bytes
+ Part offset: 817152 bytes
+ Part file size (used portion): 248204 bytes
+
+])
+
+AT_CHECK([
+# Test joining the split parts back together
+dpkg-split -o pkg-joined.deb -j pkg-split-part.*.deb
+cmp pkg-split.deb pkg-joined.deb
+], [], [Putting package pkg-split together from 3 parts: 1 2 3 done
+])
+
+AT_CLEANUP