123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- # Copyright (c) 2017 Ultimaker B.V.
- # Cura is released under the terms of the LGPLv3 or higher.
- import os.path
- import sys
- sys.path.append(os.path.join(os.path.dirname(os.path.abspath(__file__)), ".."))
- import configparser #To parse the resulting config files.
- import pytest #To register tests with.
- import VersionUpgrade27to30 #The module we're testing.
- ## Creates an instance of the upgrader to test with.
- @pytest.fixture
- def upgrader():
- return VersionUpgrade27to30.VersionUpgrade27to30()
- test_cfg_version_good_data = [
- {
- "test_name": "Simple",
- "file_data": """[general]
- version = 1
- """,
- "version": 1000000
- },
- {
- "test_name": "Other Data Around",
- "file_data": """[nonsense]
- life = good
- [general]
- version = 3
- [values]
- layer_height = 0.12
- infill_sparse_density = 42
- """,
- "version": 3000000
- },
- {
- "test_name": "Negative Version", #Why not?
- "file_data": """[general]
- version = -20
- """,
- "version": -20000000
- },
- {
- "test_name": "Setting Version",
- "file_data": """[general]
- version = 1
- [metadata]
- setting_version = 1
- """,
- "version": 1000001
- },
- {
- "test_name": "Negative Setting Version",
- "file_data": """[general]
- version = 1
- [metadata]
- setting_version = -3
- """,
- "version": 999997
- }
- ]
- ## Tests the technique that gets the version number from CFG files.
- #
- # \param data The parametrised data to test with. It contains a test name
- # to debug with, the serialised contents of a CFG file and the correct
- # version number in that CFG file.
- # \param upgrader The instance of the upgrade class to test.
- @pytest.mark.parametrize("data", test_cfg_version_good_data)
- def test_cfgVersionGood(data, upgrader):
- version = upgrader.getCfgVersion(data["file_data"])
- assert version == data["version"]
- test_cfg_version_bad_data = [
- {
- "test_name": "Empty",
- "file_data": "",
- "exception": configparser.Error #Explicitly not specified further which specific error we're getting, because that depends on the implementation of configparser.
- },
- {
- "test_name": "No General",
- "file_data": """[values]
- layer_height = 0.1337
- """,
- "exception": configparser.Error
- },
- {
- "test_name": "No Version",
- "file_data": """[general]
- true = false
- """,
- "exception": configparser.Error
- },
- {
- "test_name": "Not a Number",
- "file_data": """[general]
- version = not-a-text-version-number
- """,
- "exception": ValueError
- },
- {
- "test_name": "Setting Value NaN",
- "file_data": """[general]
- version = 4
- [metadata]
- setting_version = latest_or_something
- """,
- "exception": ValueError
- },
- {
- "test_name": "Major-Minor",
- "file_data": """[general]
- version = 1.2
- """,
- "exception": ValueError
- }
- ]
- ## Tests whether getting a version number from bad CFG files gives an
- # exception.
- #
- # \param data The parametrised data to test with. It contains a test name
- # to debug with, the serialised contents of a CFG file and the class of
- # exception it needs to throw.
- # \param upgrader The instance of the upgrader to test.
- @pytest.mark.parametrize("data", test_cfg_version_bad_data)
- def test_cfgVersionBad(data, upgrader):
- with pytest.raises(data["exception"]):
- upgrader.getCfgVersion(data["file_data"])
- test_translate_theme_data = [
- (
- "Original Cura theme",
- """[general]
- version = 4
- theme = cura
- [metadata]
- setting_version = 2
- """,
- "cura-light"
- ),
- (
- "No theme",
- """[general]
- version = 4
- [metadata]
- setting_version = 2
- """,
- None #Indicates that the theme should be absent in the new file.
- )
- ]
- ## Tests whether the theme is properly translated.
- @pytest.mark.parametrize("test_name, file_data, new_theme", test_translate_theme_data)
- def test_translateTheme(test_name, file_data, new_theme, upgrader):
- #Read old file.
- original_parser = configparser.ConfigParser(interpolation = None)
- original_parser.read_string(file_data)
- #Perform the upgrade.
- _, upgraded_stacks = upgrader.upgradePreferences(file_data, "<string>")
- upgraded_stack = upgraded_stacks[0]
- parser = configparser.ConfigParser(interpolation = None)
- parser.read_string(upgraded_stack)
- #Check whether the theme was properly translated.
- if not new_theme:
- assert "theme" not in parser["general"]
- else:
- assert "theme" in parser["general"]
- assert parser["general"]["theme"] == new_theme
|