[PATCH 2/2] ddraw/tests: Mark WARP negative rectangle handling broken.

Stefan Dösinger stefan at codeweavers.com
Tue Jan 9 09:34:26 CST 2018


Signed-off-by: Stefan Dösinger <stefan at codeweavers.com>
---
 dlls/ddraw/tests/ddraw1.c | 28 ++++++++++++++++++++++------
 dlls/ddraw/tests/ddraw2.c | 28 ++++++++++++++++++++++------
 dlls/ddraw/tests/ddraw4.c | 26 ++++++++++++++++++++------
 dlls/ddraw/tests/ddraw7.c | 26 ++++++++++++++++++++------
 4 files changed, 84 insertions(+), 24 deletions(-)

diff --git a/dlls/ddraw/tests/ddraw1.c b/dlls/ddraw/tests/ddraw1.c
index 58703013c1..916680fa9c 100644
--- a/dlls/ddraw/tests/ddraw1.c
+++ b/dlls/ddraw/tests/ddraw1.c
@@ -10969,9 +10969,21 @@ static void test_clear(void)
     hr = IDirect3DViewport_Clear(viewport, 2, rect, D3DCLEAR_TARGET);
     ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
 
+    color = get_surface_color(rt, 160, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    color = get_surface_color(rt, 160, 120);
+    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 120);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+
+    viewport_set_background(device, viewport, white);
+    hr = IDirect3DViewport_Clear(viewport, 1, &rect_full, D3DCLEAR_TARGET);
+    ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
+
     /* negative x, negative y.
-     *
-     * FIXME: WARP seems to clear the entire screen here.*/
+     * Also ignored, except on WARP, which clears the entire screen.*/
     rect_negneg.x1 = 640;
     rect_negneg.y1 = 240;
     rect_negneg.x2 = 320;
@@ -10981,13 +10993,17 @@ static void test_clear(void)
     ok(hr == D3D_OK, "Failed to clear, hr %#x.\n", hr);
 
     color = get_surface_color(rt, 160, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 160, 120);
-    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 120);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
 
     /* Test how the viewport affects clears */
     viewport_set_background(device, viewport, white);
diff --git a/dlls/ddraw/tests/ddraw2.c b/dlls/ddraw/tests/ddraw2.c
index 0b51c99964..e7c81ca81f 100644
--- a/dlls/ddraw/tests/ddraw2.c
+++ b/dlls/ddraw/tests/ddraw2.c
@@ -12345,9 +12345,21 @@ static void test_clear(void)
     hr = IDirect3DViewport2_Clear(viewport, 2, rect, D3DCLEAR_TARGET);
     ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
 
+    color = get_surface_color(rt, 160, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    color = get_surface_color(rt, 160, 120);
+    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 120);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+
+    viewport_set_background(device, viewport, white);
+    hr = IDirect3DViewport2_Clear(viewport, 1, &rect_full, D3DCLEAR_TARGET);
+    ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
+
     /* negative x, negative y.
-     *
-     * FIXME: WARP seems to clear the entire screen here.*/
+     * Also ignored, except on WARP, which clears the entire screen.*/
     rect_negneg.x1 = 640;
     rect_negneg.y1 = 240;
     rect_negneg.x2 = 320;
@@ -12357,13 +12369,17 @@ static void test_clear(void)
     ok(hr == D3D_OK, "Failed to clear, hr %#x.\n", hr);
 
     color = get_surface_color(rt, 160, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 160, 120);
-    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 120);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
 
     /* Test how the viewport affects clears */
     viewport_set_background(device, viewport, white);
diff --git a/dlls/ddraw/tests/ddraw4.c b/dlls/ddraw/tests/ddraw4.c
index dde67d7a33..dac0c0a350 100644
--- a/dlls/ddraw/tests/ddraw4.c
+++ b/dlls/ddraw/tests/ddraw4.c
@@ -14402,9 +14402,19 @@ static void test_clear(void)
     hr = IDirect3DViewport3_Clear2(viewport, 2, rect, D3DCLEAR_TARGET, 0xffff0000, 0.0, 0);
     ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
 
+    color = get_surface_color(rt, 160, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    color = get_surface_color(rt, 160, 120);
+    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 120);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+
+    hr = IDirect3DViewport3_Clear2(viewport, 1, &rect_full, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0);
+    ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
     /* negative x, negative y.
-     *
-     * FIXME: WARP seems to clear the entire screen here.*/
+     * Also ignored, except on WARP, which clears the entire screen.*/
     rect_negneg.x1 = 640;
     rect_negneg.y1 = 240;
     rect_negneg.x2 = 320;
@@ -14413,13 +14423,17 @@ static void test_clear(void)
     ok(hr == D3D_OK, "Failed to clear, hr %#x.\n", hr);
 
     color = get_surface_color(rt, 160, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 160, 120);
-    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 120);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
 
     /* Test how the viewport affects clears */
     hr = IDirect3DViewport3_Clear2(viewport, 1, &rect_full, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0);
diff --git a/dlls/ddraw/tests/ddraw7.c b/dlls/ddraw/tests/ddraw7.c
index a9474f2444..639e099cdd 100644
--- a/dlls/ddraw/tests/ddraw7.c
+++ b/dlls/ddraw/tests/ddraw7.c
@@ -13769,9 +13769,19 @@ static void test_clear(void)
     hr = IDirect3DDevice7_Clear(device, 2, rect, D3DCLEAR_TARGET, 0xffff0000, 0.0, 0);
     ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
 
+    color = get_surface_color(rt, 160, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    color = get_surface_color(rt, 160, 120);
+    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 360);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    color = get_surface_color(rt, 480, 120);
+    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+
+    hr = IDirect3DDevice7_Clear(device, 0, NULL, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0);
+    ok(SUCCEEDED(hr), "Failed to clear, hr %#x.\n", hr);
     /* negative x, negative y.
-     *
-     * FIXME: WARP seems to clear the entire screen here.*/
+     * Also ignored, except on WARP, which clears the entire screen.*/
     rect_negneg.x1 = 640;
     rect_negneg.y1 = 240;
     rect_negneg.x2 = 320;
@@ -13780,13 +13790,17 @@ static void test_clear(void)
     ok(hr == D3D_OK, "Failed to clear, hr %#x.\n", hr);
 
     color = get_surface_color(rt, 160, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 3(pos, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 160, 120);
-    ok(compare_color(color, 0x00ff0000, 0), "Clear rectangle 1(pos, pos) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 360);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(NULL) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
     color = get_surface_color(rt, 480, 120);
-    ok(compare_color(color, 0x00ffffff, 0), "Clear rectangle 4(neg, neg) has color %08x.\n", color);
+    ok(compare_color(color, 0x00ffffff, 0) || broken(compare_color(color, 0x0000ff00, 0)),
+            "Got unexpected color %08x.\n", color);
 
     /* Test how the viewport affects clears */
     hr = IDirect3DDevice7_Clear(device, 0, NULL, D3DCLEAR_TARGET, 0xffffffff, 0.0, 0);
-- 
2.13.6




More information about the wine-devel mailing list