38abb26b5a
- Add support for extracting xar and rpm archives - Add libarchive_fe subdir (common code for tar and cpio) Approved by: kientzle MFC after: 2 weeks
129 lines
4.5 KiB
C
129 lines
4.5 KiB
C
/*-
|
|
* Copyright (c) 2003-2007 Tim Kientzle
|
|
* Copyright (c) 2009 Michihiro NAKAJIMA
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
#include "test.h"
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
/*
|
|
Execute the following command to rebuild the data for this program:
|
|
tail -n +32 test_read_format_cpio_svr4_gzip_rpm.c | /bin/sh
|
|
|
|
F=test_read_format_cpio_svr4_gzip_rpm.rpm
|
|
NAME=rpmsample
|
|
TMPRPM=/tmp/rpm
|
|
rm -rf ${TMPRPM}
|
|
mkdir -p ${TMPRPM}/BUILD
|
|
mkdir -p ${TMPRPM}/RPMS
|
|
mkdir -p ${TMPRPM}/SOURCES
|
|
mkdir -p ${TMPRPM}/SPECS
|
|
mkdir -p ${TMPRPM}/SRPMS
|
|
echo "hello" > ${TMPRPM}/BUILD/file1
|
|
echo "hello" > ${TMPRPM}/BUILD/file2
|
|
echo "hello" > ${TMPRPM}/BUILD/file3
|
|
cat > ${TMPRPM}/SPECS/${NAME}.spec <<END
|
|
##
|
|
%define _topdir ${TMPRPM}
|
|
%define _binary_payload w9.gzdio
|
|
|
|
Summary: Sample data of RPM filter of libarchive
|
|
Name: ${NAME}
|
|
Version: 1.0.0
|
|
Release: 1
|
|
License: BSD
|
|
URL: http://code.google.com/p/libarchive
|
|
BuildArch: noarch
|
|
BuildRoot: %{_tmppath}/%{name}-%{version}-root
|
|
|
|
%install
|
|
rm -rf \$RPM_BUILD_ROOT
|
|
|
|
mkdir -p \$RPM_BUILD_ROOT%{_sysconfdir}
|
|
install -m 644 file1 \$RPM_BUILD_ROOT%{_sysconfdir}/file1
|
|
install -m 644 file2 \$RPM_BUILD_ROOT%{_sysconfdir}/file2
|
|
install -m 644 file3 \$RPM_BUILD_ROOT%{_sysconfdir}/file3
|
|
TZ=utc touch -afm -t 197001020000.01 \$RPM_BUILD_ROOT%{_sysconfdir}/file1
|
|
TZ=utc touch -afm -t 197001020000.01 \$RPM_BUILD_ROOT%{_sysconfdir}/file2
|
|
TZ=utc touch -afm -t 197001020000.01 \$RPM_BUILD_ROOT%{_sysconfdir}/file3
|
|
|
|
%files
|
|
%{_sysconfdir}/file1
|
|
%{_sysconfdir}/file2
|
|
%{_sysconfdir}/file3
|
|
|
|
%description
|
|
Sample data.
|
|
END
|
|
#
|
|
rpmbuild -bb ${TMPRPM}/SPECS/${NAME}.spec
|
|
uuencode ${F} < ${TMPRPM}/RPMS/noarch/${NAME}-1.0.0-1.noarch.rpm > ${F}.uu
|
|
|
|
rm -rf ${TMPRPM}
|
|
exit 1
|
|
*/
|
|
|
|
DEFINE_TEST(test_read_format_cpio_svr4_gzip_rpm)
|
|
{
|
|
struct archive_entry *ae;
|
|
struct archive *a;
|
|
const char *name = "test_read_format_cpio_svr4_gzip_rpm.rpm";
|
|
int r;
|
|
|
|
assert((a = archive_read_new()) != NULL);
|
|
r = archive_read_support_compression_gzip(a);
|
|
if (r == ARCHIVE_WARN) {
|
|
skipping("gzip reading not fully supported on this platform");
|
|
assertEqualInt(ARCHIVE_OK, archive_read_finish(a));
|
|
return;
|
|
}
|
|
assertEqualIntA(a, ARCHIVE_OK, r);
|
|
assertEqualIntA(a, ARCHIVE_OK,
|
|
archive_read_support_compression_rpm(a));
|
|
assertEqualIntA(a, ARCHIVE_OK, archive_read_support_format_all(a));
|
|
extract_reference_file(name);
|
|
assertEqualIntA(a, ARCHIVE_OK, archive_read_open_filename(a, name, 2));
|
|
|
|
assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
|
|
assertEqualString("./etc/file1", archive_entry_pathname(ae));
|
|
assertEqualInt(86401, archive_entry_mtime(ae));
|
|
assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
|
|
assertEqualString("./etc/file2", archive_entry_pathname(ae));
|
|
assertEqualInt(86401, archive_entry_mtime(ae));
|
|
assertEqualIntA(a, ARCHIVE_OK, archive_read_next_header(a, &ae));
|
|
assertEqualString("./etc/file3", archive_entry_pathname(ae));
|
|
assertEqualInt(86401, archive_entry_mtime(ae));
|
|
|
|
/* Verify the end-of-archive. */
|
|
assertEqualIntA(a, ARCHIVE_EOF, archive_read_next_header(a, &ae));
|
|
|
|
/* Verify that the format detection worked. */
|
|
assertEqualInt(archive_compression(a), ARCHIVE_COMPRESSION_GZIP);
|
|
assertEqualString(archive_compression_name(a), "gzip");
|
|
assertEqualInt(archive_format(a), ARCHIVE_FORMAT_CPIO_SVR4_NOCRC);
|
|
|
|
assertEqualInt(ARCHIVE_OK, archive_read_close(a));
|
|
assertEqualInt(ARCHIVE_OK, archive_read_finish(a));
|
|
}
|
|
|