include/vcl/test/GraphicsRenderTests.hxx |   17 +-
 vcl/backendtest/GraphicsRenderTests.cxx  |  195 +++++++++++++++++++++++++++----
 vcl/backendtest/VisualBackendTest.cxx    |   10 -
 vcl/backendtest/outputdevice/bitmap.cxx  |   36 ++++-
 vcl/inc/test/outputdevice.hxx            |   13 +-
 vcl/qa/cppunit/BackendTest.cxx           |  141 +++++++++++++++++++---
 6 files changed, 347 insertions(+), 65 deletions(-)

New commits:
commit c46d2c25ee790d02a97ed6bc7403571a2a0823bd
Author:     homeboy445 <akshitsa...@gmail.com>
AuthorDate: Thu Jul 22 17:05:33 2021 +0530
Commit:     Tomaž Vajngerl <qui...@gmail.com>
CommitDate: Fri Aug 27 05:29:35 2021 +0200

    backendtest: Test Drawing Bitmap other than 24bpp
    
    This test draws bitmap formats other than 24bpp -
    namely 32bpp and 8bpp greyscale.
    
    Change-Id: I1b21214429be08fc7cf1eb086c2ad8946780f481
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/119371
    Tested-by: Jenkins
    Reviewed-by: Tomaž Vajngerl <qui...@gmail.com>

diff --git a/include/vcl/test/GraphicsRenderTests.hxx 
b/include/vcl/test/GraphicsRenderTests.hxx
index dee521438edc..41cbe561b483 100644
--- a/include/vcl/test/GraphicsRenderTests.hxx
+++ b/include/vcl/test/GraphicsRenderTests.hxx
@@ -81,11 +81,18 @@ class VCL_PLUGIN_PUBLIC GraphicsRenderTests
     void testDrawBezierAAWithPolylineB2D();
     void testDrawDropShapeWithPolygon();
     void testDrawDropShapeAAWithPolygon();
-    void testDrawBitmap();
-    void testDrawTransformedBitmap();
-    void testDrawBitmapExWithAlpha();
-    void testDrawMask();
-    void testDrawBlend();
+    void testDrawBitmap24bpp();
+    void testDrawTransformedBitmap24bpp();
+    void testDrawBitmapExWithAlpha24bpp();
+    void testDrawMask24bpp();
+    void testDrawBlend24bpp();
+    void testDrawBitmap32bpp();
+    void testDrawTransformedBitmap32bpp();
+    void testDrawBitmapExWithAlpha32bpp();
+    void testDrawMask32bpp();
+    void testDrawBlend32bpp();
+    void testDrawBitmap8bppGreyScale();
+    void testDrawTransformedBitmap8bppGreyScale();
     void testDrawXor();
     void testClipRectangle();
     void testClipPolygon();
diff --git a/vcl/backendtest/GraphicsRenderTests.cxx 
b/vcl/backendtest/GraphicsRenderTests.cxx
index 263d37cf6d3f..ad508ec6d975 100644
--- a/vcl/backendtest/GraphicsRenderTests.cxx
+++ b/vcl/backendtest/GraphicsRenderTests.cxx
@@ -13,6 +13,9 @@
 #include <vcl/test/GraphicsRenderTests.hxx>
 #include <tools/stream.hxx>
 
+#include <svdata.hxx>
+#include <salinst.hxx>
+
 #include <unordered_map>
 
 #define SHOULD_ASSERT                                                          
                    \
@@ -32,6 +35,7 @@ void exportBitmapExToImage(OUString const& rImageName, const 
BitmapEx& rBitmapEx
     SvFileStream aStream(rImageName, StreamMode::WRITE | StreamMode::TRUNC);
     GraphicFilter::GetGraphicFilter().compressAsPNG(aBitmapEx, aStream);
 }
+bool is32bppSupported() { return 
ImplGetSVData()->mpDefInst->supportsBitmap32(); }
 }
 
 OUString GraphicsRenderTests::returnTestStatus(vcl::test::TestResult const 
result)
@@ -758,11 +762,11 @@ void GraphicsRenderTests::testDrawDropShapeAAWithPolygon()
     }
 }
 
-void GraphicsRenderTests::testDrawBitmap()
+void GraphicsRenderTests::testDrawBitmap24bpp()
 {
     vcl::test::OutputDeviceTestBitmap aOutDevTest;
-    Bitmap aBitmap = aOutDevTest.setupDrawBitmap();
-    OUString aTestName = "testDrawBitmap";
+    Bitmap aBitmap = aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N24_BPP);
+    OUString aTestName = "testDrawBitmap24bpp";
     if (!SHOULD_ASSERT)
     {
         appendTestResult(aTestName, "SKIPPED");
@@ -779,11 +783,11 @@ void GraphicsRenderTests::testDrawBitmap()
     }
 }
 
-void GraphicsRenderTests::testDrawTransformedBitmap()
+void GraphicsRenderTests::testDrawTransformedBitmap24bpp()
 {
     vcl::test::OutputDeviceTestBitmap aOutDevTest;
-    Bitmap aBitmap = aOutDevTest.setupDrawTransformedBitmap();
-    OUString aTestName = "testDrawTransformedBitmap";
+    Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N24_BPP);
+    OUString aTestName = "testDrawTransformedBitmap24bpp";
     if (!SHOULD_ASSERT)
     {
         appendTestResult(aTestName, "SKIPPED");
@@ -800,11 +804,11 @@ void GraphicsRenderTests::testDrawTransformedBitmap()
     }
 }
 
-void GraphicsRenderTests::testDrawBitmapExWithAlpha()
+void GraphicsRenderTests::testDrawBitmapExWithAlpha24bpp()
 {
     vcl::test::OutputDeviceTestBitmap aOutDevTest;
-    Bitmap aBitmap = aOutDevTest.setupDrawBitmapExWithAlpha();
-    OUString aTestName = "testDrawBitmapExWithAlpha";
+    Bitmap aBitmap = 
aOutDevTest.setupDrawBitmapExWithAlpha(vcl::PixelFormat::N24_BPP);
+    OUString aTestName = "testDrawBitmapExWithAlpha24bpp";
     if (!SHOULD_ASSERT)
     {
         appendTestResult(aTestName, "SKIPPED");
@@ -821,11 +825,11 @@ void GraphicsRenderTests::testDrawBitmapExWithAlpha()
     }
 }
 
-void GraphicsRenderTests::testDrawMask()
+void GraphicsRenderTests::testDrawMask24bpp()
 {
     vcl::test::OutputDeviceTestBitmap aOutDevTest;
-    Bitmap aBitmap = aOutDevTest.setupDrawMask();
-    OUString aTestName = "testDrawMask";
+    Bitmap aBitmap = aOutDevTest.setupDrawMask(vcl::PixelFormat::N24_BPP);
+    OUString aTestName = "testDrawMask24bpp";
     if (!SHOULD_ASSERT)
     {
         appendTestResult(aTestName, "SKIPPED");
@@ -841,11 +845,11 @@ void GraphicsRenderTests::testDrawMask()
     }
 }
 
-void GraphicsRenderTests::testDrawBlend()
+void GraphicsRenderTests::testDrawBlend24bpp()
 {
     vcl::test::OutputDeviceTestBitmap aOutDevTest;
-    BitmapEx aBitmapEx = aOutDevTest.setupDrawBlend();
-    OUString aTestName = "testDrawBlend";
+    BitmapEx aBitmapEx = aOutDevTest.setupDrawBlend(vcl::PixelFormat::N24_BPP);
+    OUString aTestName = "testDrawBlend24bpp";
     if (!SHOULD_ASSERT)
     {
         appendTestResult(aTestName, "SKIPPED");
@@ -1545,6 +1549,150 @@ void 
GraphicsRenderTests::testEvenOddRuleInIntersectingRectsWithPolyPolygonB2D()
     }
 }
 
+void GraphicsRenderTests::testDrawBitmap8bppGreyScale()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N8_BPP, 
true);
+    OUString aTestName = "testDrawBitmap8bppGreyScale";
+    if (!SHOULD_ASSERT)
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult
+        = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap8bppGreyScale(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawTransformedBitmap8bppGreyScale()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N8_BPP, true);
+    OUString aTestName = "testDrawTransformedBitmap8bppGreyScale";
+    if (!SHOULD_ASSERT)
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult
+        = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap8bppGreyScale(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawBitmap32bpp()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N32_BPP);
+    OUString aTestName = "testDrawBitmap32bpp";
+    if (!SHOULD_ASSERT || !is32bppSupported())
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult
+        = vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawTransformedBitmap32bpp()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N32_BPP);
+    OUString aTestName = "testDrawTransformedBitmap32bpp";
+    if (!SHOULD_ASSERT || !is32bppSupported())
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult
+        = vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawBitmapExWithAlpha32bpp()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = 
aOutDevTest.setupDrawBitmapExWithAlpha(vcl::PixelFormat::N32_BPP);
+    OUString aTestName = "testDrawBitmapExWithAlpha32bpp";
+    if (!SHOULD_ASSERT || !is32bppSupported())
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult
+        = vcl::test::OutputDeviceTestBitmap::checkBitmapExWithAlpha(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawMask32bpp()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    Bitmap aBitmap = aOutDevTest.setupDrawMask(vcl::PixelFormat::N32_BPP);
+    OUString aTestName = "testDrawMask32bpp";
+    if (!SHOULD_ASSERT || !is32bppSupported())
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult = 
vcl::test::OutputDeviceTestBitmap::checkMask(aBitmap);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmap : Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        BitmapEx aBitmapEx(aBitmap);
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
+void GraphicsRenderTests::testDrawBlend32bpp()
+{
+    vcl::test::OutputDeviceTestBitmap aOutDevTest;
+    BitmapEx aBitmapEx = aOutDevTest.setupDrawBlend(vcl::PixelFormat::N32_BPP);
+    OUString aTestName = "testDrawBlend32bpp";
+    if (!SHOULD_ASSERT || !is32bppSupported())
+    {
+        appendTestResult(aTestName, "SKIPPED");
+        return;
+    }
+    vcl::test::TestResult eResult = 
vcl::test::OutputDeviceTestBitmap::checkBlend(aBitmapEx);
+    appendTestResult(aTestName, returnTestStatus(eResult),
+                     (m_aStoreResultantBitmap ? aBitmapEx.GetBitmap() : 
Bitmap()));
+    if (m_aStoreResultantBitmap)
+    {
+        exportBitmapExToImage(m_aUserInstallPath + aTestName + ".png", 
aBitmapEx);
+    }
+}
+
 void GraphicsRenderTests::runALLTests()
 {
     testDrawRectWithRectangle();
@@ -1576,11 +1724,11 @@ void GraphicsRenderTests::runALLTests()
     testDrawInvertTrackFrameWithRectangle();
     testDrawBezierWithPolylineB2D();
     testDrawBezierAAWithPolylineB2D();
-    testDrawBitmap();
-    testDrawTransformedBitmap();
-    testDrawBitmapExWithAlpha();
-    testDrawMask();
-    testDrawBlend();
+    testDrawBitmap24bpp();
+    testDrawTransformedBitmap24bpp();
+    testDrawBitmapExWithAlpha24bpp();
+    testDrawMask24bpp();
+    testDrawBlend24bpp();
     testDrawXor();
     testClipRectangle();
     testClipPolygon();
@@ -1619,6 +1767,13 @@ void GraphicsRenderTests::runALLTests()
     testTextDrawing();
     testEvenOddRuleInIntersectingRectsWithPolyPolygon();
     testEvenOddRuleInIntersectingRectsWithPolyPolygonB2D();
+    testDrawBitmap8bppGreyScale();
+    testDrawTransformedBitmap8bppGreyScale();
+    testDrawBitmap32bpp();
+    testDrawTransformedBitmap32bpp();
+    testDrawBitmapExWithAlpha32bpp();
+    testDrawMask32bpp();
+    testDrawBlend32bpp();
 }
 
 void GraphicsRenderTests::appendTestResult(OUString aTestName, OUString 
aTestStatus,
diff --git a/vcl/backendtest/VisualBackendTest.cxx 
b/vcl/backendtest/VisualBackendTest.cxx
index 55ec308fb226..5426bf2acdd8 100644
--- a/vcl/backendtest/VisualBackendTest.cxx
+++ b/vcl/backendtest/VisualBackendTest.cxx
@@ -477,35 +477,35 @@ public:
         aRectangle = aRegions[index++];
         {
             vcl::test::OutputDeviceTestBitmap aOutDevTest;
-            Bitmap aBitmap = aOutDevTest.setupDrawBitmap();
+            Bitmap aBitmap = 
aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N24_BPP);
             
assertAndSetBackground(vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap),
 aRectangle, rRenderContext);
             drawBitmapScaledAndCentered(aRectangle, aBitmap, rRenderContext);
         }
         aRectangle = aRegions[index++];
         {
             vcl::test::OutputDeviceTestBitmap aOutDevTest;
-            Bitmap aBitmap = aOutDevTest.setupDrawTransformedBitmap();
+            Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N24_BPP);
             
assertAndSetBackground(vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap),
 aRectangle, rRenderContext);
             drawBitmapScaledAndCentered(aRectangle, aBitmap, rRenderContext);
         }
         aRectangle = aRegions[index++];
         {
             vcl::test::OutputDeviceTestBitmap aOutDevTest;
-            Bitmap aBitmap = aOutDevTest.setupDrawBitmapExWithAlpha();
+            Bitmap aBitmap = 
aOutDevTest.setupDrawBitmapExWithAlpha(vcl::PixelFormat::N24_BPP);
             
assertAndSetBackground(vcl::test::OutputDeviceTestBitmap::checkBitmapExWithAlpha(aBitmap),
 aRectangle, rRenderContext);
             drawBitmapScaledAndCentered(aRectangle, aBitmap, rRenderContext);
         }
         aRectangle = aRegions[index++];
         {
             vcl::test::OutputDeviceTestBitmap aOutDevTest;
-            Bitmap aBitmap = aOutDevTest.setupDrawMask();
+            Bitmap aBitmap = 
aOutDevTest.setupDrawMask(vcl::PixelFormat::N24_BPP);
             
assertAndSetBackground(vcl::test::OutputDeviceTestBitmap::checkMask(aBitmap), 
aRectangle, rRenderContext);
             drawBitmapScaledAndCentered(aRectangle, aBitmap, rRenderContext);
         }
         aRectangle = aRegions[index++];
         {
             vcl::test::OutputDeviceTestBitmap aOutDevTest;
-            BitmapEx aBitmap = aOutDevTest.setupDrawBlend();
+            BitmapEx aBitmap = 
aOutDevTest.setupDrawBlend(vcl::PixelFormat::N24_BPP);
             
assertAndSetBackground(vcl::test::OutputDeviceTestBitmap::checkBlend(aBitmap), 
aRectangle, rRenderContext);
             drawBitmapScaledAndCentered(aRectangle, aBitmap.GetBitmap(), 
rRenderContext);
         }
diff --git a/vcl/backendtest/outputdevice/bitmap.cxx 
b/vcl/backendtest/outputdevice/bitmap.cxx
index 2c7d7569cde6..066355c53f14 100644
--- a/vcl/backendtest/outputdevice/bitmap.cxx
+++ b/vcl/backendtest/outputdevice/bitmap.cxx
@@ -15,10 +15,10 @@
 
 namespace vcl::test {
 
-Bitmap OutputDeviceTestBitmap::setupDrawTransformedBitmap()
+Bitmap OutputDeviceTestBitmap::setupDrawTransformedBitmap(vcl::PixelFormat 
aBitmapFormat,bool isBitmapGreyScale)
 {
     Size aBitmapSize(9, 9);
-    Bitmap aBitmap(aBitmapSize, vcl::PixelFormat::N24_BPP);
+    Bitmap aBitmap(aBitmapSize, aBitmapFormat);
     {
         BitmapScopedWriteAccess aWriteAccess(aBitmap);
         aWriteAccess->Erase(constFillColor);
@@ -27,6 +27,9 @@ Bitmap OutputDeviceTestBitmap::setupDrawTransformedBitmap()
         aWriteAccess->DrawRect(tools::Rectangle(2, 2,  6, 6));
     }
 
+    if (isBitmapGreyScale)
+        aBitmap.Convert(BmpConversion::N8BitGreys);
+
     initialSetup(13, 13, constBackgroundColor);
 
     basegfx::B2DHomMatrix aTransform;
@@ -40,10 +43,10 @@ Bitmap OutputDeviceTestBitmap::setupDrawTransformedBitmap()
 }
 
 
-Bitmap OutputDeviceTestBitmap::setupDrawBitmap()
+Bitmap OutputDeviceTestBitmap::setupDrawBitmap(vcl::PixelFormat 
aBitmapFormat,bool isBitmapGreyScale)
 {
     Size aBitmapSize(9, 9);
-    Bitmap aBitmap(aBitmapSize, vcl::PixelFormat::N24_BPP);
+    Bitmap aBitmap(aBitmapSize, aBitmapFormat);
     {
         BitmapScopedWriteAccess aWriteAccess(aBitmap);
         aWriteAccess->Erase(constFillColor);
@@ -52,6 +55,9 @@ Bitmap OutputDeviceTestBitmap::setupDrawBitmap()
         aWriteAccess->DrawRect(tools::Rectangle(2, 2,  6, 6));
     }
 
+    if (isBitmapGreyScale)
+        aBitmap.Convert(BmpConversion::N8BitGreys);
+
     initialSetup(13, 13, constBackgroundColor);
 
     Point aPoint((maVDRectangle.GetWidth()  / 2.0) - (aBitmapSize.Width() / 
2.0),
@@ -62,10 +68,10 @@ Bitmap OutputDeviceTestBitmap::setupDrawBitmap()
     return mpVirtualDevice->GetBitmap(maVDRectangle.TopLeft(), 
maVDRectangle.GetSize());
 }
 
-Bitmap OutputDeviceTestBitmap::setupDrawBitmapExWithAlpha()
+Bitmap OutputDeviceTestBitmap::setupDrawBitmapExWithAlpha(vcl::PixelFormat 
aBitmapFormat)
 {
     Size aBitmapSize(9, 9);
-    Bitmap aBitmap(aBitmapSize, vcl::PixelFormat::N24_BPP);
+    Bitmap aBitmap(aBitmapSize, aBitmapFormat);
     {
         BitmapScopedWriteAccess aWriteAccess(aBitmap);
         aWriteAccess->Erase(COL_WHITE);
@@ -92,10 +98,10 @@ Bitmap OutputDeviceTestBitmap::setupDrawBitmapExWithAlpha()
     return mpVirtualDevice->GetBitmap(maVDRectangle.TopLeft(), 
maVDRectangle.GetSize());
 }
 
-Bitmap OutputDeviceTestBitmap::setupDrawMask()
+Bitmap OutputDeviceTestBitmap::setupDrawMask(vcl::PixelFormat aBitmapFormat)
 {
     Size aBitmapSize(9, 9);
-    Bitmap aBitmap(aBitmapSize, vcl::PixelFormat::N24_BPP);
+    Bitmap aBitmap(aBitmapSize, aBitmapFormat);
     {
         BitmapScopedWriteAccess aWriteAccess(aBitmap);
         aWriteAccess->Erase(COL_WHITE);
@@ -111,10 +117,10 @@ Bitmap OutputDeviceTestBitmap::setupDrawMask()
     return mpVirtualDevice->GetBitmap(maVDRectangle.TopLeft(), 
maVDRectangle.GetSize());
 }
 
-BitmapEx OutputDeviceTestBitmap::setupDrawBlend()
+BitmapEx OutputDeviceTestBitmap::setupDrawBlend(vcl::PixelFormat aBitmapFormat)
 {
     Size aBitmapSize(9, 9);
-    Bitmap aBitmap(aBitmapSize, vcl::PixelFormat::N24_BPP);
+    Bitmap aBitmap(aBitmapSize, aBitmapFormat);
     {
         BitmapScopedWriteAccess aWriteAccess(aBitmap);
         aWriteAccess->Erase(COL_WHITE);
@@ -157,6 +163,16 @@ TestResult 
OutputDeviceTestBitmap::checkTransformedBitmap(Bitmap& rBitmap)
     return checkRectangles(rBitmap, aExpected);
 }
 
+TestResult OutputDeviceTestBitmap::checkTransformedBitmap8bppGreyScale(Bitmap& 
rBitmap)
+{
+    std::vector<Color> aExpected
+    {
+        Color(0xC0,0xC0,0xC0), Color(0xC0,0xC0,0xC0),
+        Color(0xE2,0xE2,0xE2), Color(0xE,0xE,0xE), Color(0xE2,0xE2,0xE2), 
Color(0xE,0xE,0xE), Color(0xE,0xE,0xE)
+    };
+    return checkRectangles(rBitmap, aExpected);
+}
+
 TestResult OutputDeviceTestBitmap::checkBitmapExWithAlpha(Bitmap& rBitmap)
 {
     const Color aBlendedColor(0xEE, 0xEE, 0x33);
diff --git a/vcl/inc/test/outputdevice.hxx b/vcl/inc/test/outputdevice.hxx
index b72206d76cd1..67ae1be876b1 100644
--- a/vcl/inc/test/outputdevice.hxx
+++ b/vcl/inc/test/outputdevice.hxx
@@ -105,16 +105,19 @@ class VCL_DLLPUBLIC OutputDeviceTestBitmap : public 
OutputDeviceTestCommon
 public:
     OutputDeviceTestBitmap() = default;
 
-    Bitmap setupDrawTransformedBitmap();
-    Bitmap setupDrawBitmap();
-    Bitmap setupDrawBitmapExWithAlpha();
-    Bitmap setupDrawMask();
-    BitmapEx setupDrawBlend();
+    Bitmap setupDrawTransformedBitmap(vcl::PixelFormat aBitmapFormat,
+                                      bool isBitmapGreyScale = false);
+    Bitmap setupDrawBitmap(vcl::PixelFormat aBitmapFormat, bool 
isBitmapGreyScale = false);
+    Bitmap setupDrawBitmapExWithAlpha(vcl::PixelFormat aBitmapFormat);
+    Bitmap setupDrawMask(vcl::PixelFormat aBitmapFormat);
+    BitmapEx setupDrawBlend(vcl::PixelFormat aBitmapFormat);
 
     static TestResult checkTransformedBitmap(Bitmap& rBitmap);
     static TestResult checkBitmapExWithAlpha(Bitmap& rBitmap);
     static TestResult checkMask(Bitmap& rBitmap);
     static TestResult checkBlend(const BitmapEx& rBitmap);
+
+    static TestResult checkTransformedBitmap8bppGreyScale(Bitmap& rBitmap);
 };
 
 class VCL_DLLPUBLIC OutputDeviceTestAnotherOutDev : public 
OutputDeviceTestCommon
diff --git a/vcl/qa/cppunit/BackendTest.cxx b/vcl/qa/cppunit/BackendTest.cxx
index 7bef9b2479d7..c337ad1f0707 100644
--- a/vcl/qa/cppunit/BackendTest.cxx
+++ b/vcl/qa/cppunit/BackendTest.cxx
@@ -16,6 +16,9 @@
 #include <basegfx/matrix/b2dhommatrix.hxx>
 #include <bitmap/BitmapWriteAccess.hxx>
 
+#include <svdata.hxx>
+#include <salinst.hxx>
+
 #include <test/outputdevice.hxx>
 
 // Run tests from visualbackendtest ('bin/run visualbackendtest').
@@ -57,6 +60,8 @@ class BackendTest : public test::BootstrapFixture
         }
     }
 
+    bool is32bppSupported() { return 
ImplGetSVData()->mpDefInst->supportsBitmap32(); }
+
 public:
     BackendTest()
         : BootstrapFixture(true, false)
@@ -449,62 +454,148 @@ public:
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
 
-    void testDrawBitmap()
+    void testDrawBitmap24bpp()
     {
         if (getDefaultDeviceBitCount() < 24)
             return;
         vcl::test::OutputDeviceTestBitmap aOutDevTest;
-        Bitmap aBitmap = aOutDevTest.setupDrawBitmap();
-        exportImage("08-01_bitmap_test.png", aBitmap);
+        Bitmap aBitmap = 
aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N24_BPP);
+        exportImage("08-01_bitmap_test_24bpp.png", aBitmap);
         auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
         if (SHOULD_ASSERT)
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
 
-    void testDrawTransformedBitmap()
+    void testDrawTransformedBitmap24bpp()
     {
         if (getDefaultDeviceBitCount() < 24)
             return;
         vcl::test::OutputDeviceTestBitmap aOutDevTest;
-        Bitmap aBitmap = aOutDevTest.setupDrawTransformedBitmap();
+        Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N24_BPP);
         auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
-        exportImage("08-02_transformed_bitmap_test.png", aBitmap);
+        exportImage("08-02_transformed_bitmap_test_24bpp.png", aBitmap);
         if (SHOULD_ASSERT)
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
 
-    void testDrawBitmapExWithAlpha()
+    void testDrawBitmapExWithAlpha24bpp()
     {
         if (getDefaultDeviceBitCount() < 24)
             return;
         vcl::test::OutputDeviceTestBitmap aOutDevTest;
-        Bitmap aBitmap = aOutDevTest.setupDrawBitmapExWithAlpha();
+        Bitmap aBitmap = 
aOutDevTest.setupDrawBitmapExWithAlpha(vcl::PixelFormat::N24_BPP);
         auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkBitmapExWithAlpha(aBitmap);
-        exportImage("08-03_bitmapex_with_alpha_test.png", aBitmap);
+        exportImage("08-03_bitmapex_with_alpha_test_24bpp.png", aBitmap);
         if (SHOULD_ASSERT)
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
 
-    void testDrawMask()
+    void testDrawMask24bpp()
     {
         if (getDefaultDeviceBitCount() < 24)
             return;
         vcl::test::OutputDeviceTestBitmap aOutDevTest;
-        Bitmap aBitmap = aOutDevTest.setupDrawMask();
+        Bitmap aBitmap = aOutDevTest.setupDrawMask(vcl::PixelFormat::N24_BPP);
         auto eResult = vcl::test::OutputDeviceTestBitmap::checkMask(aBitmap);
-        exportImage("08-04_mask_test.png", aBitmap);
+        exportImage("08-04_mask_test_24bpp.png", aBitmap);
         if (SHOULD_ASSERT)
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
 
-    void testDrawBlend()
+    void testDrawBlend24bpp()
     {
         if (getDefaultDeviceBitCount() < 24)
             return;
         vcl::test::OutputDeviceTestBitmap aOutDevTest;
-        BitmapEx aBitmapEx = aOutDevTest.setupDrawBlend();
+        BitmapEx aBitmapEx = 
aOutDevTest.setupDrawBlend(vcl::PixelFormat::N24_BPP);
         auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkBlend(aBitmapEx);
-        exportImage("08-05_blend_test.png", aBitmapEx);
+        exportImage("08-05_blend_test_24bpp.png", aBitmapEx);
+        if (SHOULD_ASSERT)
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawBitmap32bpp()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = 
aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N32_BPP);
+        exportImage("09-01_bitmap_test_32bpp.png", aBitmap);
+        auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
+        if (SHOULD_ASSERT && is32bppSupported())
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawTransformedBitmap32bpp()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N32_BPP);
+        auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap(aBitmap);
+        exportImage("09-02_transformed_bitmap_test_32bpp.png", aBitmap);
+        if (SHOULD_ASSERT && is32bppSupported())
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawBitmapExWithAlpha32bpp()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = 
aOutDevTest.setupDrawBitmapExWithAlpha(vcl::PixelFormat::N32_BPP);
+        auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkBitmapExWithAlpha(aBitmap);
+        exportImage("09-03_bitmapex_with_alpha_test_32bpp.png", aBitmap);
+        if (SHOULD_ASSERT && is32bppSupported())
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawMask32bpp()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = aOutDevTest.setupDrawMask(vcl::PixelFormat::N32_BPP);
+        auto eResult = vcl::test::OutputDeviceTestBitmap::checkMask(aBitmap);
+        exportImage("09-04_mask_test_32bpp.png", aBitmap);
+        if (SHOULD_ASSERT && is32bppSupported())
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawBlend32bpp()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        BitmapEx aBitmapEx = 
aOutDevTest.setupDrawBlend(vcl::PixelFormat::N32_BPP);
+        auto eResult = 
vcl::test::OutputDeviceTestBitmap::checkBlend(aBitmapEx);
+        exportImage("09-05_blend_test_32bpp.png", aBitmapEx);
+        if (SHOULD_ASSERT && is32bppSupported())
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawBitmap8bppGreyScale()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = aOutDevTest.setupDrawBitmap(vcl::PixelFormat::N8_BPP, 
true);
+        exportImage("010-01_bitmap_test_8bpp_greyscale.png", aBitmap);
+        auto eResult
+            = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap8bppGreyScale(aBitmap);
+        if (SHOULD_ASSERT)
+            CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
+    }
+
+    void testDrawTransformedBitmap8bppGreyScale()
+    {
+        if (getDefaultDeviceBitCount() < 24)
+            return;
+        vcl::test::OutputDeviceTestBitmap aOutDevTest;
+        Bitmap aBitmap = 
aOutDevTest.setupDrawTransformedBitmap(vcl::PixelFormat::N8_BPP, true);
+        auto eResult
+            = 
vcl::test::OutputDeviceTestBitmap::checkTransformedBitmap8bppGreyScale(aBitmap);
+        exportImage("010-02_transformed_bitmap_test_8bpp_greyscale.png", 
aBitmap);
         if (SHOULD_ASSERT)
             CPPUNIT_ASSERT(eResult != vcl::test::TestResult::Failed);
     }
@@ -1251,13 +1342,23 @@ public:
 
     CPPUNIT_TEST(testFilledAsymmetricalDropShape);
 
-    CPPUNIT_TEST(testDrawBitmap);
-    CPPUNIT_TEST(testDrawTransformedBitmap);
-    CPPUNIT_TEST(testDrawBitmapExWithAlpha);
-    CPPUNIT_TEST(testDrawMask);
-    CPPUNIT_TEST(testDrawBlend);
+    CPPUNIT_TEST(testDrawBitmap24bpp);
+    CPPUNIT_TEST(testDrawTransformedBitmap24bpp);
+    CPPUNIT_TEST(testDrawBitmapExWithAlpha24bpp);
+    CPPUNIT_TEST(testDrawMask24bpp);
+    CPPUNIT_TEST(testDrawBlend24bpp);
+
     CPPUNIT_TEST(testDrawXor);
 
+    CPPUNIT_TEST(testDrawBitmap32bpp);
+    CPPUNIT_TEST(testDrawTransformedBitmap32bpp);
+    CPPUNIT_TEST(testDrawBitmapExWithAlpha32bpp);
+    CPPUNIT_TEST(testDrawMask32bpp);
+    CPPUNIT_TEST(testDrawBlend32bpp);
+
+    CPPUNIT_TEST(testDrawTransformedBitmap8bppGreyScale);
+    CPPUNIT_TEST(testDrawBitmap8bppGreyScale);
+
     CPPUNIT_TEST(testDrawTransformedBitmapExAlpha);
 
     CPPUNIT_TEST(testClipRectangle);

Reply via email to