123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498 |
- import pytest
- import unittest.mock
- import cura.Settings.CuraContainerStack
- from cura.Settings.Exceptions import InvalidContainerError, InvalidOperationError
- from UM.Settings.DefinitionContainer import DefinitionContainer
- from UM.Settings.InstanceContainer import InstanceContainer
- from UM.Settings.SettingInstance import InstanceState
- import UM.Settings.ContainerRegistry
- import UM.Settings.ContainerStack
- import UM.Settings.SettingDefinition
- from cura.Settings.cura_empty_instance_containers import empty_container
- def getInstanceContainer(container_type) -> InstanceContainer:
- """Gets an instance container with a specified container type.
- :param container_type: The type metadata for the instance container.
- :return: An instance container instance.
- """
- container = InstanceContainer(container_id = "InstanceContainer")
- container.setMetaDataEntry("type", container_type)
- return container
- class DefinitionContainerSubClass(DefinitionContainer):
- def __init__(self):
- super().__init__(container_id = "SubDefinitionContainer")
- class InstanceContainerSubClass(InstanceContainer):
- def __init__(self, container_type):
- super().__init__(container_id = "SubInstanceContainer")
- self.setMetaDataEntry("type", container_type)
- def test_addContainer(global_stack):
- """Tests whether adding a container is properly forbidden."""
- with pytest.raises(InvalidOperationError):
- global_stack.addContainer(unittest.mock.MagicMock())
- def test_addExtruder(global_stack):
- """Tests adding extruders to the global stack."""
- mock_definition = unittest.mock.MagicMock()
- mock_definition.getProperty = lambda key, property, context = None: 2 if key == "machine_extruder_count" and property == "value" else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = mock_definition
- assert len(global_stack.extruderList) == 0
- first_extruder = unittest.mock.MagicMock()
- first_extruder.getMetaDataEntry = lambda key: 0 if key == "position" else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.addExtruder(first_extruder)
- assert len(global_stack.extruderList) == 1
- assert global_stack.extruderList[0] == first_extruder
- second_extruder = unittest.mock.MagicMock()
- second_extruder.getMetaDataEntry = lambda key: 1 if key == "position" else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.addExtruder(second_extruder)
- assert len(global_stack.extruderList) == 2
- assert global_stack.extruderList[1] == second_extruder
-
-
-
-
- assert len(global_stack.extruderList) == 2
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "material"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainUserChangesInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.userChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "user"),
- InstanceContainerSubClass(container_type = "user")
- ])
- def test_constrainUserChangesValid(container, global_stack):
- global_stack.userChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "material"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainQualityChangesInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.qualityChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "quality_changes"),
- InstanceContainerSubClass(container_type = "quality_changes")
- ])
- def test_constrainQualityChangesValid(container, global_stack):
- global_stack.qualityChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "material"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainQualityInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.quality = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "quality"),
- InstanceContainerSubClass(container_type = "quality")
- ])
- def test_constrainQualityValid(container, global_stack):
- global_stack.quality = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "quality"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainMaterialInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.material = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "material"),
- InstanceContainerSubClass(container_type = "material")
- ])
- def test_constrainMaterialValid(container, global_stack):
- global_stack.material = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "material"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainVariantInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.variant = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "variant"),
- InstanceContainerSubClass(container_type = "variant")
- ])
- def test_constrainVariantValid(container, global_stack):
- global_stack.variant = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong container type"),
- getInstanceContainer(container_type = "material"),
- DefinitionContainer(container_id = "wrong class")
- ])
- def test_constrainDefinitionChangesInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.definitionChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "definition_changes"),
- InstanceContainerSubClass(container_type = "definition_changes")
- ])
- def test_constrainDefinitionChangesValid(container, global_stack):
- global_stack.definitionChanges = container
- @pytest.mark.parametrize("container", [
- getInstanceContainer(container_type = "wrong class"),
- getInstanceContainer(container_type = "material"),
- ])
- def test_constrainDefinitionInvalid(container, global_stack):
- with pytest.raises(InvalidContainerError):
- global_stack.definition = container
- @pytest.mark.parametrize("container", [
- DefinitionContainer(container_id = "DefinitionContainer"),
- DefinitionContainerSubClass()
- ])
- def test_constrainDefinitionValid(container, global_stack):
- global_stack.definition = container
- def test_deserializeCompletesEmptyContainers(global_stack):
- """Tests whether deserialising completes the missing containers with empty ones. The initial containers are just the
- definition and the definition_changes (that cannot be empty after CURA-5281)
- """
- global_stack._containers = [DefinitionContainer(container_id = "definition"), global_stack.definitionChanges]
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- global_stack.deserialize("")
- assert len(global_stack.getContainers()) == len(cura.Settings.CuraContainerStack._ContainerIndexes.IndexTypeMap)
- for container_type_index in cura.Settings.CuraContainerStack._ContainerIndexes.IndexTypeMap:
- if container_type_index in \
- (cura.Settings.CuraContainerStack._ContainerIndexes.Definition, cura.Settings.CuraContainerStack._ContainerIndexes.DefinitionChanges):
- continue
- assert global_stack.getContainer(container_type_index) == empty_container
- def test_deserializeRemovesWrongInstanceContainer(global_stack):
- """Tests whether an instance container with the wrong type gets removed when deserialising."""
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Quality] = getInstanceContainer(container_type = "wrong type")
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Definition] = DefinitionContainer(container_id = "some definition")
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- global_stack.deserialize("")
- assert global_stack.quality == global_stack._empty_instance_container
- def test_deserializeRemovesWrongContainerClass(global_stack):
- """Tests whether a container with the wrong class gets removed when deserialising."""
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Quality] = DefinitionContainer(container_id = "wrong class")
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Definition] = DefinitionContainer(container_id = "some definition")
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- global_stack.deserialize("")
- assert global_stack.quality == global_stack._empty_instance_container
- def test_deserializeWrongDefinitionClass(global_stack):
- """Tests whether an instance container in the definition spot results in an error."""
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Definition] = getInstanceContainer(container_type = "definition")
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- with pytest.raises(UM.Settings.ContainerStack.InvalidContainerStackError):
- global_stack.deserialize("")
- def test_deserializeMoveInstanceContainer(global_stack):
- """Tests whether an instance container with the wrong type is moved into the correct slot by deserialising."""
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Quality] = getInstanceContainer(container_type = "material")
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Definition] = DefinitionContainer(container_id = "some definition")
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- global_stack.deserialize("")
- assert global_stack.quality == empty_container
- assert global_stack.material != empty_container
- def test_deserializeMoveDefinitionContainer(global_stack):
- """Tests whether a definition container in the wrong spot is moved into the correct spot by deserialising."""
- global_stack._containers[cura.Settings.CuraContainerStack._ContainerIndexes.Material] = DefinitionContainer(container_id = "some definition")
- with unittest.mock.patch("UM.Settings.ContainerStack.ContainerStack.deserialize", unittest.mock.MagicMock()):
- global_stack.deserialize("")
- assert global_stack.material == empty_container
- assert global_stack.definition != empty_container
- def test_getPropertyFallThrough(global_stack):
- """Tests whether getProperty properly applies the stack-like behaviour on its containers."""
-
- mock_layer_heights = {}
- mock_no_settings = {}
- container_indexes = cura.Settings.CuraContainerStack._ContainerIndexes
- for type_id, type_name in container_indexes.IndexTypeMap.items():
- container = unittest.mock.MagicMock()
- container.getProperty = lambda key, property, context = None, type_id = type_id: type_id if (key == "layer_height" and property == "value") else None
- container.hasProperty = lambda key, property: key == "layer_height"
- container.getMetaDataEntry = unittest.mock.MagicMock(return_value = type_name)
- mock_layer_heights[type_id] = container
- container = unittest.mock.MagicMock()
- container.getProperty = unittest.mock.MagicMock(return_value = None)
- container.hasProperty = unittest.mock.MagicMock(return_value = False)
- container.getMetaDataEntry = unittest.mock.MagicMock(return_value = type_name)
- mock_no_settings[type_id] = container
- global_stack.userChanges = mock_no_settings[container_indexes.UserChanges]
- global_stack.qualityChanges = mock_no_settings[container_indexes.QualityChanges]
- global_stack.quality = mock_no_settings[container_indexes.Quality]
- global_stack.material = mock_no_settings[container_indexes.Material]
- global_stack.variant = mock_no_settings[container_indexes.Variant]
- global_stack.definitionChanges = mock_no_settings[container_indexes.DefinitionChanges]
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = mock_layer_heights[container_indexes.Definition]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.Definition
- global_stack.definitionChanges = mock_layer_heights[container_indexes.DefinitionChanges]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.DefinitionChanges
- global_stack.variant = mock_layer_heights[container_indexes.Variant]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.Variant
- global_stack.material = mock_layer_heights[container_indexes.Material]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.Material
- global_stack.quality = mock_layer_heights[container_indexes.Quality]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.Quality
- global_stack.qualityChanges = mock_layer_heights[container_indexes.QualityChanges]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.QualityChanges
- global_stack.userChanges = mock_layer_heights[container_indexes.UserChanges]
- assert global_stack.getProperty("layer_height", "value") == container_indexes.UserChanges
- def test_getPropertyNoResolveInDefinition(global_stack):
- """In definitions, test whether having no resolve allows us to find the value."""
- value = unittest.mock.MagicMock()
- value.getProperty = lambda key, property, context = None: 10 if (key == "material_bed_temperature" and property == "value") else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = value
- assert global_stack.getProperty("material_bed_temperature", "value") == 10
- def test_getPropertyResolveInDefinition(global_stack):
- """In definitions, when the value is asked and there is a resolve function, it must get the resolve first."""
- resolve_and_value = unittest.mock.MagicMock()
- resolve_and_value.getProperty = lambda key, property, context = None: (7.5 if property == "resolve" else 5) if (key == "material_bed_temperature" and property in ("resolve", "value")) else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = resolve_and_value
- assert global_stack.getProperty("material_bed_temperature", "value") == 7.5
- def test_getPropertyResolveInInstance(global_stack):
- """In instance containers, when the value is asked and there is a resolve function, it must get the value first."""
- container_indices = cura.Settings.CuraContainerStack._ContainerIndexes
- instance_containers = {}
- for container_type in container_indices.IndexTypeMap:
- instance_containers[container_type] = unittest.mock.MagicMock()
- instance_containers[container_type].getProperty = lambda key, property, context = None: (7.5 if property == "resolve" else (InstanceState.User if property == "state" else (5 if property != "limit_to_extruder" else "-1"))) if (key == "material_bed_temperature") else None
- instance_containers[container_type].getMetaDataEntry = unittest.mock.MagicMock(return_value = container_indices.IndexTypeMap[container_type])
- instance_containers[container_indices.Definition].getProperty = lambda key, property, context = None: 10 if (key == "material_bed_temperature" and property == "value") else None
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = instance_containers[container_indices.Definition]
-
- global_stack.definitionChanges = instance_containers[container_indices.DefinitionChanges]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- global_stack.variant = instance_containers[container_indices.Variant]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- global_stack.material = instance_containers[container_indices.Material]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- global_stack.quality = instance_containers[container_indices.Quality]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- global_stack.qualityChanges = instance_containers[container_indices.QualityChanges]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- global_stack.userChanges = instance_containers[container_indices.UserChanges]
- assert global_stack.getProperty("material_bed_temperature", "value") == 5
- def test_getPropertyInstancesBeforeResolve(global_stack):
- """Tests whether the value in instances gets evaluated before the resolve in definitions."""
- def getValueProperty(key, property, context = None):
- if key != "material_bed_temperature":
- return None
- if property == "value":
- return 10
- if property == "limit_to_extruder":
- return -1
- return InstanceState.User
- def getResolveProperty(key, property, context = None):
- if key != "material_bed_temperature":
- return None
- if property == "resolve":
- return 7.5
- return None
- value = unittest.mock.MagicMock()
- value.getProperty = unittest.mock.MagicMock(side_effect = getValueProperty)
- value.getMetaDataEntry = unittest.mock.MagicMock(return_value = "quality_changes")
- resolve = unittest.mock.MagicMock()
- resolve.getProperty = unittest.mock.MagicMock(side_effect = getResolveProperty)
- with unittest.mock.patch("cura.Settings.CuraContainerStack.DefinitionContainer", unittest.mock.MagicMock):
- global_stack.definition = resolve
- global_stack.qualityChanges = value
- assert global_stack.getProperty("material_bed_temperature", "value") == 10
- def test_hasUserValueUserChanges(global_stack):
- """Tests whether the hasUserValue returns true for settings that are changed in the user-changes container."""
- container = unittest.mock.MagicMock()
- container.getMetaDataEntry = unittest.mock.MagicMock(return_value = "user")
- container.hasProperty = lambda key, property: key == "layer_height"
- global_stack.userChanges = container
- assert global_stack.hasUserValue("layer_height")
- assert not global_stack.hasUserValue("infill_sparse_density")
- assert not global_stack.hasUserValue("")
- def test_hasUserValueQualityChanges(global_stack):
- """Tests whether the hasUserValue returns true for settings that are changed in the quality-changes container."""
- container = unittest.mock.MagicMock()
- container.getMetaDataEntry = unittest.mock.MagicMock(return_value = "quality_changes")
- container.hasProperty = lambda key, property: key == "layer_height"
- global_stack.qualityChanges = container
- assert global_stack.hasUserValue("layer_height")
- assert not global_stack.hasUserValue("infill_sparse_density")
- assert not global_stack.hasUserValue("")
- def test_hasNoUserValue(global_stack):
- """Tests whether a container in some other place on the stack is correctly not recognised as user value."""
- container = unittest.mock.MagicMock()
- container.getMetaDataEntry = unittest.mock.MagicMock(return_value = "quality")
- container.hasProperty = lambda key, property: key == "layer_height"
- global_stack.quality = container
- assert not global_stack.hasUserValue("layer_height")
- def test_insertContainer(global_stack):
- """Tests whether inserting a container is properly forbidden."""
- with pytest.raises(InvalidOperationError):
- global_stack.insertContainer(0, unittest.mock.MagicMock())
- def test_removeContainer(global_stack):
- """Tests whether removing a container is properly forbidden."""
- with pytest.raises(InvalidOperationError):
- global_stack.removeContainer(unittest.mock.MagicMock())
- def test_setNextStack(global_stack):
- """Tests whether changing the next stack is properly forbidden."""
- with pytest.raises(InvalidOperationError):
- global_stack.setNextStack(unittest.mock.MagicMock())
- @pytest.mark.parametrize("key, property, value", [
- ("layer_height", "value", 0.1337),
- ("foo", "value", 100),
- ("support_enabled", "value", True),
- ("layer_height", "default_value", 0.1337),
- ("layer_height", "is_bright_pink", "of course")
- ])
- def test_setPropertyUser(key, property, value, global_stack):
- user_changes = unittest.mock.MagicMock()
- user_changes.getMetaDataEntry = unittest.mock.MagicMock(return_value = "user")
- global_stack.userChanges = user_changes
- global_stack.setProperty(key, property, value)
-
- global_stack.userChanges.setProperty.assert_called_once_with(key, property, value, None, False)
|