Skip to content
Conor Finn edited this page Sep 7, 2022 · 12 revisions

Wiki > Project tools > Config Upgrader

The config upgrader will upgrade a config to include all the latest changes. This will be run as part of the deployment steps.

The script looks for a version number in the configuration directory and take the config from there to the latest config using upgrade steps. To run it in an EPICS terminal use:

cd ...\EPICS
python misc\upgrade\master\upgrade.py

Log files are written to ...\Var\logs\upgrade. You will then need to use git to commit any changes.

Adding an upgrade Step

To add an upgrade step create an upgrade class in ...EPICS\misc\upgrade\master\src. This class should derive from class UpgradeStep and have a single function def perform(self, file_access, logger): so it should be of the form:

class UpgradeStepFromXpxpx(UpgradeStep):
    """
    What it does
    """

    def perform(self, file_access, logger):
        """
        Perform the upgrade step

        Args:
            file_access (FileAccess): file access
            logger (LocalLogger): logger

        Returns: exit code 0 success; anything else fail

        """
        logger.info("Starting step ...")
        return -1

Next the step needs to be added to the upgrade list. This is found in ...EPICS\misc\upgrade\master\upgrade.py and look like:

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepFrom3p2p1p1()),
    ("3.2.1.2", UpgradeStepNoOp()),
    ("3.3.0", None)
]

Add the entry in replacing the None with your class, then add a new version label and None. The version label should be of the form "X.X.x.m" where X.X.x is from the last production build and m is the next number. The ("3.2.1.2", UpgradeStepNoOp) line is a way of getting from a development configuration to a production build without doing anything. E.g.

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepFrom3p2p1p1()),
    ("3.2.1.2", UpgradeStepNoOp()),
    ("3.3.0", MyNewUpgradeStep()),
    ("3.3.0.1", None)
]

You are now ready to code the perform function to do the upgrade, please use tests. The file system is isolated from the code using file_access and logging should use logger.

Note: When the upgrade script is run the configurations will end up on the final version in the list, i.e. the one with a None. So the last entry in the list will be the configuration you are wishing to finally arrive at (and not e.g. a future version placeholder)

Do not drop the previous last entry even if adding a new step that does nothing. Though this version may not have been deployed to any instruments, the config version will exist on a system test build server and probably some developer's machines too

A collection of common upgrade steps can be found here.

Creating a Production upgrade script

To create a production config simply edit the UPGRADE_STEPS list in upgrade.py. Replace the None with UpgradeStepNoOp() and add a new tuple ("X.X.x", None) to the list, don't forget the comma. E.g. from:

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepFrom3p2p1p1()),
    ("3.2.1.2", None)
]

to

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepFrom3p2p1p1()),
    ("3.2.1.2", UpgradeStepNoOp()),
    ("3.3.0", None)
]

or

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepNoOp()),
    ("3.3.0", None)
]

to

UPGRADE_STEPS = [
    ("3.2.1", UpgradeStepFrom3p2p1()),
    ("3.2.1.1", UpgradeStepNoOp()),
    ("3.3.0", UpgradeStepNoOp()),
    ("3.4.0", None)
]
Clone this wiki locally