From 03236f55bb3f5ab6a9e73bbab1227a8e6ef93d0f Mon Sep 17 00:00:00 2001 From: Amine Khaldi Date: Mon, 23 Sep 2013 11:36:35 +0000 Subject: [PATCH] [MSVFW32_WINETEST] * Sync with Wine 1.7.1. CORE-7469 svn path=/trunk/; revision=60337 --- rostests/winetests/msvfw32/CMakeLists.txt | 7 +- rostests/winetests/msvfw32/msvfw.c | 140 +++++++++++++++++++++- rostests/winetests/msvfw32/testlist.c | 5 +- 3 files changed, 141 insertions(+), 11 deletions(-) diff --git a/rostests/winetests/msvfw32/CMakeLists.txt b/rostests/winetests/msvfw32/CMakeLists.txt index db1b17f8a1c..cff4bf2528a 100644 --- a/rostests/winetests/msvfw32/CMakeLists.txt +++ b/rostests/winetests/msvfw32/CMakeLists.txt @@ -1,10 +1,5 @@ -add_definitions( - -D__ROS_LONG64__ - -D_DLL -D__USE_CRTIMP) - add_executable(msvfw32_winetest msvfw.c testlist.c) -target_link_libraries(msvfw32_winetest wine) set_module_type(msvfw32_winetest win32cui) -add_importlibs(msvfw32_winetest msvfw32 msvcrt kernel32 ntdll) +add_importlibs(msvfw32_winetest msvfw32 msvcrt kernel32) add_cd_file(TARGET msvfw32_winetest DESTINATION reactos/bin FOR all) diff --git a/rostests/winetests/msvfw32/msvfw.c b/rostests/winetests/msvfw32/msvfw.c index b0d820815a1..139c644326a 100644 --- a/rostests/winetests/msvfw32/msvfw.c +++ b/rostests/winetests/msvfw32/msvfw.c @@ -1,7 +1,7 @@ /* * Unit tests for video playback * - * Copyright 2008 Jörg Höhle + * Copyright 2008,2010 Jörg Höhle * Copyright 2008 Austin English * * This library is free software; you can redistribute it and/or @@ -63,7 +63,145 @@ static void test_OpenCase(void) } } +static void test_Locate(void) +{ + static BITMAPINFOHEADER bi = {sizeof(BITMAPINFOHEADER),32,8, 1,8, BI_RLE8, 0,100000,100000, 0,0}; + static BITMAPINFOHEADER bo = {sizeof(BITMAPINFOHEADER),32,8, 1,8, BI_RGB, 0,100000,100000, 0,0}; + HIC h; + DWORD err; + + /* Oddly, MSDN documents that ICLocate takes BITMAPINFOHEADER + * pointers, while ICDecompressQuery takes the larger + * BITMAPINFO. Probably it's all the same as long as the + * variable length color quads are present when they are + * needed. */ + + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h != 0, "RLE8->RGB failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + + bo.biHeight = - bo.biHeight; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h == 0, "RLE8->RGB height<0 succeeded\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + + bi.biCompression = mmioFOURCC('c','v','i','d'); /* Cinepak */ + h = ICOpen(ICTYPE_VIDEO, mmioFOURCC('c','v','i','d'), ICMODE_DECOMPRESS); + if (h == 0) win_skip("Cinepak/ICCVID codec not found\n"); + else { + bo.biBitCount = bi.biBitCount = 32; + err = ICDecompressQuery(h, &bi, &bo); + ok(err == ICERR_OK, "Query cvid->RGB32: %d\n", err); + + err = ICDecompressQuery(h, &bi, NULL); + ok(err == ICERR_OK, "Query cvid 32: %d\n", err); + + bo.biHeight = -bo.biHeight; + err = ICDecompressQuery(h, &bi, &bo); + todo_wine ok(err == ICERR_OK, "Query cvid->RGB32 height<0: %d\n", err); + bo.biHeight = -bo.biHeight; + + ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + + bo.biBitCount = bi.biBitCount = 8; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "cvid->RGB8 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "cvid->RGB8 height<0 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + + bo.biBitCount = bi.biBitCount = 16; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h != 0, "cvid->RGB16 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "cvid->RGB16 height<0 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + + bo.biBitCount = bi.biBitCount = 32; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h != 0, "cvid->RGB32 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "cvid->RGB32 height<0 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + + bi.biCompression = mmioFOURCC('C','V','I','D'); + /* Unlike ICOpen, upper case fails with ICLocate. */ + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h == 0, "CVID->RGB32 upper case succeeded\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + } + + bi.biCompression = mmioFOURCC('M','S','V','C'); /* MS Video 1 */ + + bo.biBitCount = bi.biBitCount = 16; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h != 0, "MSVC->RGB16 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + + bo.biHeight = - bo.biHeight; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "MSVC->RGB16 height<0 failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight = - bo.biHeight; + + bo.biHeight--; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h == 0, "MSVC->RGB16 height too small succeeded\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + bo.biHeight++; + + /* ICLocate wants upper case MSVC */ + bi.biCompression = mmioFOURCC('m','s','v','c'); + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h == 0, "msvc->RGB16 succeeded\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + + bi.biCompression = mmioFOURCC('M','S','V','C'); + h = ICOpen(ICTYPE_VIDEO, mmioFOURCC('M','S','V','C'), ICMODE_DECOMPRESS); + ok(h != 0, "No MSVC codec installed!?\n"); + if (h != 0) { + err = ICDecompressQuery(h, &bi, &bo); + ok(err == ICERR_OK, "Query MSVC->RGB16: %d\n", err); + + err = ICDecompressQuery(h, &bi, NULL); + ok(err == ICERR_OK, "Query MSVC 16: %d\n", err); + + bo.biHeight = -bo.biHeight; + err = ICDecompressQuery(h, &bi, &bo); + todo_wine ok(err == ICERR_OK, "Query MSVC->RGB16 height<0: %d\n", err); + bo.biHeight = -bo.biHeight; + + bi.biCompression = mmioFOURCC('m','s','v','c'); + err = ICDecompressQuery(h, &bi, &bo); + ok(err == ICERR_BADFORMAT, "Query msvc->RGB16: %d\n", err); + + ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + } + + bi.biCompression = BI_RGB; + bo.biBitCount = bi.biBitCount = 8; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + todo_wine ok(h != 0, "RGB8->RGB identity failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); + + bi.biCompression = BI_RLE8; + h = ICLocate(ICTYPE_VIDEO, 0, &bi, &bo, ICMODE_DECOMPRESS); + ok(h != 0, "RLE8->RGB again failed\n"); + if (h) ok(ICClose(h) == ICERR_OK,"ICClose failed\n"); +} + START_TEST(msvfw) { test_OpenCase(); + test_Locate(); } diff --git a/rostests/winetests/msvfw32/testlist.c b/rostests/winetests/msvfw32/testlist.c index 1aa529c6574..ebe4aec9336 100644 --- a/rostests/winetests/msvfw32/testlist.c +++ b/rostests/winetests/msvfw32/testlist.c @@ -1,10 +1,7 @@ /* Automatically generated file; DO NOT EDIT!! */ -#define WIN32_LEAN_AND_MEAN -#include - #define STANDALONE -#include "wine/test.h" +#include extern void func_msvfw(void);