From 8c199714e9bc638fb3f6ec747fb7a23373e49335 Mon Sep 17 00:00:00 2001 From: Eirik Aavitsland Date: Mon, 9 Jul 2018 10:45:22 +0200 Subject: Fix crash when parsing malformed url reference The parsing did not check for end of input. Change-Id: I56a478877d242146395977b767511425d2b8ced1 Reviewed-by: Lars Knoll --- tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'tests') diff --git a/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp b/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp index 87d24c7..a8fc9de 100644 --- a/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp +++ b/tests/auto/qsvgrenderer/tst_qsvgrenderer.cpp @@ -54,6 +54,8 @@ private slots: void getSetCheck(); void inexistentUrl(); void emptyUrl(); + void invalidUrl_data(); + void invalidUrl(); void testStrokeWidth(); void testMapViewBoxToTarget(); void testRenderElement(); @@ -132,6 +134,30 @@ void tst_QSvgRenderer::emptyUrl() QVERIFY(renderer.isValid()); } +void tst_QSvgRenderer::invalidUrl_data() +{ + QTest::addColumn("svg"); + + QTest::newRow("00") << QByteArray(""); + QTest::newRow("01") << QByteArray(""); + QTest::newRow("02") << QByteArray(""); + QTest::newRow("03") << QByteArray(""); + QTest::newRow("04") << QByteArray(""); + QTest::newRow("05") << QByteArray(""); + QTest::newRow("06") << QByteArray(""); + QTest::newRow("07") << QByteArray(""); + QTest::newRow("08") << QByteArray(""); + QTest::newRow("09") << QByteArray(""); +} + +void tst_QSvgRenderer::invalidUrl() +{ + QFETCH(QByteArray, svg); + + QSvgRenderer renderer(svg); + QVERIFY(renderer.isValid()); +} + void tst_QSvgRenderer::testStrokeWidth() { qreal squareSize = 30.0; -- cgit v1.2.1