]>
Commit | Line | Data |
---|---|---|
908eaf68 | 1 | #!/bin/bash |
6bf19c94 CH |
2 | # |
3 | # Copyright (C) 2009 Red Hat, Inc. | |
4 | # Copyright (c) 2000-2001 Silicon Graphics, Inc. All Rights Reserved. | |
5 | # | |
6 | # This program is free software; you can redistribute it and/or | |
7 | # modify it under the terms of the GNU General Public License as | |
8 | # published by the Free Software Foundation. | |
9 | # | |
10 | # This program is distributed in the hope that it would be useful, | |
11 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
13 | # GNU General Public License for more details. | |
14 | # | |
15 | # You should have received a copy of the GNU General Public License | |
e8c212d6 | 16 | # along with this program. If not, see <http://www.gnu.org/licenses/>. |
6bf19c94 CH |
17 | # |
18 | # | |
19 | # standard filters | |
20 | # | |
21 | ||
6bf19c94 CH |
22 | # ctime(3) dates |
23 | # | |
24 | _filter_date() | |
25 | { | |
26 | sed \ | |
79e40ab1 | 27 | -e 's/[A-Z][a-z][a-z] [A-z][a-z][a-z] *[0-9][0-9]* [0-9][0-9]:[0-9][0-9]:[0-9][0-9] [0-9][0-9][0-9][0-9]$/DATE/' |
6bf19c94 CH |
28 | } |
29 | ||
15489c76 JC |
30 | _filter_generated_node_ids() |
31 | { | |
32 | sed -re 's/\#block[0-9]{3,}/NODE_NAME/' | |
33 | } | |
34 | ||
627f607e AG |
35 | _filter_qom_path() |
36 | { | |
37 | sed -e 's#\(Attached to: *\) /.*#\1 PATH#' | |
38 | } | |
39 | ||
62284d17 | 40 | # replace occurrences of the actual TEST_DIR value with TEST_DIR |
6bf19c94 CH |
41 | _filter_testdir() |
42 | { | |
b135233b | 43 | sed -e "s#$TEST_DIR/#TEST_DIR/#g" |
6bf19c94 CH |
44 | } |
45 | ||
62284d17 SH |
46 | # replace occurrences of the actual IMGFMT value with IMGFMT |
47 | _filter_imgfmt() | |
48 | { | |
49 | sed -e "s#$IMGFMT#IMGFMT#g" | |
50 | } | |
51 | ||
86ce1f6e RS |
52 | # Replace error message when the format is not supported and delete |
53 | # the output lines after the first one | |
54 | _filter_qemu_img_check() | |
55 | { | |
56 | sed -e '/allocated.*fragmented.*compressed clusters/d' \ | |
57 | -e 's/qemu-img: This image format does not support checks/No errors were found on the image./' \ | |
58 | -e '/Image end offset: [0-9]\+/d' | |
59 | } | |
60 | ||
a06d5cc2 KW |
61 | # Removes \r from messages |
62 | _filter_win32() | |
63 | { | |
64 | sed -e 's/\r//g' | |
65 | } | |
66 | ||
6bf19c94 CH |
67 | # sanitize qemu-io output |
68 | _filter_qemu_io() | |
69 | { | |
c34b8012 | 70 | _filter_win32 | sed -e "s/[0-9]* ops\; [0-9/:. sec]* ([0-9/.inf]* [EPTGMKiBbytes]*\/sec and [0-9/.inf]* ops\/sec)/X ops\; XX:XX:XX.X (XXX YYY\/sec and XXX ops\/sec)/" \ |
9e0c3e8d | 71 | -e "s/: line [0-9][0-9]*: *[0-9][0-9]*\( Aborted\| Killed\)/:\1/" \ |
c34b8012 | 72 | -e "s/qemu-io> //g" |
6bf19c94 CH |
73 | } |
74 | ||
c09b437b SH |
75 | # replace occurrences of QEMU_PROG with "qemu" |
76 | _filter_qemu() | |
77 | { | |
9580498b | 78 | sed -e "s#\\(^\\|(qemu) \\)$(basename $QEMU_PROG):#\1QEMU_PROG:#" \ |
ac9524dc | 79 | -e 's#^QEMU [0-9]\+\.[0-9]\+\.[0-9]\+ monitor#QEMU X.Y.Z monitor#' \ |
4dd7b8d3 | 80 | -e '/main-loop: WARNING: I\/O thread spun for [0-9]\+ iterations/d' \ |
ac9524dc | 81 | -e $'s#\r##' # QEMU monitor uses \r\n line endings |
c09b437b SH |
82 | } |
83 | ||
a9b43397 KW |
84 | # replace problematic QMP output like timestamps |
85 | _filter_qmp() | |
86 | { | |
87 | _filter_win32 | \ | |
88 | sed -e 's#\("\(micro\)\?seconds": \)[0-9]\+#\1 TIMESTAMP#g' \ | |
cc20b07a HR |
89 | -e 's#^{"QMP":.*}$#QMP_VERSION#' \ |
90 | -e '/^ "QMP": {\s*$/, /^ }\s*$/ c\' \ | |
91 | -e ' QMP_VERSION' | |
a9b43397 KW |
92 | } |
93 | ||
69404d9e KW |
94 | # readline makes HMP command strings so long that git complains |
95 | _filter_hmp() | |
96 | { | |
97 | sed -e $'s/^\\((qemu) \\)\\?.*\e\\[D/\\1/g' \ | |
98 | -e $'s/\e\\[K//g' | |
99 | } | |
100 | ||
a752e478 VSO |
101 | # replace block job offset |
102 | _filter_block_job_offset() | |
103 | { | |
104 | sed -e 's/, "offset": [0-9]\+,/, "offset": OFFSET,/' | |
105 | } | |
106 | ||
24dfdfd0 FZ |
107 | # replace block job len |
108 | _filter_block_job_len() | |
109 | { | |
110 | sed -e 's/, "len": [0-9]\+,/, "len": LEN,/g' | |
111 | } | |
112 | ||
44673a0b HR |
113 | # replace actual image size (depends on the host filesystem) |
114 | _filter_actual_image_size() | |
115 | { | |
116 | sed -s 's/\("actual-size":\s*\)[0-9]\+/\1SIZE/g' | |
117 | } | |
118 | ||
6ffb4cb6 KW |
119 | # replace driver-specific options in the "Formatting..." line |
120 | _filter_img_create() | |
121 | { | |
122 | sed -e "s#$IMGPROTO:$TEST_DIR#TEST_DIR#g" \ | |
123 | -e "s#$TEST_DIR#TEST_DIR#g" \ | |
124 | -e "s#$IMGFMT#IMGFMT#g" \ | |
46174339 | 125 | -e 's#nbd:127.0.0.1:10810#TEST_DIR/t.IMGFMT#g' \ |
6ffb4cb6 KW |
126 | -e "s# encryption=off##g" \ |
127 | -e "s# cluster_size=[0-9]\\+##g" \ | |
128 | -e "s# table_size=[0-9]\\+##g" \ | |
fe646693 | 129 | -e "s# compat=[^ ]*##g" \ |
6ffb4cb6 KW |
130 | -e "s# compat6=\\(on\\|off\\)##g" \ |
131 | -e "s# static=\\(on\\|off\\)##g" \ | |
132 | -e "s# zeroed_grain=\\(on\\|off\\)##g" \ | |
133 | -e "s# subformat='[^']*'##g" \ | |
134 | -e "s# adapter_type='[^']*'##g" \ | |
f249924e | 135 | -e "s# hwversion=[^ ]*##g" \ |
6ffb4cb6 KW |
136 | -e "s# lazy_refcounts=\\(on\\|off\\)##g" \ |
137 | -e "s# block_size=[0-9]\\+##g" \ | |
138 | -e "s# block_state_zero=\\(on\\|off\\)##g" \ | |
139 | -e "s# log_size=[0-9]\\+##g" \ | |
b7e875b2 | 140 | -e "s# refcount_bits=[0-9]\\+##g" \ |
307d9991 | 141 | -e "s# key-secret=[a-zA-Z0-9]\\+##g" \ |
bff55548 JS |
142 | -e "s# iter-time=[0-9]\\+##g" \ |
143 | -e "s# force_size=\\(on\\|off\\)##g" | |
6ffb4cb6 KW |
144 | } |
145 | ||
c2eb918e HT |
146 | _filter_img_info() |
147 | { | |
1cc6169b HR |
148 | if [[ "$1" == "--format-specific" ]]; then |
149 | local format_specific=1 | |
150 | shift | |
151 | else | |
152 | local format_specific=0 | |
153 | fi | |
154 | ||
155 | discard=0 | |
156 | regex_json_spec_start='^ *"format-specific": \{' | |
c2eb918e HT |
157 | sed -e "s#$IMGPROTO:$TEST_DIR#TEST_DIR#g" \ |
158 | -e "s#$TEST_DIR#TEST_DIR#g" \ | |
159 | -e "s#$IMGFMT#IMGFMT#g" \ | |
a231cb27 | 160 | -e 's#nbd://127.0.0.1:10810$#TEST_DIR/t.IMGFMT#g' \ |
ae0c0a3d | 161 | -e 's#json.*vdisk-id.*vxhs"}}#TEST_DIR/t.IMGFMT#' \ |
c2eb918e HT |
162 | -e "/encrypted: yes/d" \ |
163 | -e "/cluster_size: [0-9]\\+/d" \ | |
164 | -e "/table_size: [0-9]\\+/d" \ | |
165 | -e "/compat: '[^']*'/d" \ | |
166 | -e "/compat6: \\(on\\|off\\)/d" \ | |
167 | -e "/static: \\(on\\|off\\)/d" \ | |
168 | -e "/zeroed_grain: \\(on\\|off\\)/d" \ | |
169 | -e "/subformat: '[^']*'/d" \ | |
170 | -e "/adapter_type: '[^']*'/d" \ | |
f249924e | 171 | -e "/hwversion: '[^']*'/d" \ |
c2eb918e HT |
172 | -e "/lazy_refcounts: \\(on\\|off\\)/d" \ |
173 | -e "/block_size: [0-9]\\+/d" \ | |
174 | -e "/block_state_zero: \\(on\\|off\\)/d" \ | |
f0603329 DB |
175 | -e "/log_size: [0-9]\\+/d" \ |
176 | -e "s/iters: [0-9]\\+/iters: 1024/" \ | |
1cc6169b HR |
177 | -e "s/uuid: [-a-f0-9]\\+/uuid: 00000000-0000-0000-0000-000000000000/" | \ |
178 | while IFS='' read -r line; do | |
179 | if [[ $format_specific == 1 ]]; then | |
180 | discard=0 | |
181 | elif [[ $line == "Format specific information:" ]]; then | |
182 | discard=1 | |
183 | elif [[ $line =~ $regex_json_spec_start ]]; then | |
184 | discard=2 | |
185 | regex_json_spec_end="^${line%%[^ ]*}\\},? *$" | |
186 | fi | |
187 | if [[ $discard == 0 ]]; then | |
188 | echo "$line" | |
189 | elif [[ $discard == 1 && ! $line ]]; then | |
190 | echo | |
191 | discard=0 | |
192 | elif [[ $discard == 2 && $line =~ $regex_json_spec_end ]]; then | |
193 | discard=0 | |
194 | fi | |
195 | done | |
c2eb918e HT |
196 | } |
197 | ||
d9ca2214 EB |
198 | # filter out offsets and file names from qemu-img map; good for both |
199 | # human and json output | |
f67ac71e HR |
200 | _filter_qemu_img_map() |
201 | { | |
202 | sed -e 's/\([0-9a-fx]* *[0-9a-fx]* *\)[0-9a-fx]* */\1/g' \ | |
d9ca2214 | 203 | -e 's/"offset": [0-9]\+/"offset": OFFSET/g' \ |
f67ac71e HR |
204 | -e 's/Mapped to *//' | _filter_testdir | _filter_imgfmt |
205 | } | |
206 | ||
60d44688 HR |
207 | _filter_nbd() |
208 | { | |
209 | # nbd.c error messages contain function names and line numbers that are | |
210 | # prone to change. Message ordering depends on timing between send and | |
211 | # receive callbacks sometimes, making them unreliable. | |
212 | # | |
213 | # Filter out the TCP port number since this changes between runs. | |
dd170c06 | 214 | sed -e '/nbd\/.*\.c:/d' \ |
02d2d860 | 215 | -e 's#127\.0\.0\.1:[0-9]*#127.0.0.1:PORT#g' \ |
4a940d14 | 216 | -e "s#?socket=$TEST_DIR#?socket=TEST_DIR#g" \ |
02d2d860 | 217 | -e 's#\(foo\|PORT/\?\|.sock\): Failed to .*$#\1#' |
60d44688 HR |
218 | } |
219 | ||
6bf19c94 | 220 | # make sure this script returns success |
a2d9c0c4 | 221 | true |