1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
|
"""
***************************************************************************
QgisAlgorithmTests.py
---------------------
Date : January 2016
Copyright : (C) 2016 by Matthias Kuhn
Email : matthias@opengis.ch
***************************************************************************
* *
* 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__ = "Matthias Kuhn"
__date__ = "January 2016"
__copyright__ = "(C) 2016, Matthias Kuhn"
import AlgorithmsTestBase
import nose2
import shutil
import os
from qgis.core import (
QgsApplication,
QgsProcessingAlgorithm,
QgsProcessingFeedback,
QgsProcessingException,
)
from qgis.analysis import QgsNativeAlgorithms
import unittest
from qgis.testing import start_app, QgisTestCase
from processing.tools.dataobjects import createContext
from processing.core.ProcessingConfig import ProcessingConfig
from processing.modeler.ModelerUtils import ModelerUtils
class TestAlg(QgsProcessingAlgorithm):
def __init__(self):
super().__init__()
def name(self):
return "testalg"
def displayName(self):
return "testalg"
def initAlgorithm(self, config=None):
pass
def createInstance(self):
return TestAlg()
def processAlgorithm(self, parameters, context, feedback):
raise QgsProcessingException("Exception while processing")
return {}
class TestQgisAlgorithms(QgisTestCase, AlgorithmsTestBase.AlgorithmsTest):
@classmethod
def setUpClass(cls):
start_app()
from processing.core.Processing import Processing
Processing.initialize()
cls.cleanup_paths = []
cls.in_place_layers = {}
cls.vector_layer_params = {}
@classmethod
def tearDownClass(cls):
from processing.core.Processing import Processing
Processing.deinitialize()
for path in cls.cleanup_paths:
shutil.rmtree(path)
def definition_file(self):
return "qgis_algorithm_tests1.yaml"
def testProcessingException(self):
"""
Test that Python exception is caught when running an alg
"""
alg = TestAlg()
context = createContext()
feedback = QgsProcessingFeedback()
results, ok = alg.run({}, context, feedback)
self.assertFalse(ok)
def testParameterPythonImport(self):
for t in QgsApplication.processingRegistry().parameterTypes():
import_string = t.pythonImportString()
# check that pythonImportString correctly imports
# and that we can instantiate an object!
if t.className() == "QgsProcessingParameterProviderConnection":
exec(
f"{import_string}\ntest = {t.className()}('id','name', 'provider')\nassert test is not None",
{},
)
else:
exec(
f"{import_string}\ntest = {t.className()}('id','name')\nassert test is not None"
), {}
if __name__ == "__main__":
nose2.main()
|