2019-02-22 13:45:50 +03:00
|
|
|
QA output created by 244
|
|
|
|
|
|
|
|
=== Create and open image with external data file ===
|
|
|
|
|
|
|
|
With data file name in the image:
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864 data_file=TEST_DIR/t.IMGFMT.data
|
|
|
|
No errors were found on the image.
|
|
|
|
read 65536/65536 bytes at offset 0
|
|
|
|
64 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 65536/65536 bytes at offset 0
|
|
|
|
64 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
2019-04-28 18:54:44 +03:00
|
|
|
qemu-io: can't open device TEST_DIR/t.qcow2: Could not open 'inexistent': No such file or directory
|
2019-02-22 13:45:50 +03:00
|
|
|
no file open, try 'help open'
|
|
|
|
|
|
|
|
Data file required, but without data file name in the image:
|
2019-04-28 18:54:44 +03:00
|
|
|
qemu-io: can't open device TEST_DIR/t.qcow2: 'data-file' is required for this image
|
2019-02-22 13:45:50 +03:00
|
|
|
no file open, try 'help open'
|
|
|
|
read 65536/65536 bytes at offset 0
|
|
|
|
64 KiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
2019-04-28 18:54:44 +03:00
|
|
|
qemu-io: can't open device TEST_DIR/t.qcow2: Could not open 'inexistent': No such file or directory
|
2019-02-22 13:45:50 +03:00
|
|
|
no file open, try 'help open'
|
|
|
|
|
|
|
|
Setting data-file for an image with internal data:
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864
|
2019-04-28 18:54:44 +03:00
|
|
|
qemu-io: can't open device TEST_DIR/t.qcow2: 'data-file' can only be set for images with an external data file
|
2019-02-22 13:45:50 +03:00
|
|
|
no file open, try 'help open'
|
2019-04-28 18:54:44 +03:00
|
|
|
qemu-io: can't open device TEST_DIR/t.qcow2: Could not open 'inexistent': No such file or directory
|
2019-02-22 13:45:50 +03:00
|
|
|
no file open, try 'help open'
|
|
|
|
|
|
|
|
=== Conflicting features ===
|
|
|
|
|
|
|
|
Convert to compressed target with data file:
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT.src', fmt=IMGFMT size=67108864
|
|
|
|
wrote 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
2020-04-02 16:57:17 +03:00
|
|
|
qemu-img: error while writing at byte 0: Operation not supported
|
2019-02-22 13:45:50 +03:00
|
|
|
|
|
|
|
Convert uncompressed, then write compressed data manually:
|
|
|
|
Images are identical.
|
|
|
|
write failed: Operation not supported
|
|
|
|
No errors were found on the image.
|
|
|
|
|
|
|
|
Take an internal snapshot:
|
2023-08-11 14:09:46 +03:00
|
|
|
qemu-img: Could not create snapshot 'test': Operation not supported
|
2019-02-22 13:45:50 +03:00
|
|
|
No errors were found on the image.
|
|
|
|
|
|
|
|
=== Standalone image with external data file (efficient) ===
|
|
|
|
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864 data_file=TEST_DIR/t.IMGFMT.data
|
|
|
|
qcow2 file size before I/O: 196616
|
|
|
|
|
|
|
|
wrote 4194304/4194304 bytes at offset 1048576
|
|
|
|
4 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
discard 2097152/2097152 bytes at offset 2097152
|
|
|
|
2 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
wrote 3145728/3145728 bytes at offset 3145728
|
|
|
|
3 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
No errors were found on the image.
|
|
|
|
|
2023-09-08 00:02:26 +03:00
|
|
|
[{ "start": 0, "length": 1048576, "depth": 0, "present": false, "zero": true, "data": false, "compressed": false},
|
|
|
|
{ "start": 1048576, "length": 1048576, "depth": 0, "present": true, "zero": false, "data": true, "compressed": false, "offset": 1048576},
|
|
|
|
{ "start": 2097152, "length": 2097152, "depth": 0, "present": true, "zero": true, "data": false, "compressed": false},
|
|
|
|
{ "start": 4194304, "length": 1048576, "depth": 0, "present": true, "zero": true, "data": false, "compressed": false, "offset": 4194304},
|
|
|
|
{ "start": 5242880, "length": 1048576, "depth": 0, "present": true, "zero": true, "data": false, "compressed": false},
|
|
|
|
{ "start": 6291456, "length": 60817408, "depth": 0, "present": false, "zero": true, "data": false, "compressed": false}]
|
2019-02-22 13:45:50 +03:00
|
|
|
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 4194304/4194304 bytes at offset 2097152
|
|
|
|
4 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 4194304
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 5242880
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
qcow2 file size after I/O: 327680
|
|
|
|
|
|
|
|
=== Standalone image with external data file (valid raw) ===
|
|
|
|
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864 data_file=TEST_DIR/t.IMGFMT.data data_file_raw=on
|
2021-03-26 17:55:08 +03:00
|
|
|
qcow2 file size before I/O: 327680
|
2019-02-22 13:45:50 +03:00
|
|
|
|
|
|
|
wrote 4194304/4194304 bytes at offset 1048576
|
|
|
|
4 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
discard 2097152/2097152 bytes at offset 2097152
|
|
|
|
2 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
wrote 3145728/3145728 bytes at offset 3145728
|
|
|
|
3 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
No errors were found on the image.
|
|
|
|
|
2023-09-08 00:02:26 +03:00
|
|
|
[{ "start": 0, "length": 2097152, "depth": 0, "present": true, "zero": false, "data": true, "compressed": false, "offset": 0},
|
|
|
|
{ "start": 2097152, "length": 2097152, "depth": 0, "present": true, "zero": true, "data": false, "compressed": false},
|
|
|
|
{ "start": 4194304, "length": 2097152, "depth": 0, "present": true, "zero": true, "data": false, "compressed": false, "offset": 4194304},
|
|
|
|
{ "start": 6291456, "length": 60817408, "depth": 0, "present": true, "zero": false, "data": true, "compressed": false, "offset": 6291456}]
|
2019-02-22 13:45:50 +03:00
|
|
|
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 4194304/4194304 bytes at offset 2097152
|
|
|
|
4 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
|
2020-04-09 22:10:06 +03:00
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 3145728/3145728 bytes at offset 3145728
|
|
|
|
3 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
2019-02-22 13:45:50 +03:00
|
|
|
qcow2 file size after I/O: 327680
|
|
|
|
|
|
|
|
=== bdrv_co_block_status test for file and offset=0 ===
|
|
|
|
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864 data_file=TEST_DIR/t.IMGFMT.data
|
|
|
|
wrote 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
Offset Length Mapped to File
|
|
|
|
0 0x100000 0 TEST_DIR/t.qcow2.data
|
2023-09-08 00:02:26 +03:00
|
|
|
[{ "start": 0, "length": 1048576, "depth": 0, "present": true, "zero": false, "data": true, "compressed": false, "offset": 0},
|
|
|
|
{ "start": 1048576, "length": 66060288, "depth": 0, "present": false, "zero": true, "data": false, "compressed": false}]
|
2020-02-11 12:49:00 +03:00
|
|
|
|
|
|
|
=== Copy offloading ===
|
|
|
|
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=67108864 data_file=TEST_DIR/t.IMGFMT.data
|
|
|
|
Images are identical.
|
|
|
|
Images are identical.
|
2019-11-13 19:26:07 +03:00
|
|
|
|
|
|
|
=== Flushing should flush the data file ===
|
|
|
|
|
|
|
|
wrote 512/512 bytes at offset 0
|
|
|
|
512 bytes, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
|
|
|
|
Success: qemu-io failed, so the data file was flushed
|
2021-03-26 17:55:09 +03:00
|
|
|
|
|
|
|
=== Preallocation with data-file-raw ===
|
|
|
|
|
|
|
|
--- Using a non-zeroed data file ---
|
|
|
|
wrote 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
{ "execute": "qmp_capabilities" }
|
|
|
|
{"return": {}}
|
|
|
|
{ "execute": "blockdev-create",
|
|
|
|
"arguments": {
|
|
|
|
"job-id": "create",
|
|
|
|
"options": {
|
|
|
|
"driver": "IMGFMT",
|
|
|
|
"size": 1048576,
|
|
|
|
"file": "meta",
|
|
|
|
"data-file": "data",
|
|
|
|
"data-file-raw": true
|
|
|
|
} } }
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "created", "id": "create"}}
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "running", "id": "create"}}
|
|
|
|
{"return": {}}
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "waiting", "id": "create"}}
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "pending", "id": "create"}}
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "concluded", "id": "create"}}
|
|
|
|
{ "execute": "job-dismiss", "arguments": { "id": "create" } }
|
|
|
|
{"timestamp": {"seconds": TIMESTAMP, "microseconds": TIMESTAMP}, "event": "JOB_STATUS_CHANGE", "data": {"status": "null", "id": "create"}}
|
|
|
|
{"return": {}}
|
|
|
|
|
|
|
|
Comparing pattern:
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
Images are identical.
|
|
|
|
|
|
|
|
--- Truncation (growing) ---
|
|
|
|
wrote 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
Image resized.
|
|
|
|
|
|
|
|
Comparing pattern:
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
read 1048576/1048576 bytes at offset 1048576
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
Images are identical.
|
|
|
|
|
|
|
|
--- Giving a backing file at runtime ---
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT', fmt=IMGFMT size=1048576 data_file=TEST_DIR/t.IMGFMT.data data_file_raw=on
|
|
|
|
Formatting 'TEST_DIR/t.IMGFMT.base', fmt=IMGFMT size=1048576
|
|
|
|
wrote 1048576/1048576 bytes at offset 0
|
|
|
|
1 MiB, X ops; XX:XX:XX.X (XXX YYY/sec and XXX ops/sec)
|
|
|
|
|
|
|
|
Comparing qcow2 image and raw data file:
|
|
|
|
Images are identical.
|
2019-02-22 13:45:50 +03:00
|
|
|
*** done
|