Merge "Add unit tests for libziparchive."
This commit is contained in:
commit
a183f45f7a
4 changed files with 157 additions and 17 deletions
|
|
@ -51,3 +51,17 @@ LOCAL_SRC_FILES := zip_archive_test.cc
|
||||||
LOCAL_LDFLAGS := -llog
|
LOCAL_LDFLAGS := -llog
|
||||||
LOCAL_STATIC_LIBRARIES := libziparchive libz libgtest libgtest_main
|
LOCAL_STATIC_LIBRARIES := libziparchive libz libgtest libgtest_main
|
||||||
include $(BUILD_NATIVE_TEST)
|
include $(BUILD_NATIVE_TEST)
|
||||||
|
|
||||||
|
include $(CLEAR_VARS)
|
||||||
|
LOCAL_MODULE := ziparchive-tests-host
|
||||||
|
LOCAL_CPP_EXTENSION := .cc
|
||||||
|
LOCAL_CFLAGS += \
|
||||||
|
-DGTEST_OS_LINUX \
|
||||||
|
-DGTEST_HAS_STD_STRING
|
||||||
|
LOCAL_SRC_FILES := zip_archive_test.cc
|
||||||
|
LOCAL_STATIC_LIBRARIES := libziparchive-host \
|
||||||
|
libz \
|
||||||
|
libgtest_host \
|
||||||
|
libgtest_main_host \
|
||||||
|
liblog
|
||||||
|
include $(BUILD_HOST_NATIVE_TEST)
|
||||||
|
|
|
||||||
BIN
libziparchive/testdata/valid.zip
vendored
Normal file
BIN
libziparchive/testdata/valid.zip
vendored
Normal file
Binary file not shown.
|
|
@ -243,7 +243,7 @@ static int32_t CopyFileToFile(int fd, uint8_t* begin, const uint32_t length, uin
|
||||||
|
|
||||||
uint32_t count = 0;
|
uint32_t count = 0;
|
||||||
uint64_t crc = 0;
|
uint64_t crc = 0;
|
||||||
while (count <= length) {
|
while (count < length) {
|
||||||
uint32_t remaining = length - count;
|
uint32_t remaining = length - count;
|
||||||
|
|
||||||
// Safe conversion because kBufSize is narrow enough for a 32 bit signed
|
// Safe conversion because kBufSize is narrow enough for a 32 bit signed
|
||||||
|
|
|
||||||
|
|
@ -16,31 +16,157 @@
|
||||||
|
|
||||||
#include "ziparchive/zip_archive.h"
|
#include "ziparchive/zip_archive.h"
|
||||||
|
|
||||||
|
#include "getopt.h"
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <gtest/gtest.h>
|
#include <gtest/gtest.h>
|
||||||
|
|
||||||
TEST(ziparchive, open) {
|
static std::string test_data_dir;
|
||||||
// Ignore this test, it's just a simple test involving
|
|
||||||
// the framework jar.
|
|
||||||
ZipArchiveHandle handle;
|
|
||||||
void* iterationCookie;
|
|
||||||
|
|
||||||
ASSERT_EQ(0, OpenArchive("/sdcard/test.jar", &handle));
|
static const std::string kValidZip = "valid.zip";
|
||||||
ASSERT_EQ(0, StartIteration(handle, &iterationCookie, NULL));
|
|
||||||
|
static const uint8_t kATxtContents[] = {
|
||||||
|
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
|
||||||
|
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
|
||||||
|
'\n'
|
||||||
|
};
|
||||||
|
|
||||||
|
static const uint8_t kBTxtContents[] = {
|
||||||
|
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
|
||||||
|
'\n'
|
||||||
|
};
|
||||||
|
|
||||||
|
static int32_t OpenArchiveWrapper(const std::string& name,
|
||||||
|
ZipArchiveHandle* handle) {
|
||||||
|
const std::string abs_path = test_data_dir + "/" + name;
|
||||||
|
return OpenArchive(abs_path.c_str(), handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void AssertNameEquals(const std::string& name_str,
|
||||||
|
const ZipEntryName& name) {
|
||||||
|
ASSERT_EQ(name_str.size(), name.name_length);
|
||||||
|
ASSERT_EQ(0, memcmp(name_str.c_str(), name.name, name.name_length));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(ziparchive, Open) {
|
||||||
|
ZipArchiveHandle handle;
|
||||||
|
ASSERT_EQ(0, OpenArchiveWrapper(kValidZip, &handle));
|
||||||
|
|
||||||
|
CloseArchive(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(ziparchive, Iteration) {
|
||||||
|
ZipArchiveHandle handle;
|
||||||
|
ASSERT_EQ(0, OpenArchiveWrapper(kValidZip, &handle));
|
||||||
|
|
||||||
|
void* iteration_cookie;
|
||||||
|
ASSERT_EQ(0, StartIteration(handle, &iteration_cookie, NULL));
|
||||||
|
|
||||||
ZipEntry data;
|
ZipEntry data;
|
||||||
ZipEntryName name;
|
ZipEntryName name;
|
||||||
int ctr = 0;
|
|
||||||
while (Next(iterationCookie, &data, &name) == 0) {
|
|
||||||
printf("Found %.*s\n", name.name_length, name.name);
|
|
||||||
ctr++;
|
|
||||||
}
|
|
||||||
|
|
||||||
ASSERT_EQ(2245, ctr);
|
// b/c.txt
|
||||||
|
ASSERT_EQ(0, Next(iteration_cookie, &data, &name));
|
||||||
|
AssertNameEquals("b/c.txt", name);
|
||||||
|
|
||||||
ASSERT_EQ(0, FindEntry(handle, "java/sql/Clob.class", &data));
|
// b/d.txt
|
||||||
ASSERT_EQ(-1, FindEntry(handle, "java/sql/Slob.class", &data));
|
ASSERT_EQ(0, Next(iteration_cookie, &data, &name));
|
||||||
|
AssertNameEquals("b/d.txt", name);
|
||||||
|
|
||||||
CloseArchive(&handle);
|
// a.txt
|
||||||
|
ASSERT_EQ(0, Next(iteration_cookie, &data, &name));
|
||||||
|
AssertNameEquals("a.txt", name);
|
||||||
|
|
||||||
|
// b.txt
|
||||||
|
ASSERT_EQ(0, Next(iteration_cookie, &data, &name));
|
||||||
|
AssertNameEquals("b.txt", name);
|
||||||
|
|
||||||
|
// b/
|
||||||
|
ASSERT_EQ(0, Next(iteration_cookie, &data, &name));
|
||||||
|
AssertNameEquals("b/", name);
|
||||||
|
|
||||||
|
// End of iteration.
|
||||||
|
ASSERT_EQ(-1, Next(iteration_cookie, &data, &name));
|
||||||
|
|
||||||
|
CloseArchive(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(ziparchive, FindEntry) {
|
||||||
|
ZipArchiveHandle handle;
|
||||||
|
ASSERT_EQ(0, OpenArchiveWrapper(kValidZip, &handle));
|
||||||
|
|
||||||
|
ZipEntry data;
|
||||||
|
ASSERT_EQ(0, FindEntry(handle, "a.txt", &data));
|
||||||
|
|
||||||
|
// Known facts about a.txt, from zipinfo -v.
|
||||||
|
ASSERT_EQ(63, data.offset);
|
||||||
|
ASSERT_EQ(kCompressDeflated, data.method);
|
||||||
|
ASSERT_EQ(static_cast<uint32_t>(17), data.uncompressed_length);
|
||||||
|
ASSERT_EQ(static_cast<uint32_t>(13), data.compressed_length);
|
||||||
|
ASSERT_EQ(0x950821c5, data.crc32);
|
||||||
|
|
||||||
|
// An entry that doesn't exist. Should be a negative return code.
|
||||||
|
ASSERT_LT(FindEntry(handle, "nonexistent.txt", &data), 0);
|
||||||
|
|
||||||
|
CloseArchive(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(ziparchive, ExtractToMemory) {
|
||||||
|
ZipArchiveHandle handle;
|
||||||
|
ASSERT_EQ(0, OpenArchiveWrapper(kValidZip, &handle));
|
||||||
|
|
||||||
|
// An entry that's deflated.
|
||||||
|
ZipEntry data;
|
||||||
|
ASSERT_EQ(0, FindEntry(handle, "a.txt", &data));
|
||||||
|
const uint32_t a_size = data.uncompressed_length;
|
||||||
|
ASSERT_EQ(a_size, sizeof(kATxtContents));
|
||||||
|
uint8_t* buffer = new uint8_t[a_size];
|
||||||
|
ASSERT_EQ(0, ExtractToMemory(handle, &data, buffer, a_size));
|
||||||
|
ASSERT_EQ(0, memcmp(buffer, kATxtContents, a_size));
|
||||||
|
delete[] buffer;
|
||||||
|
|
||||||
|
// An entry that's stored.
|
||||||
|
ASSERT_EQ(0, FindEntry(handle, "b.txt", &data));
|
||||||
|
const uint32_t b_size = data.uncompressed_length;
|
||||||
|
ASSERT_EQ(b_size, sizeof(kBTxtContents));
|
||||||
|
buffer = new uint8_t[b_size];
|
||||||
|
ASSERT_EQ(0, ExtractToMemory(handle, &data, buffer, b_size));
|
||||||
|
ASSERT_EQ(0, memcmp(buffer, kBTxtContents, b_size));
|
||||||
|
delete[] buffer;
|
||||||
|
|
||||||
|
CloseArchive(handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char** argv) {
|
||||||
|
::testing::InitGoogleTest(&argc, argv);
|
||||||
|
|
||||||
|
static struct option options[] = {
|
||||||
|
{ "test_data_dir", required_argument, NULL, 't' },
|
||||||
|
{ NULL, 0, NULL, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
int option_index;
|
||||||
|
const int c = getopt_long_only(argc, argv, "", options, &option_index);
|
||||||
|
if (c == -1) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (c == 't') {
|
||||||
|
test_data_dir = optarg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test_data_dir.size() == 0) {
|
||||||
|
printf("Test data flag (--test_data_dir) required\n\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (test_data_dir[0] != '/') {
|
||||||
|
printf("Test data must be an absolute path, was %s\n\n",
|
||||||
|
test_data_dir.c_str());
|
||||||
|
return -2;
|
||||||
|
}
|
||||||
|
|
||||||
|
return RUN_ALL_TESTS();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue