mirror of
https://github.com/qgis/QGIS.git
synced 2025-10-18 00:06:00 -04:00
[processing] Add unit tests for retrieving param from script code
And fix number param retrieving from script code
This commit is contained in:
parent
3ef7b3b7eb
commit
f24cda4402
@ -863,14 +863,20 @@ class ParameterNumber(Parameter):
|
|||||||
if self.optional:
|
if self.optional:
|
||||||
param_type += 'optional '
|
param_type += 'optional '
|
||||||
param_type += 'number'
|
param_type += 'number'
|
||||||
return '##' + self.name + '=' + param_type + str(self.default)
|
code = '##' + self.name + '=' + param_type
|
||||||
|
if self.default:
|
||||||
|
code += str(self.default)
|
||||||
|
return code
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def fromScriptCode(self, line):
|
def fromScriptCode(self, line):
|
||||||
|
|
||||||
isOptional, name, definition = _splitParameterOptions(line)
|
isOptional, name, definition = _splitParameterOptions(line)
|
||||||
descName = _createDescriptiveName(name)
|
descName = _createDescriptiveName(name)
|
||||||
if definition.lower().strip().startswith('number'):
|
if definition.lower().strip().startswith('number'):
|
||||||
default = definition.strip()[len('number') + 1:] or None
|
default = definition.strip()[len('number'):] or None
|
||||||
|
if default == 'None':
|
||||||
|
default = None
|
||||||
return ParameterNumber(name, descName, default=default, optional=isOptional)
|
return ParameterNumber(name, descName, default=default, optional=isOptional)
|
||||||
|
|
||||||
def _evaluate(self, value):
|
def _evaluate(self, value):
|
||||||
|
@ -41,7 +41,8 @@ from processing.core.parameters import (Parameter,
|
|||||||
ParameterVector,
|
ParameterVector,
|
||||||
ParameterTableField,
|
ParameterTableField,
|
||||||
ParameterSelection,
|
ParameterSelection,
|
||||||
ParameterExpression)
|
ParameterExpression,
|
||||||
|
getParameterFromString)
|
||||||
from processing.tools import dataobjects
|
from processing.tools import dataobjects
|
||||||
from processing.tests.TestData import points2
|
from processing.tests.TestData import points2
|
||||||
|
|
||||||
@ -96,6 +97,19 @@ class ParameterBooleanTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, True)
|
self.assertEqual(requiredParameter.value, True)
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterBoolean('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterBoolean))
|
||||||
|
self.assertFalse(result.optional)
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterBoolean))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterCRSTest(unittest.TestCase):
|
class ParameterCRSTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -119,6 +133,18 @@ class ParameterCRSTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, 'EPSG:12003')
|
self.assertEqual(requiredParameter.value, 'EPSG:12003')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterCrs('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterCrs))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterCrs))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterDataObjectTest(unittest.TestCase):
|
class ParameterDataObjectTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -161,6 +187,18 @@ class ParameterExtentTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, '1,2,3,4')
|
self.assertEqual(requiredParameter.value, '1,2,3,4')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterExtent('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterExtent))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterExtent))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterPointTest(unittest.TestCase):
|
class ParameterPointTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -191,6 +229,18 @@ class ParameterPointTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, '1,2')
|
self.assertEqual(requiredParameter.value, '1,2')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterPoint('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterPoint))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterPoint))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterSelectionTest(unittest.TestCase):
|
class ParameterSelectionTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -283,6 +333,18 @@ class ParameterFileTest(unittest.TestCase):
|
|||||||
parameter.setValue('myFile.png')
|
parameter.setValue('myFile.png')
|
||||||
self.assertEqual(parameter.getValueAsCommandLineParameter(), '"myFile.png"')
|
self.assertEqual(parameter.getValueAsCommandLineParameter(), '"myFile.png"')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterFile('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterFile))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterFile))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class TestParameterFixedTable(unittest.TestCase):
|
class TestParameterFixedTable(unittest.TestCase):
|
||||||
|
|
||||||
@ -393,6 +455,18 @@ class ParameterMultipleInputTest(unittest.TestCase):
|
|||||||
|
|
||||||
# TODO With Layer Name, instead of Layer object
|
# TODO With Layer Name, instead of Layer object
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterMultipleInput('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterMultipleInput))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterMultipleInput))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterNumberTest(unittest.TestCase):
|
class ParameterNumberTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -447,6 +521,18 @@ class ParameterNumberTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, 5)
|
self.assertEqual(requiredParameter.value, 5)
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterNumber('myName', 'myDescription')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterNumber))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterNumber))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterStringTest(unittest.TestCase):
|
class ParameterStringTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -470,6 +556,18 @@ class ParameterStringTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, 'check')
|
self.assertEqual(requiredParameter.value, 'check')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterString('myName', 'myDescription', default='test')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterString))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterString))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterExpressionTest(unittest.TestCase):
|
class ParameterExpressionTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -493,6 +591,18 @@ class ParameterExpressionTest(unittest.TestCase):
|
|||||||
self.assertFalse(requiredParameter.setValue(None))
|
self.assertFalse(requiredParameter.setValue(None))
|
||||||
self.assertEqual(requiredParameter.value, 'check')
|
self.assertEqual(requiredParameter.value, 'check')
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parameter = ParameterExpression('myName', 'myDescription', default='test')
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterExpression))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterExpression))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
|
|
||||||
class ParameterTableFieldTest(unittest.TestCase):
|
class ParameterTableFieldTest(unittest.TestCase):
|
||||||
|
|
||||||
@ -505,6 +615,21 @@ class ParameterTableFieldTest(unittest.TestCase):
|
|||||||
parameter = ParameterTableField(
|
parameter = ParameterTableField(
|
||||||
'myName', 'myDesc', parent_name, optional=True)
|
'myName', 'myDesc', parent_name, optional=True)
|
||||||
|
|
||||||
|
def testScriptCode(self):
|
||||||
|
parent_name = 'test_parent_layer'
|
||||||
|
test_data = points2()
|
||||||
|
test_layer = QgsVectorLayer(test_data, parent_name, 'ogr')
|
||||||
|
parameter = ParameterTableField(
|
||||||
|
'myName', 'myDesc', parent_name)
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterTableField))
|
||||||
|
|
||||||
|
parameter.optional = True
|
||||||
|
code = parameter.getAsScriptCode()
|
||||||
|
result = getParameterFromString(code)
|
||||||
|
self.assertTrue(isinstance(result, ParameterTableField))
|
||||||
|
self.assertTrue(result.optional)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user