Forked from
tests / apertis-test-cases
512 commits behind the upstream repository.
-
Denis Pynkin authored
Use CGroups blkio to limit the read speed to 1MBps allowing to remove the USB flash in predictable state even on extremely fast devices. Signed-off-by:
Denis Pynkin <denis.pynkin@collabora.com>
Denis Pynkin authoredUse CGroups blkio to limit the read speed to 1MBps allowing to remove the USB flash in predictable state even on extremely fast devices. Signed-off-by:
Denis Pynkin <denis.pynkin@collabora.com>
apertis-update-manager-usb-unplug.yaml 4.76 KiB
metadata:
name: apertis-update-manager-usb-unplug
format: "Apertis Test Definition 1.0"
image-types:
minimal: [ armhf ]
image-deployment:
- OSTree
type: functional
exec-type: manual
priority: medium
maintainer: "Apertis Project"
description: "Test the apertis-update-manager automatic update interrupted by mass storage removing."
resources:
- "A static update bundle file of the same architecture, variant and version as the testing image"
- "A Fat32 USB flash drive, preloaded with the update bundle at the root of the disk"
- "Downloaded update file (with '.delta' extension) should be copied to flash drive using the name 'static-update.bundle'"
- "The DUT u-boot environment must be clean: in u-boot, run: `env default -a` followed by `saveenv`"
- "A PC must be connected to DUT serial port"
expected:
- "The update wasn't applied"
- "System boots using the initial deployment"
run:
steps:
- "Check the initial deployment"
- $ sudo ostree admin status
- "Prepare the copy of commit and deploy to allow the upgrade to the same version"
- "Command below shows you an initial commit ID, for instance"
- |
$ export BOOTID=$(sudo ostree admin status | sed -n -e 's/^\* apertis \([0-9a-f]*\)\.[0-9]$/\1/p'); echo $BOOTID
- "Get the Collection ID and ref"
- $ export CID=$(sudo ostree refs -c | head -n 1 | tr -d '(),' | cut -f 1 -d ' '); echo COLLECTION_ID=$CID
- $ export REF=$(sudo ostree refs -c | head -n 1 | tr -d '(),' | cut -f 2 -d ' '); echo REF=$REF
- "Create the commit with changed timestamp to allow upgrade with recent update file"
- |
$ export NEWID=$(sudo ostree commit --orphan --tree=ref=$BOOTID --add-metadata-string=ostree.collection-binding=$CID --bind-ref=$REF --timestamp="1 year ago"); echo "New commit: $NEWID"
- "Deploy the prepared commit"
- $ sudo ostree admin upgrade --allow-downgrade --deploy-only --override-commit=$NEWID --reboot
- "Wait until the system is booted again and check the deployment"
- $ sudo ostree admin status
- "The booted commit (started with '*') must have ID which we prepare and the initial commit ID should be marked as '(rollback)'"
- "Remove the initial deployment"
- $ sudo ostree admin undeploy 1
- "Add udev rule for limiting the maximal read speed from USB drive to 1MBps."
- $ sudo tee /etc/udev/rules.d/99-usblimit.rules <<"EOF"
- |
>KERNEL=="sd*", SUBSYSTEMS=="usb", ACTION=="add", ENV{DEVTYPE}=="disk", ENV{MAJOR}=="8", RUN+="/bin/sh -c 'echo $env{MAJOR}:$env{MINOR} 1048576 > /sys/fs/cgroup/blkio/blkio.throttle.read_bps_device'"
EOF
- "Reboot the system"
- "Check the current deployment"
- $ sudo ostree admin status
- "Need to monitor the journal log to catch events in time"
- $ sudo journalctl -ef --unit apertis-update-manager &
- "Plug the USB flash drive into the device"
- "The update starts automatically"
- "Wait while the upgrade starts (5-20 seconds depending on your HW) and remove the USB flash drive before it is completed:"
- |
>Dec 19 22:31:46 apertis apertis-update-[390]: mount added : /media/test
Dec 19 22:31:46 apertis apertis-update-[390]: Ostree static delta starting
Dec 19 22:31:46 apertis apertis-update-[390]: Cannot check the ID in black list: No such file or directory
- "Update should be interrupted with error messages similar to"
- |
>[ 59.542717] scsi 1:0:0:0: rejecting I/O to offline device
[ 59.548183] scsi 1:0:0:0: rejecting I/O to offline device
[ 59.553633] scsi 1:0:0:0: rejecting I/O to dead device
[ 59.558840] scsi 1:0:0:0: rejecting I/O to dead device
[ 59.564239] print_req_error: I/O error, dev sda, sector 24393
[ 59.570120] print_req_error: I/O error, dev sda, sector 24633