bfd39aecf3
First, split it into its own section; it's important enough to merit it. Second, explicitly reference the systemd timer/service units. For example, a question I often have is "when is the next run" and of course you can get that rpm `systemctl status rpm-ostreed-automatic.timer` but you have to know that, and the reminder helps. (I briefly looked at implementing the `Trigger` line from `systemctl status` but it's not entirely trivial...tempting to just fork off a `systemctl status | grep `) Prep for unifying this text with the message we print when one does `rpm-ostree upgrade` when auto-updates are enabled. Closes: #1432 Approved by: jlebon
59 lines
2.1 KiB
Bash
Executable File
59 lines
2.1 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Copyright (C) 2018 Jonathan Lebon
|
|
# Copyright (C) 2018 Red Hat, Inc.
|
|
#
|
|
# This library is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
# License as published by the Free Software Foundation; either
|
|
# version 2 of the License, or (at your option) any later version.
|
|
#
|
|
# This library is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
# Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this library; if not, write to the
|
|
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
# Boston, MA 02111-1307, USA.
|
|
|
|
set -euo pipefail
|
|
|
|
. ${commondir}/libtest.sh
|
|
. ${commondir}/libvm.sh
|
|
|
|
set -x
|
|
|
|
# Prepare an OSTree repo with updates
|
|
vm_ostreeupdate_prepare_reboot
|
|
|
|
vm_ostreeupdate_create v2
|
|
|
|
vm_rpmostree cleanup -m
|
|
|
|
vm_rpmostree status > status.txt
|
|
assert_file_has_content status.txt 'AutomaticUpdates: disabled'
|
|
vm_change_update_policy ex-stage
|
|
vm_rpmostree status > status.txt
|
|
assert_file_has_content_literal status.txt 'AutomaticUpdates: ex-stage; rpm-ostreed-automatic.timer: inactive'
|
|
|
|
vm_rpmostree upgrade --trigger-automatic-update-policy
|
|
vm_assert_status_jq ".deployments[1][\"booted\"]" \
|
|
".deployments[0][\"staged\"]" \
|
|
".deployments[0][\"version\"] == \"v2\""
|
|
vm_rpmostree status -v > status.txt
|
|
assert_file_has_content status.txt "Staged: yes"
|
|
vm_rpmostree upgrade > upgrade.txt
|
|
assert_file_has_content_literal upgrade.txt 'note: automatic updates (ex-stage) are enabled'
|
|
# And ensure that we have new content in /etc after staging
|
|
vm_cmd echo new-content-in-etc \> /etc/somenewfile
|
|
vm_reboot
|
|
vm_assert_status_jq ".deployments[0][\"booted\"]" \
|
|
".deployments[0][\"staged\"]|not" \
|
|
".deployments[1][\"staged\"]|not" \
|
|
".deployments[0][\"version\"] == \"v2\""
|
|
vm_cmd cat /etc/somenewfile > somenewfile.txt
|
|
assert_file_has_content somenewfile.txt new-content-in-etc
|
|
echo "ok autoupdate staged"
|