Blame libfreerdp/codec/test/TestFreeRDPCodecClear.c

Packit Service fa4841
#include <winpr/crt.h>
Packit Service fa4841
#include <winpr/print.h>
Packit Service fa4841
Packit Service fa4841
#include <freerdp/codec/clear.h>
Packit Service fa4841
Packit Service fa4841
/* [MS-RDPEGFX] 4.1.1.1 Example 1 */
Packit Service bb5c11
static const BYTE PREPARE_CLEAR_EXAMPLE_1[] =
Packit Service bb5c11
    "\x03\xc3\x11\x00";
Packit Service bb5c11
static const BYTE TEST_CLEAR_EXAMPLE_1[] =
Packit Service bb5c11
    "\x03\xc3\x11\x00";
Packit Service fa4841
Packit Service fa4841
/* [MS-RDPEGFX] 4.1.1.1 Example 2 */
Packit Service fa4841
static const BYTE TEST_CLEAR_EXAMPLE_2[] =
Packit Service fa4841
    "\x00\x0d\x00\x00\x00\x00\x00\x00\x00\x00\x82\x00\x00\x00\x00\x00"
Packit Service fa4841
    "\x00\x00\x4e\x00\x11\x00\x75\x00\x00\x00\x02\x0e\xff\xff\xff\x00"
Packit Service fa4841
    "\x00\x00\xdb\xff\xff\x00\x3a\x90\xff\xb6\x66\x66\xb6\xff\xb6\x66"
Packit Service fa4841
    "\x00\x90\xdb\xff\x00\x00\x3a\xdb\x90\x3a\x3a\x90\xdb\x66\x00\x00"
Packit Service fa4841
    "\xff\xff\xb6\x64\x64\x64\x11\x04\x11\x4c\x11\x4c\x11\x4c\x11\x4c"
Packit Service fa4841
    "\x11\x4c\x00\x47\x13\x00\x01\x01\x04\x00\x01\x00\x00\x47\x16\x00"
Packit Service fa4841
    "\x11\x02\x00\x47\x29\x00\x11\x01\x00\x49\x0a\x00\x01\x00\x04\x00"
Packit Service fa4841
    "\x01\x00\x00\x4a\x0a\x00\x09\x00\x01\x00\x00\x47\x05\x00\x01\x01"
Packit Service fa4841
    "\x1c\x00\x01\x00\x11\x4c\x11\x4c\x11\x4c\x00\x47\x0d\x4d\x00\x4d";
Packit Service fa4841
Packit Service fa4841
/* [MS-RDPEGFX] 4.1.1.1 Example 3 */
Packit Service fa4841
static const BYTE TEST_CLEAR_EXAMPLE_3[] =
Packit Service fa4841
    "\x00\xdf\x0e\x00\x00\x00\x8b\x00\x00\x00\x00\x00\x00\x00\xfe\xfe"
Packit Service fa4841
    "\xfe\xff\x80\x05\xff\xff\xff\x40\xfe\xfe\xfe\x40\x00\x00\x3f\x00"
Packit Service fa4841
    "\x03\x00\x0b\x00\xfe\xfe\xfe\xc5\xd0\xc6\xd0\xc7\xd0\x68\xd4\x69"
Packit Service fa4841
    "\xd4\x6a\xd4\x6b\xd4\x6c\xd4\x6d\xd4\x1a\xd4\x1a\xd4\xa6\xd0\x6e"
Packit Service fa4841
    "\xd4\x6f\xd4\x70\xd4\x71\xd4\x72\xd4\x73\xd4\x74\xd4\x21\xd4\x22"
Packit Service fa4841
    "\xd4\x23\xd4\x24\xd4\x25\xd4\xd9\xd0\xda\xd0\xdb\xd0\xc5\xd0\xc5"
Packit Service fa4841
    "\xd0\xdc\xd0\xc2\xd0\x21\xd4\x22\xd4\x23\xd4\x24\xd4\x25\xd4\xc9"
Packit Service fa4841
    "\xd0\xca\xd0\x5a\xd4\x2b\xd1\x28\xd1\x2c\xd1\x75\xd4\x27\xd4\x28"
Packit Service fa4841
    "\xd4\x29\xd4\x2a\xd4\x1a\xd4\x1a\xd4\x1a\xd4\xb7\xd0\xb8\xd0\xb9"
Packit Service fa4841
    "\xd0\xba\xd0\xbb\xd0\xbc\xd0\xbd\xd0\xbe\xd0\xbf\xd0\xc0\xd0\xc1"
Packit Service fa4841
    "\xd0\xc2\xd0\xc3\xd0\xc4\xd0";
Packit Service fa4841
Packit Service fa4841
/* [MS-RDPEGFX] 4.1.1.1 Example 4 */
Packit Service fa4841
static const BYTE TEST_CLEAR_EXAMPLE_4[] =
Packit Service fa4841
    "\x01\x0b\x78\x00\x00\x00\x00\x00\x46\x00\x00\x00\x00\x00\x00\x00"
Packit Service fa4841
    "\x00\x00\x06\x00\x00\x00\x0e\x00\x00\x00\x00\x00\x0f\xff\xff\xff"
Packit Service fa4841
    "\xff\xff\xff\xff\xff\xff\xb6\xff\xff\xff\xff\xff\xff\xff\xff\xff"
Packit Service fa4841
    "\xb6\x66\xff\xff\xff\xff\xff\xff\xff\xb6\x66\xdb\x90\x3a\xff\xff"
Packit Service fa4841
    "\xb6\xff\xff\xff\xff\xff\xff\xff\xff\xff\x46\x91\x47\x91\x48\x91"
Packit Service fa4841
    "\x49\x91\x4a\x91\x1b\x91";
Packit Service fa4841
Packit Service bb5c11
Packit Service fa4841
static BOOL test_ClearDecompressExample(UINT32 nr, UINT32 width, UINT32 height,
Packit Service bb5c11
                                        const BYTE* pSrcData,
Packit Service bb5c11
                                        const UINT32 SrcSize)
Packit Service fa4841
{
Packit Service fa4841
	BOOL rc = FALSE;
Packit Service fa4841
	int status;
Packit Service fa4841
	BYTE* pDstData = calloc(width * height, 4);
Packit Service fa4841
	CLEAR_CONTEXT* clear = clear_context_new(FALSE);
Packit Service fa4841
Packit Service fa4841
	if (!clear || !pDstData)
Packit Service fa4841
		goto fail;
Packit Service fa4841
Packit Service bb5c11
	status = clear_decompress(clear, pSrcData, SrcSize, width, height,
Packit Service bb5c11
	                          pDstData, PIXEL_FORMAT_XRGB32, 0, 0, 0, width, height,
Packit Service bb5c11
	                          NULL);
Packit Service bb5c11
	printf("clear_decompress example %"PRIu32" status: %d\n", nr, status);
Packit Service fa4841
	fflush(stdout);
Packit Service fa4841
	rc = (status == 0);
Packit Service fa4841
fail:
Packit Service fa4841
	clear_context_free(clear);
Packit Service fa4841
	free(pDstData);
Packit Service fa4841
	return rc;
Packit Service fa4841
}
Packit Service fa4841
Packit Service fa4841
int TestFreeRDPCodecClear(int argc, char* argv[])
Packit Service fa4841
{
Packit Service fa4841
	/* Example 1 needs a filled glyph cache
Packit Service fa4841
	if (!test_ClearDecompressExample(1, 8, 9, TEST_CLEAR_EXAMPLE_1,
Packit Service fa4841
	                                 sizeof(TEST_CLEAR_EXAMPLE_1)))
Packit Service bb5c11
		return -1;
Packit Service fa4841
	*/
Packit Service bb5c11
	if (!test_ClearDecompressExample(2, 78, 17, TEST_CLEAR_EXAMPLE_2,
Packit Service bb5c11
	                                 sizeof(TEST_CLEAR_EXAMPLE_2)))
Packit Service fa4841
		return -1;
Packit Service fa4841
Packit Service bb5c11
	if (!test_ClearDecompressExample(3, 64, 24, TEST_CLEAR_EXAMPLE_3,
Packit Service bb5c11
	                                 sizeof(TEST_CLEAR_EXAMPLE_3)))
Packit Service fa4841
		return -1;
Packit Service fa4841
Packit Service bb5c11
	if (!test_ClearDecompressExample(4, 7, 15, TEST_CLEAR_EXAMPLE_4,
Packit Service bb5c11
	                                 sizeof(TEST_CLEAR_EXAMPLE_4)))
Packit Service fa4841
		return -1;
Packit Service fa4841
Packit Service fa4841
	return 0;
Packit Service fa4841
}
Packit Service bb5c11