diff options
author | Karel Zak | 2017-11-14 15:40:09 +0100 |
---|---|---|
committer | Karel Zak | 2017-11-14 15:40:09 +0100 |
commit | 7ee921edbeaf04845c87b0d9c280f32e98118e85 (patch) | |
tree | f1226d2f68ea371f95326dc0e8c009e708341d64 | |
parent | libfdisk: (gpt) move backup header after device resize (diff) | |
download | kernel-qcow2-util-linux-7ee921edbeaf04845c87b0d9c280f32e98118e85.tar.gz kernel-qcow2-util-linux-7ee921edbeaf04845c87b0d9c280f32e98118e85.tar.xz kernel-qcow2-util-linux-7ee921edbeaf04845c87b0d9c280f32e98118e85.zip |
tests: GPT device resize test
Signed-off-by: Karel Zak <kzak@redhat.com>
-rw-r--r-- | tests/expected/fdisk/gpt-resize | 54 | ||||
-rwxr-xr-x | tests/ts/fdisk/gpt-resize | 63 |
2 files changed, 117 insertions, 0 deletions
diff --git a/tests/expected/fdisk/gpt-resize b/tests/expected/fdisk/gpt-resize new file mode 100644 index 000000000..239213c2a --- /dev/null +++ b/tests/expected/fdisk/gpt-resize @@ -0,0 +1,54 @@ +Disk <removed>: 10 MiB, 10485760 bytes, 20480 sectors +Units: sectors of 1 * 512 = 512 bytes +Sector size (logical/physical): 512 bytes / 512 bytes +I/O size (minimum/optimal): 512 bytes / <removed> bytes + +>>> Created a new <removed>. +<removed>p1: Created a new <removed>. +<removed>p2: Done. + +New situation: +Disklabel type: gpt +Disk identifier: <removed> + +Device Start End Sectors Size Type +<removed>p1 2048 20446 18399 9M Linux filesystem + +The partition table has been altered. + + +----- fixing after resize: ----- + + + +Welcome to fdisk <removed>. +Changes will remain in memory only, until you decide to write them. +Be careful before using the write command. + +GPT PMBR size mismatch (20479 != 40959) will be corrected by write. +The backup GPT table is not on the end of the device. This problem will be corrected by write. + +Command (m for help): Partition number (2-128, default 2): First sector (20447-40926, default 20480): Last sector, +sectors or +size{K,M,G,T,P} (20480-40926, default 40926): +Created a new <removed>. + +Command (m for help): The partition table has been altered. +Calling ioctl() to re-read partition table. +Re-reading the partition table failed.: Invalid argument + +The kernel still uses the old table. The new table will be used at the next reboot or after you run partprobe(8) or kpartx(8). + + + +----- list result: ----- + + +Disk <removed>: 20 MiB, 20971520 bytes, 40960 sectors +Units: sectors of 1 * 512 = 512 bytes +Sector size (logical/physical): 512 bytes / 512 bytes +I/O size (minimum/optimal): 512 bytes / <removed> bytes +Disklabel type: gpt +Disk identifier: <removed> + +Device Start End Sectors Size Type +<removed>p1 2048 20446 18399 9M Linux filesystem +<removed>p2 20480 40926 20447 10M Linux filesystem diff --git a/tests/ts/fdisk/gpt-resize b/tests/ts/fdisk/gpt-resize new file mode 100755 index 000000000..b8319817d --- /dev/null +++ b/tests/ts/fdisk/gpt-resize @@ -0,0 +1,63 @@ +#!/bin/bash + +# +# This file is part of util-linux. +# +# This file is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This file 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 General Public License for more details. +# + +# +# Test GPT Alternative-LBA and backup header update after device resize. +# + +TS_TOPDIR="${0%/*}/../.." +TS_DESC="gpt-resize" + +. $TS_TOPDIR/functions.sh +ts_init "$*" + +ts_skip_nonroot + +ts_check_test_command "$TS_CMD_FDISK" +ts_check_test_command "$TS_CMD_SFDISK" +ts_check_prog "dd" + +ts_check_losetup + +ts_device_init 10 +DEVICE=$TS_LODEV + +# create GPT with one partition +echo ",," | $TS_CMD_SFDISK --no-reread --no-tell-kernel --label gpt $DEVICE >> $TS_OUTPUT 2>&1 +udevadm settle + +# enlarge the image +IMAGE=$($TS_CMD_LOSETUP --output BACK-FILE --noheadings $DEVICE) +dd if=/dev/zero of=${IMAGE} bs=1MiB count=10 conv=notrunc oflag=append &> /dev/null +udevadm settle + +# update device size +$TS_CMD_LOSETUP --set-capacity $DEVICE +udevadm settle + +echo -e "\n\n----- fixing after resize: -----\n\n" >> $TS_OUTPUT + +# create another GPT partition on new free space (all default) +echo -e 'n\n\n\n\nw\n' | $TS_CMD_FDISK $DEVICE >> $TS_OUTPUT 2>&1 +udevadm settle + + +echo -e "\n\n----- list result: -----\n\n" >> $TS_OUTPUT + +$TS_CMD_FDISK --list $DEVICE 2>&1 >> $TS_OUTPUT + +ts_fdisk_clean $DEVICE +ts_finalize |