mirror of
https://git.tukaani.org/xz.git
synced 2024-04-04 12:36:23 +02:00
c47ecd6d39
Explicitly casting the integer to lzma_check silences the warning. Since such an invalid value is needed in multiple tests, a constant INVALID_LZMA_CHECK_ID was added to tests.h. The use of 0x1000 for lzma_block.check wasn't optimal as if the underlying type is a char then 0x1000 will be truncated to 0. However, in these test cases the value is ignored, thus even with such truncation the test would have passed.
150 lines
3.4 KiB
C
150 lines
3.4 KiB
C
///////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
/// \file tests.h
|
|
/// \brief Common definitions for test applications
|
|
//
|
|
// Author: Lasse Collin
|
|
//
|
|
// This file has been put into the public domain.
|
|
// You can do whatever you want with this file.
|
|
//
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifndef LZMA_TESTS_H
|
|
#define LZMA_TESTS_H
|
|
|
|
#include "sysdefs.h"
|
|
#include "tuklib_integer.h"
|
|
#include "lzma.h"
|
|
#include "tuktest.h"
|
|
|
|
|
|
// Invalid value for the lzma_check enumeration. This must be positive
|
|
// but small enough to fit into signed char since the underlying type might
|
|
// one some platform be a signed char.
|
|
//
|
|
// Don't put LZMA_ at the beginning of the name so that it is obvious that
|
|
// this constant doesn't come from the API headers.
|
|
#define INVALID_LZMA_CHECK_ID ((lzma_check)(LZMA_CHECK_ID_MAX + 1))
|
|
|
|
|
|
#define memcrap(buf, size) memset(buf, 0xFD, size)
|
|
|
|
|
|
// TODO: Remove these three macros once all tests have been converted.
|
|
#define expect(test) ((test) ? 0 : (fprintf(stderr, "%s:%d: %s\n", \
|
|
__FILE__, __LINE__, #test), abort(), 0))
|
|
|
|
#define succeed(test) expect(!(test))
|
|
|
|
#define fail(test) expect(test)
|
|
|
|
|
|
// This table and macro allow getting more readable error messages when
|
|
// comparing the lzma_ret enumeration values.
|
|
static const char enum_strings_lzma_ret[][24] = {
|
|
"LZMA_OK",
|
|
"LZMA_STREAM_END",
|
|
"LZMA_NO_CHECK",
|
|
"LZMA_UNSUPPORTED_CHECK",
|
|
"LZMA_GET_CHECK",
|
|
"LZMA_MEM_ERROR",
|
|
"LZMA_MEMLIMIT_ERROR",
|
|
"LZMA_FORMAT_ERROR",
|
|
"LZMA_OPTIONS_ERROR",
|
|
"LZMA_DATA_ERROR",
|
|
"LZMA_BUF_ERROR",
|
|
"LZMA_PROG_ERROR",
|
|
"LZMA_SEEK_NEEDED",
|
|
};
|
|
|
|
#define assert_lzma_ret(test_expr, ref_val) \
|
|
assert_enum_eq(test_expr, ref_val, enum_strings_lzma_ret)
|
|
|
|
|
|
static const char enum_strings_lzma_check[][24] = {
|
|
"LZMA_CHECK_NONE",
|
|
"LZMA_CHECK_CRC32",
|
|
"LZMA_CHECK_UNKNOWN_2",
|
|
"LZMA_CHECK_UNKNOWN_3",
|
|
"LZMA_CHECK_CRC64",
|
|
"LZMA_CHECK_UNKNOWN_5",
|
|
"LZMA_CHECK_UNKNOWN_6",
|
|
"LZMA_CHECK_UNKNOWN_7",
|
|
"LZMA_CHECK_UNKNOWN_8",
|
|
"LZMA_CHECK_UNKNOWN_9",
|
|
"LZMA_CHECK_SHA256",
|
|
"LZMA_CHECK_UNKNOWN_11",
|
|
"LZMA_CHECK_UNKNOWN_12",
|
|
"LZMA_CHECK_UNKNOWN_13",
|
|
"LZMA_CHECK_UNKNOWN_14",
|
|
"LZMA_CHECK_UNKNOWN_15",
|
|
};
|
|
|
|
#define assert_lzma_check(test_expr, ref_val) \
|
|
assert_enum_eq(test_expr, ref_val, enum_strings_lzma_check)
|
|
|
|
|
|
static inline bool
|
|
coder_loop(lzma_stream *strm, uint8_t *in, size_t in_size,
|
|
uint8_t *out, size_t out_size,
|
|
lzma_ret expected_ret, lzma_action finishing_action)
|
|
{
|
|
size_t in_left = in_size;
|
|
size_t out_left = out_size > 0 ? out_size + 1 : 0;
|
|
lzma_action action = LZMA_RUN;
|
|
lzma_ret ret;
|
|
|
|
strm->next_in = NULL;
|
|
strm->avail_in = 0;
|
|
strm->next_out = NULL;
|
|
strm->avail_out = 0;
|
|
|
|
while (true) {
|
|
if (in_left > 0) {
|
|
if (--in_left == 0)
|
|
action = finishing_action;
|
|
|
|
strm->next_in = in++;
|
|
strm->avail_in = 1;
|
|
}
|
|
|
|
if (out_left > 0) {
|
|
--out_left;
|
|
strm->next_out = out++;
|
|
strm->avail_out = 1;
|
|
}
|
|
|
|
ret = lzma_code(strm, action);
|
|
if (ret != LZMA_OK)
|
|
break;
|
|
}
|
|
|
|
bool error = false;
|
|
|
|
if (ret != expected_ret)
|
|
error = true;
|
|
|
|
if (strm->total_in != in_size || strm->total_out != out_size)
|
|
error = true;
|
|
|
|
return error;
|
|
}
|
|
|
|
|
|
static inline bool
|
|
decoder_loop_ret(lzma_stream *strm, uint8_t *in, size_t in_size,
|
|
lzma_ret expected_ret)
|
|
{
|
|
return coder_loop(strm, in, in_size, NULL, 0, expected_ret, LZMA_RUN);
|
|
}
|
|
|
|
|
|
static inline bool
|
|
decoder_loop(lzma_stream *strm, uint8_t *in, size_t in_size)
|
|
{
|
|
return coder_loop(strm, in, in_size, NULL, 0,
|
|
LZMA_STREAM_END, LZMA_RUN);
|
|
}
|
|
|
|
#endif
|