mirror of
https://github.com/facebook/zstd.git
synced 2025-08-08 17:22:10 +03:00
added unit tests to ZSTD_compressSequencesAndLiterals()
seems to work as expected, correctly control that `litSize` and `srcSize` are exactly correct.
This commit is contained in:
105
tests/fuzzer.c
105
tests/fuzzer.c
@@ -40,7 +40,6 @@
|
||||
#include "datagen.h" /* RDG_genBuffer */
|
||||
#define XXH_STATIC_LINKING_ONLY /* XXH64_state_t */
|
||||
#include "xxhash.h" /* XXH64 */
|
||||
#include "util.h"
|
||||
#include "timefn.h" /* SEC_TO_MICRO, UTIL_time_t, UTIL_TIME_INITIALIZER, UTIL_clockSpanMicro, UTIL_getTime */
|
||||
/* must be included after util.h, due to ERROR macro redefinition issue on Visual Studio */
|
||||
#include "zstd_internal.h" /* ZSTD_WORKSPACETOOLARGE_MAXDURATION, ZSTD_WORKSPACETOOLARGE_FACTOR, KB, MB */
|
||||
@@ -339,6 +338,35 @@ static void FUZ_decodeSequences(BYTE* dst, ZSTD_Sequence* seqs, size_t seqsSize,
|
||||
}
|
||||
}
|
||||
|
||||
static size_t FUZ_getLitSize(const ZSTD_Sequence* seqs, size_t nbSeqs)
|
||||
{
|
||||
size_t n, litSize = 0;
|
||||
assert(seqs != NULL);
|
||||
for (n=0; n<nbSeqs; n++) {
|
||||
litSize += seqs[n].litLength;
|
||||
}
|
||||
return litSize;
|
||||
}
|
||||
|
||||
static void
|
||||
FUZ_transferLiterals(void* dst, size_t dstCapacity,
|
||||
const void* src, size_t srcSize,
|
||||
const ZSTD_Sequence* seqs, size_t nbSeqs)
|
||||
{
|
||||
size_t n;
|
||||
const char* ip = (const char*)src;
|
||||
char* op = (char*)dst;
|
||||
size_t const litSize = FUZ_getLitSize(seqs, nbSeqs);
|
||||
assert(litSize <= dstCapacity);
|
||||
for (n=0; n<nbSeqs; n++) {
|
||||
size_t const ll = seqs[n].litLength;
|
||||
memcpy(op, ip, ll);
|
||||
op += ll;
|
||||
ip += ll + seqs[n].matchLength;
|
||||
}
|
||||
assert((size_t)(ip - (const char*)src) == srcSize);
|
||||
}
|
||||
|
||||
#ifdef ZSTD_MULTITHREAD
|
||||
|
||||
typedef struct {
|
||||
@@ -3808,7 +3836,7 @@ static int basicUnitTests(U32 const seed, double compressibility)
|
||||
if (seqs == NULL) goto _output_error;
|
||||
assert(cctx != NULL);
|
||||
|
||||
/* Populate src with random data */
|
||||
/* Populate src with compressible random data */
|
||||
RDG_genBuffer(CNBuffer, srcSize, compressibility, 0., seed);
|
||||
|
||||
/* Roundtrip Test with block delimiters generated by ZSTD_generateSequences() */
|
||||
@@ -3850,6 +3878,79 @@ static int basicUnitTests(U32 const seed, double compressibility)
|
||||
}
|
||||
DISPLAYLEVEL(3, "OK \n");
|
||||
|
||||
DISPLAYLEVEL(3, "test%3i : ZSTD_compressSequencesAndLiterals : ", testNb++);
|
||||
{
|
||||
const size_t srcSize = 100 KB;
|
||||
const BYTE* const src = (BYTE*)CNBuffer;
|
||||
BYTE* const dst = (BYTE*)compressedBuffer;
|
||||
const size_t dstCapacity = ZSTD_compressBound(srcSize);
|
||||
const size_t decompressSize = srcSize;
|
||||
char* const decompressBuffer = (char*)malloc(decompressSize);
|
||||
char* const litBuffer = (char*)malloc(decompressSize);
|
||||
size_t compressedSize;
|
||||
|
||||
ZSTD_CCtx* const cctx = ZSTD_createCCtx();
|
||||
ZSTD_Sequence* const seqs = (ZSTD_Sequence*)malloc(srcSize * sizeof(ZSTD_Sequence));
|
||||
size_t nbSeqs;
|
||||
|
||||
if (litBuffer == NULL) goto _output_error;
|
||||
if (decompressBuffer == NULL) goto _output_error;
|
||||
if (seqs == NULL) goto _output_error;
|
||||
assert(cctx != NULL);
|
||||
|
||||
/* Populate src with compressible random data */
|
||||
RDG_genBuffer(CNBuffer, srcSize, compressibility, 0., seed);
|
||||
|
||||
/* Roundtrip Test using the AndLiterals() variant */
|
||||
nbSeqs = ZSTD_generateSequences(cctx, seqs, srcSize, src, srcSize);
|
||||
ZSTD_CCtx_reset(cctx, ZSTD_reset_session_and_parameters);
|
||||
ZSTD_CCtx_setParameter(cctx, ZSTD_c_blockDelimiters, ZSTD_sf_explicitBlockDelimiters);
|
||||
{ size_t const litSize = FUZ_getLitSize(seqs, nbSeqs);
|
||||
FUZ_transferLiterals(litBuffer, decompressSize, CNBuffer, srcSize, seqs, nbSeqs);
|
||||
|
||||
/* not enough literals: must fail */
|
||||
compressedSize = ZSTD_compressSequencesAndLiterals(cctx, dst, dstCapacity, seqs, nbSeqs, src, litSize-1, srcSize);
|
||||
if (!ZSTD_isError(compressedSize)) {
|
||||
DISPLAY("ZSTD_compressSequencesAndLiterals() should have failed: not enough literals provided\n");
|
||||
goto _output_error;
|
||||
}
|
||||
|
||||
/* too many literals: must fail */
|
||||
compressedSize = ZSTD_compressSequencesAndLiterals(cctx, dst, dstCapacity, seqs, nbSeqs, src, litSize+1, srcSize);
|
||||
if (!ZSTD_isError(compressedSize)) {
|
||||
DISPLAY("ZSTD_compressSequencesAndLiterals() should have failed: too many literals provided\n");
|
||||
goto _output_error;
|
||||
}
|
||||
|
||||
/* correct amount of literals: should compress successfully */
|
||||
compressedSize = ZSTD_compressSequencesAndLiterals(cctx, dst, dstCapacity, seqs, nbSeqs, litBuffer, litSize, srcSize);
|
||||
if (ZSTD_isError(compressedSize)) {
|
||||
DISPLAY("Error in ZSTD_compressSequencesAndLiterals()\n");
|
||||
goto _output_error;
|
||||
}
|
||||
}
|
||||
{ size_t const dSize = ZSTD_decompress(decompressBuffer, decompressSize, dst, compressedSize);
|
||||
if (ZSTD_isError(dSize)) {
|
||||
DISPLAY("Error during decompression of frame produced by ZSTD_compressSequencesAndLiterals()\n");
|
||||
goto _output_error;
|
||||
}
|
||||
if (dSize != srcSize) {
|
||||
DISPLAY("Error: decompression of frame produced by ZSTD_compressSequencesAndLiterals() has different size\n");
|
||||
goto _output_error;
|
||||
}
|
||||
if (memcmp(decompressBuffer, src, srcSize)) {
|
||||
DISPLAY("Error: decompression of frame produced by ZSTD_compressSequencesAndLiterals() produces a different content (of same size)\n");
|
||||
goto _output_error;
|
||||
}
|
||||
}
|
||||
|
||||
ZSTD_freeCCtx(cctx);
|
||||
free(litBuffer);
|
||||
free(decompressBuffer);
|
||||
free(seqs);
|
||||
}
|
||||
DISPLAYLEVEL(3, "OK \n");
|
||||
|
||||
/* Multiple blocks of zeros test */
|
||||
#define LONGZEROSLENGTH 1000000 /* 1MB of zeros */
|
||||
DISPLAYLEVEL(3, "test%3i : compress %u zeroes : ", testNb++, LONGZEROSLENGTH);
|
||||
|
Reference in New Issue
Block a user