diff options
author | Silvio Rhatto <rhatto@riseup.net> | 2013-12-25 09:59:19 -0200 |
---|---|---|
committer | Silvio Rhatto <rhatto@riseup.net> | 2013-12-25 09:59:19 -0200 |
commit | e487acb65d59b3062cd11a1e738d0174ffa98fbd (patch) | |
tree | 29c0829ee13d9bf0f5f65fa038ebb682a8d912bb /share | |
parent | 37c02fa955615afe2dfc932402c939274879bcd8 (diff) | |
download | hydra-e487acb65d59b3062cd11a1e738d0174ffa98fbd.tar.gz hydra-e487acb65d59b3062cd11a1e738d0174ffa98fbd.tar.bz2 |
Always initialize environment on system-upgrade
Diffstat (limited to 'share')
-rwxr-xr-x | share/hydractl/system-upgrade | 32 |
1 files changed, 27 insertions, 5 deletions
diff --git a/share/hydractl/system-upgrade b/share/hydractl/system-upgrade index fdfaceb..4f3e4ec 100755 --- a/share/hydractl/system-upgrade +++ b/share/hydractl/system-upgrade @@ -23,6 +23,7 @@ hydra_config_load # Parameters TMP="/tmp" STATE="$TMP/system-upgrade" +ENV="$TMP/system-upgrade-env" # Command line arguments BASENAME="`basename $0`" @@ -34,10 +35,10 @@ function hydra_system_upgrade_stage { echo $STAGE > $STATE } -# Prepare the environment for a system upgrade -function hydra_system_upgrade_prepare { +# Set and check upgrade environment +function hydra_system_upgrade_env { # Set initial state - hydra_system_upgrade_stage prepare + hydra_system_upgrade_stage env # Available releases #release="`facter lsbdistcodename`" # this doesn't work on squeeze @@ -47,6 +48,12 @@ function hydra_system_upgrade_prepare { # Is a virtual machine? virtual="`facter 2> /dev/null | grep virtual | sed -e 's/virtual => //'`" + # Save environment + echo "release=$release" > $ENV + echo "nextrelease=$nextrelease" >> $ENV + echo "nextrelease=$nextrelease" >> $ENV + echo "virtual=$virtual" >> $ENV + # Check release if [ "$?" != "0" ]; then echo "Unsupported release" @@ -66,6 +73,12 @@ function hydra_system_upgrade_prepare { fi fi + # Set next state + hydra_system_upgrade_stage prepare +} + +# Prepare the environment for a system upgrade +function hydra_system_upgrade_prepare { # Ensure puppet is stopped during the process echo "Disabling puppet during the upgrade..." hydractl puppet-disable @@ -87,6 +100,7 @@ function hydra_system_upgrade_prepare { apt-get remove colord -y fi + # Set next state hydra_system_upgrade_stage download } @@ -101,12 +115,19 @@ function hydra_system_upgrade_download { hydra_system_upgrade_stage upgrade } -# Prepare for the upgrade +# Initialize if [ ! -e "$STATE" ]; then - hydra_system_upgrade_prepare $* + hydra_system_upgrade_env else # Resume from the previous state STAGE="`cat $STATE`" + source $ENV + hydra_system_upgrade_$STATE +fi + +# Prepare +if [ "$STAGE" == "env" ]; then + hydra_system_upgrade_prepare fi # Download packages @@ -160,3 +181,4 @@ fi # Teardown rm -f $STATE +rm -f $ENV |