compression tests
git-svn-id: https://svn.code.sf.net/p/nsis/code/NSIS/trunk@4862 212acab6-be3b-0410-9dea-997c60f758d6
This commit is contained in:
parent
9cb54c2272
commit
ce18bd8cb8
5 changed files with 358 additions and 1 deletions
|
@ -1,6 +1,8 @@
|
|||
target = 'test'
|
||||
|
||||
tests = Split("""
|
||||
compression.cpp
|
||||
decompress.cpp
|
||||
DialogTemplate.cpp
|
||||
endian.cpp
|
||||
mmap.cpp
|
||||
|
@ -18,6 +20,52 @@ required = Split("""
|
|||
util.cpp
|
||||
""")
|
||||
|
||||
required_exehead = Split("""
|
||||
Tests/memcpy.c
|
||||
""")
|
||||
|
||||
lzma_files = Split("""
|
||||
clzma.cpp
|
||||
7zip/7zGuids.cpp
|
||||
7zip/7zip/Common/OutBuffer.cpp
|
||||
7zip/7zip/Common/StreamUtils.cpp
|
||||
7zip/7zip/Compress/LZ/LZInWindow.cpp
|
||||
7zip/7zip/Compress/LZMA/LZMAEncoder.cpp
|
||||
7zip/7zip/Compress/RangeCoder/RangeCoderBit.cpp
|
||||
7zip/Common/Alloc.cpp
|
||||
7zip/Common/CRC.cpp
|
||||
7zip/LZMADecode.c
|
||||
""")
|
||||
|
||||
required += lzma_files
|
||||
|
||||
bzip2_files = Split("""
|
||||
bzip2/blocksort.c
|
||||
bzip2/bzlib.c
|
||||
bzip2/compress.c
|
||||
bzip2/huffman.c
|
||||
""")
|
||||
|
||||
bzip2_exehead_files = Split("""
|
||||
bzip2/bzlib.c
|
||||
bzip2/decompress.c
|
||||
""")
|
||||
|
||||
required += bzip2_files
|
||||
required_exehead += bzip2_exehead_files
|
||||
|
||||
zlib_files = Split("""
|
||||
zlib/deflate.c
|
||||
zlib/trees.c
|
||||
""")
|
||||
|
||||
zlib_exehead_files = Split("""
|
||||
zlib/INFBLOCK.C
|
||||
""")
|
||||
|
||||
required += zlib_files
|
||||
required_exehead += zlib_exehead_files
|
||||
|
||||
cppunitlibs = Split("""
|
||||
cppunit
|
||||
""")
|
||||
|
@ -48,6 +96,9 @@ if 'msvc' in env['TOOLS'] or 'mstoolkit' in env['TOOLS']:
|
|||
# uses exceptions
|
||||
env.Append(CCFLAGS = ['$EXCEPTION_FLAG'])
|
||||
|
||||
# for lzma
|
||||
env.Append(CPPDEFINES = ['COMPRESS_MF_BT'])
|
||||
|
||||
# test for CppUnit
|
||||
conf = env.Configure()
|
||||
cppunit = conf.CheckLibWithHeader(cppunitlibs, 'cppunit/extensions/HelperMacros.h', 'C++')
|
||||
|
@ -59,12 +110,28 @@ if cppunit:
|
|||
required_obj = []
|
||||
|
||||
for i in required:
|
||||
b = 'required/%s' % i[:-4]
|
||||
b = 'required/%s' % i.split('.')[0]
|
||||
s = '#Source/%s' % i
|
||||
o = env.Object(b, s)
|
||||
|
||||
required_obj.append(o)
|
||||
|
||||
# exehead files special treatment
|
||||
exehead_env = env.Clone()
|
||||
exehead_env.Append(
|
||||
CPPDEFINES = [
|
||||
'EXEHEAD',
|
||||
'NSIS_COMPRESS_USE_ZLIB' # just so config.h won't complain
|
||||
]
|
||||
)
|
||||
|
||||
for i in required_exehead:
|
||||
b = 'required/exehead/%s' % i.split('.')[0]
|
||||
s = '#Source/%s' % i
|
||||
o = exehead_env.Object(b, s)
|
||||
|
||||
required_obj.append(o)
|
||||
|
||||
# build test program
|
||||
tests = env.Program(target, tests + required_obj)
|
||||
|
||||
|
|
154
Source/Tests/compression.cpp
Normal file
154
Source/Tests/compression.cpp
Normal file
|
@ -0,0 +1,154 @@
|
|||
#include <cppunit/extensions/HelperMacros.h>
|
||||
#include "../Platform.h"
|
||||
#include "../growbuf.h"
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <time.h>
|
||||
|
||||
#include "decompress.h"
|
||||
|
||||
#include "../cbzip2.h"
|
||||
#include "../clzma.h"
|
||||
#include "../czlib.h"
|
||||
|
||||
class CompressionTest : public CppUnit::TestFixture {
|
||||
|
||||
public:
|
||||
void randData(IGrowBuf &buf, int kb) {
|
||||
srand(time(0));
|
||||
|
||||
for (int i = 0; i < kb; i++) {
|
||||
int r = rand();
|
||||
for (int j = 0; j < 1024/sizeof(int); j++) {
|
||||
buf.add(&r, sizeof(int));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// compressor must be initialized!
|
||||
void compress(ICompressor &compressor, IGrowBuf& in, IGrowBuf& out) {
|
||||
compressor.SetNextIn((char *) in.get(), in.getlen());
|
||||
|
||||
int ret;
|
||||
|
||||
do {
|
||||
char outbuf[1024];
|
||||
compressor.SetNextOut(outbuf, sizeof(outbuf));
|
||||
|
||||
ret = compressor.Compress(C_FINISH);
|
||||
|
||||
CPPUNIT_ASSERT_MESSAGE( compressor.GetErrStr(ret) , ret >= 0 );
|
||||
|
||||
out.add(outbuf, sizeof(outbuf) - compressor.GetAvailOut());
|
||||
} while (ret == 0);
|
||||
}
|
||||
|
||||
typedef void (*decompressInitPtr)(void *);
|
||||
typedef int (*decompressWorkPtr)(void *);
|
||||
|
||||
void decompress(IDecompressor& decompressor, IGrowBuf& in, IGrowBuf& out) {
|
||||
decompressor.init();
|
||||
decompressor.setNextIn(in.get(), in.getlen());
|
||||
|
||||
int ret;
|
||||
|
||||
do {
|
||||
char outbuf[1024];
|
||||
decompressor.setNextOut(outbuf, sizeof(outbuf));
|
||||
|
||||
ret = decompressor.decompress();
|
||||
|
||||
CPPUNIT_ASSERT( ret >= 0 );
|
||||
|
||||
out.add(outbuf, sizeof(outbuf) - decompressor.getAvailOut());
|
||||
|
||||
} while (ret == 0);
|
||||
|
||||
}
|
||||
|
||||
// compressor must be initialized!
|
||||
void testCompressDecompress(int size_kb, ICompressor &compressor, IDecompressor& decompressor) {
|
||||
GrowBuf data;
|
||||
GrowBuf compressed;
|
||||
GrowBuf decompressed;
|
||||
|
||||
randData(data, size_kb);
|
||||
|
||||
compress(compressor, data, compressed);
|
||||
decompress(decompressor, compressed, decompressed);
|
||||
|
||||
CPPUNIT_ASSERT_MESSAGE( "decompressed data is smaller", data.getlen() <= decompressed.getlen() );
|
||||
CPPUNIT_ASSERT_MESSAGE( "decompressed data is larger", data.getlen() >= decompressed.getlen() );
|
||||
CPPUNIT_ASSERT_MESSAGE( "decompressed data is different", !memcmp(data.get(), decompressed.get(), data.getlen()) );
|
||||
}
|
||||
|
||||
void testCompressDecompress(ICompressor &compressor, IDecompressor& decompressor) {
|
||||
CPPUNIT_ASSERT( compressor.Init(9, 1 << 23) == C_OK );
|
||||
testCompressDecompress(1, compressor, decompressor);
|
||||
|
||||
CPPUNIT_ASSERT( compressor.Init(9, 1 << 23) == C_OK );
|
||||
testCompressDecompress(1024, compressor, decompressor);
|
||||
|
||||
CPPUNIT_ASSERT( compressor.Init(9, 1 << 23) == C_OK );
|
||||
testCompressDecompress(8*1024, compressor, decompressor);
|
||||
|
||||
CPPUNIT_ASSERT( compressor.Init(9, 1 << 23) == C_OK );
|
||||
testCompressDecompress(32*1024, compressor, decompressor);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class bzip2CompressionTest : public CompressionTest {
|
||||
|
||||
CPPUNIT_TEST_SUITE( bzip2CompressionTest );
|
||||
CPPUNIT_TEST( test );
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
|
||||
public:
|
||||
|
||||
void test() {
|
||||
CBzip2 compressor;
|
||||
bzip2Decompressor decompressor;
|
||||
|
||||
testCompressDecompress(compressor, decompressor);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class lzmaCompressionTest : public CompressionTest {
|
||||
|
||||
CPPUNIT_TEST_SUITE( lzmaCompressionTest );
|
||||
CPPUNIT_TEST( test );
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
|
||||
public:
|
||||
|
||||
void test() {
|
||||
CLZMA compressor;
|
||||
lzmaDecompressor decompressor;
|
||||
|
||||
testCompressDecompress(compressor, decompressor);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class zlibCompressionTest : public CompressionTest {
|
||||
|
||||
CPPUNIT_TEST_SUITE( zlibCompressionTest );
|
||||
CPPUNIT_TEST( test );
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
|
||||
public:
|
||||
|
||||
void test() {
|
||||
CZlib compressor;
|
||||
zlibDecompressor decompressor;
|
||||
|
||||
testCompressDecompress(compressor, decompressor);
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION( bzip2CompressionTest );
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION( lzmaCompressionTest );
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION( zlibCompressionTest );
|
59
Source/Tests/decompress.cpp
Normal file
59
Source/Tests/decompress.cpp
Normal file
|
@ -0,0 +1,59 @@
|
|||
#include "decompress.h"
|
||||
|
||||
#define EXEHEAD
|
||||
#define NSIS_CONFIG_COMPRESSION_SUPPORT
|
||||
|
||||
extern "C" {
|
||||
#define NSIS_COMPRESS_USE_BZIP2
|
||||
#include "../bzip2/bzlib.h"
|
||||
#undef NSIS_COMPRESS_USE_BZIP2
|
||||
|
||||
#define NSIS_COMPRESS_USE_LZMA
|
||||
#include "../7zip/LZMADecode.h"
|
||||
#undef NSIS_COMPRESS_USE_LZMA
|
||||
|
||||
#define NSIS_COMPRESS_USE_ZLIB
|
||||
#include "../zlib/ZLIB.H"
|
||||
#undef NSIS_COMPRESS_USE_ZLIB
|
||||
}
|
||||
|
||||
#define DECOMPRESSOR(name, type, initf, dec, u) \
|
||||
name::name() { \
|
||||
vs = new type; \
|
||||
} \
|
||||
\
|
||||
name::~name() { \
|
||||
delete vs; \
|
||||
vs = NULL; \
|
||||
} \
|
||||
\
|
||||
void name::setNextIn(void *buffer, int size) { \
|
||||
type *s = (type *) vs; \
|
||||
s->next_in = (u *) buffer; \
|
||||
s->avail_in = size; \
|
||||
} \
|
||||
\
|
||||
void name::setNextOut(void *buffer, int size) { \
|
||||
type *s = (type *) vs; \
|
||||
s->next_out = (u *) buffer; \
|
||||
s->avail_out = size; \
|
||||
} \
|
||||
\
|
||||
int name::getAvailOut() { \
|
||||
type *s = (type *) vs; \
|
||||
return s->avail_out; \
|
||||
} \
|
||||
\
|
||||
void name::init() { \
|
||||
type *s = (type *) vs; \
|
||||
initf(s); \
|
||||
} \
|
||||
\
|
||||
int name::decompress() { \
|
||||
type *s = (type *) vs; \
|
||||
return dec(s); \
|
||||
}
|
||||
|
||||
DECOMPRESSOR(lzmaDecompressor, lzma_stream, lzmaInit, lzmaDecode, unsigned char);
|
||||
DECOMPRESSOR(bzip2Decompressor, DState, BZ2_bzDecompressInit, BZ2_bzDecompress, char);
|
||||
DECOMPRESSOR(zlibDecompressor, z_stream, inflateReset, inflate, unsigned char);
|
66
Source/Tests/decompress.h
Normal file
66
Source/Tests/decompress.h
Normal file
|
@ -0,0 +1,66 @@
|
|||
class IDecompressor {
|
||||
public:
|
||||
|
||||
virtual ~IDecompressor() {};
|
||||
|
||||
virtual void init() = 0;
|
||||
virtual void setNextIn(void *buffer, int size) = 0;
|
||||
virtual void setNextOut(void *buffer, int size) = 0;
|
||||
virtual int getAvailOut() = 0;
|
||||
virtual int decompress() = 0;
|
||||
|
||||
};
|
||||
|
||||
class lzmaDecompressor : public IDecompressor {
|
||||
public:
|
||||
|
||||
lzmaDecompressor();
|
||||
virtual ~lzmaDecompressor();
|
||||
|
||||
virtual void init();
|
||||
virtual void setNextIn(void *buffer, int size);
|
||||
virtual void setNextOut(void *buffer, int size);
|
||||
virtual int getAvailOut();
|
||||
virtual int decompress();
|
||||
|
||||
private:
|
||||
|
||||
void *vs;
|
||||
|
||||
};
|
||||
|
||||
class bzip2Decompressor : public IDecompressor {
|
||||
public:
|
||||
|
||||
bzip2Decompressor();
|
||||
virtual ~bzip2Decompressor();
|
||||
|
||||
virtual void init();
|
||||
virtual void setNextIn(void *buffer, int size);
|
||||
virtual void setNextOut(void *buffer, int size);
|
||||
virtual int getAvailOut();
|
||||
virtual int decompress();
|
||||
|
||||
private:
|
||||
|
||||
void *vs;
|
||||
|
||||
};
|
||||
|
||||
class zlibDecompressor : public IDecompressor {
|
||||
public:
|
||||
|
||||
zlibDecompressor();
|
||||
virtual ~zlibDecompressor();
|
||||
|
||||
virtual void init();
|
||||
virtual void setNextIn(void *buffer, int size);
|
||||
virtual void setNextOut(void *buffer, int size);
|
||||
virtual int getAvailOut();
|
||||
virtual int decompress();
|
||||
|
||||
private:
|
||||
|
||||
void *vs;
|
||||
|
||||
};
|
11
Source/Tests/memcpy.c
Normal file
11
Source/Tests/memcpy.c
Normal file
|
@ -0,0 +1,11 @@
|
|||
#include "../exehead/util.h"
|
||||
|
||||
void NSISCALL mini_memcpy(void *out, const void *in, int len)
|
||||
{
|
||||
char *c_out=(char*)out;
|
||||
char *c_in=(char *)in;
|
||||
while (len-- > 0)
|
||||
{
|
||||
*c_out++=*c_in++;
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue