mirror of
https://github.com/qgis/QGIS.git
synced 2025-04-11 00:04:27 -04:00
224 lines
7.9 KiB
Python
224 lines
7.9 KiB
Python
# -*- coding: utf-8 -*-
|
|
"""QGIS Unit tests for QgsComposerPolygon.
|
|
|
|
.. note:: This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
"""
|
|
__author__ = '(C) 2016 by Paul Blottiere'
|
|
__date__ = '14/03/2016'
|
|
__copyright__ = 'Copyright 2016, The QGIS Project'
|
|
# This will get replaced with a git SHA1 when you do a git archive
|
|
__revision__ = '$Format:%H$'
|
|
|
|
import qgis # NOQA
|
|
|
|
from qgis.PyQt.QtGui import QPolygonF
|
|
from qgis.PyQt.QtCore import QPointF
|
|
|
|
from qgis.core import (QgsComposerPolygon,
|
|
QgsComposerItem,
|
|
QgsComposition,
|
|
QgsFillSymbol,
|
|
QgsProject
|
|
)
|
|
from qgis.testing import (start_app,
|
|
unittest
|
|
)
|
|
from utilities import unitTestDataPath
|
|
from qgscompositionchecker import QgsCompositionChecker
|
|
|
|
start_app()
|
|
TEST_DATA_DIR = unitTestDataPath()
|
|
|
|
|
|
class TestQgsComposerPolygon(unittest.TestCase):
|
|
|
|
def __init__(self, methodName):
|
|
"""Run once on class initialization."""
|
|
unittest.TestCase.__init__(self, methodName)
|
|
|
|
# create composition
|
|
self.mComposition = QgsComposition(QgsProject.instance())
|
|
self.mComposition.setPaperSize(297, 210)
|
|
|
|
# create
|
|
polygon = QPolygonF()
|
|
polygon.append(QPointF(0.0, 0.0))
|
|
polygon.append(QPointF(100.0, 0.0))
|
|
polygon.append(QPointF(200.0, 100.0))
|
|
polygon.append(QPointF(100.0, 200.0))
|
|
|
|
self.mComposerPolygon = QgsComposerPolygon(polygon, self.mComposition)
|
|
self.mComposition.addComposerPolygon(self.mComposerPolygon)
|
|
|
|
# style
|
|
props = {}
|
|
props["color"] = "green"
|
|
props["style"] = "solid"
|
|
props["style_border"] = "solid"
|
|
props["color_border"] = "black"
|
|
props["width_border"] = "10.0"
|
|
props["joinstyle"] = "miter"
|
|
|
|
style = QgsFillSymbol.createSimple(props)
|
|
self.mComposerPolygon.setPolygonStyleSymbol(style)
|
|
|
|
def testDisplayName(self):
|
|
"""Test if displayName is valid"""
|
|
|
|
self.assertEqual(self.mComposerPolygon.displayName(), "<polygon>")
|
|
|
|
def testType(self):
|
|
"""Test if type is valid"""
|
|
|
|
self.assertEqual(
|
|
self.mComposerPolygon.type(), QgsComposerItem.ComposerPolygon)
|
|
|
|
def testDefaultStyle(self):
|
|
"""Test polygon rendering with default style."""
|
|
|
|
self.mComposerPolygon.setDisplayNodes(False)
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_defaultstyle', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
def testDisplayNodes(self):
|
|
"""Test displayNodes method"""
|
|
|
|
self.mComposerPolygon.setDisplayNodes(True)
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_displaynodes', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
self.mComposerPolygon.setDisplayNodes(False)
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_defaultstyle', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
def testSelectedNode(self):
|
|
"""Test selectedNode and deselectNode methods"""
|
|
|
|
self.mComposerPolygon.setDisplayNodes(True)
|
|
|
|
self.mComposerPolygon.setSelectedNode(3)
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_selectednode', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
self.mComposerPolygon.deselectNode()
|
|
self.mComposerPolygon.setDisplayNodes(False)
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_defaultstyle', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
def testRemoveNode(self):
|
|
"""Test removeNode method"""
|
|
|
|
rc = self.mComposerPolygon.removeNode(100)
|
|
self.assertEqual(rc, False)
|
|
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_defaultstyle', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
|
|
def testAddNode(self):
|
|
"""Test addNode method"""
|
|
|
|
# default searching radius is 10
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 10.0))
|
|
self.assertEqual(rc, False)
|
|
|
|
# default searching radius is 10
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 9.99))
|
|
self.assertEqual(rc, True)
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 5)
|
|
|
|
def testAddNodeCustomRadius(self):
|
|
"""Test addNode with custom radius"""
|
|
|
|
# default searching radius is 10
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 8.1), True, 8.0)
|
|
self.assertEqual(rc, False)
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
|
|
# default searching radius is 10
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 7.9), True, 8.0)
|
|
self.assertEqual(rc, True)
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 5)
|
|
|
|
def testAddNodeWithoutCheckingArea(self):
|
|
"""Test addNode without checking the maximum distance allowed"""
|
|
|
|
# default searching radius is 10
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 20.0))
|
|
self.assertEqual(rc, False)
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
|
|
# default searching radius is 10
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 4)
|
|
rc = self.mComposerPolygon.addNode(QPointF(50.0, 20.0), False)
|
|
self.assertEqual(rc, True)
|
|
self.assertEqual(self.mComposerPolygon.nodesSize(), 5)
|
|
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_addnode', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
def testMoveNode(self):
|
|
"""Test moveNode method"""
|
|
|
|
rc = self.mComposerPolygon.moveNode(30, QPointF(100.0, 300.0))
|
|
self.assertEqual(rc, False)
|
|
|
|
rc = self.mComposerPolygon.moveNode(3, QPointF(100.0, 150.0))
|
|
self.assertEqual(rc, True)
|
|
|
|
checker = QgsCompositionChecker(
|
|
'composerpolygon_movenode', self.mComposition)
|
|
checker.setControlPathPrefix("composer_polygon")
|
|
myTestResult, myMessage = checker.testComposition()
|
|
assert myTestResult, myMessage
|
|
|
|
def testNodeAtPosition(self):
|
|
"""Test nodeAtPosition method"""
|
|
|
|
# default searching radius is 10
|
|
rc = self.mComposerPolygon.nodeAtPosition(QPointF(100.0, 210.0))
|
|
self.assertEqual(rc, -1)
|
|
|
|
# default searching radius is 10
|
|
rc = self.mComposerPolygon.nodeAtPosition(
|
|
QPointF(100.0, 210.0), False)
|
|
self.assertEqual(rc, 3)
|
|
|
|
# default searching radius is 10
|
|
rc = self.mComposerPolygon.nodeAtPosition(
|
|
QPointF(100.0, 210.0), True, 10.1)
|
|
self.assertEqual(rc, 3)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|