blob: f5f5066ad1eba60a0abc0defff39047790f10e32 [file] [log] [blame]
/* test_deflate_params.cc - Test deflate() with dynamic change of compression level */
#include "zbuild.h"
#ifdef ZLIB_COMPAT
# include "zlib.h"
#else
# include "zlib-ng.h"
#endif
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <inttypes.h>
#include <time.h>
#include "deflate.h"
#include "test_shared.h"
#include <gtest/gtest.h>
#define COMPR_BUFFER_SIZE (48 * 1024)
#define UNCOMPR_BUFFER_SIZE (64 * 1024)
#define UNCOMPR_RAND_SIZE (8 * 1024)
TEST(deflate, params) {
PREFIX3(stream) c_stream, d_stream;
uint8_t *compr, *uncompr;
uint32_t compr_len, uncompr_len;
uint32_t diff;
int32_t i;
time_t now;
int err;
#ifndef ZLIB_COMPAT
int level = -1;
int strategy = -1;
zng_deflate_param_value params[2];
params[0].param = Z_DEFLATE_LEVEL;
params[0].buf = &level;
params[0].size = sizeof(level);
params[1].param = Z_DEFLATE_STRATEGY;
params[1].buf = &strategy;
params[1].size = sizeof(strategy);
#endif
memset(&c_stream, 0, sizeof(c_stream));
memset(&d_stream, 0, sizeof(d_stream));
compr = (uint8_t *)calloc(1, COMPR_BUFFER_SIZE);
ASSERT_TRUE(compr != NULL);
uncompr = (uint8_t *)calloc(1, UNCOMPR_BUFFER_SIZE);
ASSERT_TRUE(uncompr != NULL);
compr_len = COMPR_BUFFER_SIZE;
uncompr_len = UNCOMPR_BUFFER_SIZE;
srand((unsigned)time(&now));
for (i = 0; i < UNCOMPR_RAND_SIZE; i++)
uncompr[i] = (uint8_t)(rand() % 256);
err = PREFIX(deflateInit)(&c_stream, Z_BEST_SPEED);
EXPECT_EQ(err, Z_OK);
c_stream.next_out = compr;
c_stream.avail_out = compr_len;
c_stream.next_in = uncompr;
c_stream.avail_in = uncompr_len;
err = PREFIX(deflate)(&c_stream, Z_NO_FLUSH);
EXPECT_EQ(err, Z_OK);
EXPECT_EQ(c_stream.avail_in, 0);
/* Feed in already compressed data and switch to no compression: */
#ifndef ZLIB_COMPAT
zng_deflateGetParams(&c_stream, params, sizeof(params) / sizeof(params[0]));
EXPECT_EQ(level, Z_BEST_SPEED);
EXPECT_EQ(strategy, Z_DEFAULT_STRATEGY);
level = Z_NO_COMPRESSION;
strategy = Z_DEFAULT_STRATEGY;
zng_deflateSetParams(&c_stream, params, sizeof(params) / sizeof(params[0]));
#else
PREFIX(deflateParams)(&c_stream, Z_NO_COMPRESSION, Z_DEFAULT_STRATEGY);
#endif
c_stream.next_in = compr;
diff = (unsigned int)(c_stream.next_out - compr);
c_stream.avail_in = diff;
err = PREFIX(deflate)(&c_stream, Z_NO_FLUSH);
EXPECT_EQ(err, Z_OK);
/* Switch back to compressing mode: */
#ifndef ZLIB_COMPAT
level = -1;
strategy = -1;
zng_deflateGetParams(&c_stream, params, sizeof(params) / sizeof(params[0]));
EXPECT_EQ(level, Z_NO_COMPRESSION);
EXPECT_EQ(strategy, Z_DEFAULT_STRATEGY);
level = Z_BEST_COMPRESSION;
strategy = Z_FILTERED;
zng_deflateSetParams(&c_stream, params, sizeof(params) / sizeof(params[0]));
#else
PREFIX(deflateParams)(&c_stream, Z_BEST_COMPRESSION, Z_FILTERED);
#endif
c_stream.next_in = uncompr;
c_stream.avail_in = (unsigned int)uncompr_len;
err = PREFIX(deflate)(&c_stream, Z_NO_FLUSH);
EXPECT_EQ(err, Z_OK);
err = PREFIX(deflate)(&c_stream, Z_FINISH);
EXPECT_EQ(err, Z_STREAM_END);
err = PREFIX(deflateEnd)(&c_stream);
EXPECT_EQ(err, Z_OK);
d_stream.next_in = compr;
d_stream.avail_in = (unsigned int)compr_len;
err = PREFIX(inflateInit)(&d_stream);
EXPECT_EQ(err, Z_OK);
do {
d_stream.next_out = uncompr; /* discard the output */
d_stream.avail_out = uncompr_len;
err = PREFIX(inflate)(&d_stream, Z_NO_FLUSH);
if (err == Z_STREAM_END)
break;
EXPECT_EQ(err, Z_OK);
} while (err == Z_OK);
err = PREFIX(inflateEnd)(&d_stream);
EXPECT_EQ(err, Z_OK);
EXPECT_EQ(d_stream.total_out, (2 * uncompr_len) + diff);
free(compr);
free(uncompr);
}