From 7f1945c5fb492505db9a43853987eaf805291919 Mon Sep 17 00:00:00 2001 From: Robert Loehning Date: Tue, 18 Aug 2020 14:41:01 +0200 Subject: Fix check against division by zero The squared values must not be zero. Since both are qreal, this can happen even when neither of them is zero itself. Fixes: oss-fuzz-24738 Pick-to: 5.12 5.15 Change-Id: I61b2bc891e7e3831d4b6ee68b467db28c4f877d4 Reviewed-by: Thiago Macieira --- tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp') diff --git a/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp b/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp index b348302..ea23d2d 100644 --- a/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp +++ b/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp @@ -84,6 +84,7 @@ private slots: void duplicateStyleId(); void oss_fuzz_23731(); void oss_fuzz_24131(); + void oss_fuzz_24738(); #ifndef QT_NO_COMPRESS void testGzLoading(); @@ -1624,5 +1625,12 @@ void tst_QSvgRenderer::oss_fuzz_24131() renderer.render(&painter); } +void tst_QSvgRenderer::oss_fuzz_24738() +{ + // when configured with "-sanitize undefined", this resulted in: + // "runtime error: division by zero" + QSvgRenderer().load(QByteArray("")); +} + QTEST_MAIN(tst_QSvgRenderer) #include "tst_qsvgrenderer.moc" -- cgit v1.2.1