 52df1a5b61
			
		
	
	
		52df1a5b61
		
	
	
	
	
		
			
			When running the command `qemu-img snapshot -l SNAPSHOT` the output of VM_CLOCK (measures the offset between host and VM clock) cannot to accommodate values in the order of thousands (4-digit). This line [1] hints on the problem. Additionally, the column width for the VM_CLOCK field was reduced from 15 to 13 spaces in commit b39847a5 in line [2], resulting in a shortage of space. [1]: https://gitlab.com/qemu-project/qemu/-/blob/master/block/qapi.c?ref_type=heads#L753 [2]: https://gitlab.com/qemu-project/qemu/-/blob/master/block/qapi.c?ref_type=heads#L763 This patch restores the column width to 15 spaces and makes adjustments to the affected iotests accordingly. Furthermore, addresses a potential source of confusion by removing whitespace in column headers. Example, VM CLOCK is modified to VM_CLOCK. Additionally a '--' symbol is introduced when ICOUNT returns no output for clarity. Resolves: https://gitlab.com/qemu-project/qemu/-/issues/2062 Fixes: b39847a50553 ("migration: introduce icount field for snapshots") Signed-off-by: Abhiram Tilak <atp.exp@gmail.com> Message-ID: <20240123050354.22152-2-atp.exp@gmail.com> [kwolf: Fixed up qemu-iotests 261 and 286] Reviewed-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
		
			
				
	
	
		
			79 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| # group: rw quick
 | |
| #
 | |
| # Test qemu-img snapshot -l
 | |
| #
 | |
| # Copyright (C) 2019 Red Hat, Inc.
 | |
| #
 | |
| # This program 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 program 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.
 | |
| #
 | |
| # You should have received a copy of the GNU General Public License
 | |
| # along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
| #
 | |
| 
 | |
| seq=$(basename "$0")
 | |
| echo "QA output created by $seq"
 | |
| 
 | |
| status=1	# failure is the default!
 | |
| 
 | |
| _cleanup()
 | |
| {
 | |
|     _cleanup_test_img
 | |
| }
 | |
| trap "_cleanup; exit \$status" 0 1 2 3 15
 | |
| 
 | |
| # get standard environment, filters and checks
 | |
| . ./common.rc
 | |
| . ./common.filter
 | |
| . ./common.qemu
 | |
| 
 | |
| _supported_fmt qcow2
 | |
| _supported_proto file fuse
 | |
| # Internal snapshots are (currently) impossible with refcount_bits=1,
 | |
| # and generally impossible with external data files
 | |
| _unsupported_imgopts 'refcount_bits=1[^0-9]' data_file
 | |
| 
 | |
| _make_test_img 64M
 | |
| 
 | |
| # Should be so long as to take up the whole field width
 | |
| sn_name=abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz
 | |
| 
 | |
| # More memory will give us a larger VM state, i.e. one above 1 MB.
 | |
| # This way, we get a number with a decimal point.
 | |
| qemu_comm_method=monitor _launch_qemu -m 512 "$TEST_IMG"
 | |
| 
 | |
| _send_qemu_cmd $QEMU_HANDLE "savevm $sn_name" '(qemu)'
 | |
| _send_qemu_cmd $QEMU_HANDLE 'quit' '(qemu)'
 | |
| wait=yes _cleanup_qemu
 | |
| 
 | |
| # Check that all fields are separated by spaces.
 | |
| # We first collapse all space sequences into one space each;
 | |
| # then we turn every space-separated field into a '.';
 | |
| # and finally, we name the '.'s so the output is not just a confusing
 | |
| # sequence of dots.
 | |
| 
 | |
| echo 'Output structure:'
 | |
| $QEMU_IMG snapshot -l "$TEST_IMG" | tail -n 1 | tr -s ' ' \
 | |
|     | sed -e 's/\S\+/./g' \
 | |
|     | sed -e 's/\./(snapshot ID)/' \
 | |
|           -e 's/\./(snapshot name)/' \
 | |
|           -e 's/\./(VM state size value)/' \
 | |
|           -e 's/\./(VM state size unit)/' \
 | |
|           -e 's/\./(snapshot date)/' \
 | |
|           -e 's/\./(snapshot time)/' \
 | |
|           -e 's/\./(VM clock)/' \
 | |
|           -e 's/\./(icount)/'
 | |
| 
 | |
| # success, all done
 | |
| echo "*** done"
 | |
| rm -f $seq.full
 | |
| status=0
 |