1 /* 2 * QTest 3 * 4 * Copyright IBM, Corp. 2012 5 * Copyright Red Hat, Inc. 2012 6 * Copyright SUSE LINUX Products GmbH 2013 7 * 8 * Authors: 9 * Anthony Liguori <aliguori@us.ibm.com> 10 * Paolo Bonzini <pbonzini@redhat.com> 11 * Andreas Färber <afaerber@suse.de> 12 * 13 * This work is licensed under the terms of the GNU GPL, version 2 or later. 14 * See the COPYING file in the top-level directory. 15 * 16 */ 17 #ifndef LIBQTEST_H 18 #define LIBQTEST_H 19 20 #include "qapi/qmp/qobject.h" 21 #include "qapi/qmp/qdict.h" 22 23 typedef struct QTestState QTestState; 24 25 /** 26 * qtest_initf: 27 * @fmt: Format for creating other arguments to pass to QEMU, formatted 28 * like sprintf(). 29 * 30 * Convenience wrapper around qtest_init(). 31 * 32 * Returns: #QTestState instance. 33 */ 34 QTestState *qtest_initf(const char *fmt, ...) G_GNUC_PRINTF(1, 2); 35 36 /** 37 * qtest_vinitf: 38 * @fmt: Format for creating other arguments to pass to QEMU, formatted 39 * like vsprintf(). 40 * @ap: Format arguments. 41 * 42 * Convenience wrapper around qtest_init(). 43 * 44 * Returns: #QTestState instance. 45 */ 46 QTestState *qtest_vinitf(const char *fmt, va_list ap) G_GNUC_PRINTF(1, 0); 47 48 /** 49 * qtest_init: 50 * @extra_args: other arguments to pass to QEMU. CAUTION: these 51 * arguments are subject to word splitting and shell evaluation. 52 * 53 * Returns: #QTestState instance. 54 */ 55 QTestState *qtest_init(const char *extra_args); 56 57 /** 58 * qtest_init_without_qmp_handshake: 59 * @extra_args: other arguments to pass to QEMU. CAUTION: these 60 * arguments are subject to word splitting and shell evaluation. 61 * 62 * Returns: #QTestState instance. 63 */ 64 QTestState *qtest_init_without_qmp_handshake(const char *extra_args); 65 66 /** 67 * qtest_init_with_serial: 68 * @extra_args: other arguments to pass to QEMU. CAUTION: these 69 * arguments are subject to word splitting and shell evaluation. 70 * @sock_fd: pointer to store the socket file descriptor for 71 * connection with serial. 72 * 73 * Returns: #QTestState instance. 74 */ 75 QTestState *qtest_init_with_serial(const char *extra_args, int *sock_fd); 76 77 /** 78 * qtest_kill_qemu: 79 * @s: #QTestState instance to operate on. 80 * 81 * Kill the QEMU process and wait for it to terminate. It is safe to call this 82 * function multiple times. Normally qtest_quit() is used instead because it 83 * also frees QTestState. Use qtest_kill_qemu() when you just want to kill QEMU 84 * and qtest_quit() will be called later. 85 */ 86 void qtest_kill_qemu(QTestState *s); 87 88 /** 89 * qtest_quit: 90 * @s: #QTestState instance to operate on. 91 * 92 * Shut down the QEMU process associated to @s. 93 */ 94 void qtest_quit(QTestState *s); 95 96 /** 97 * qtest_qmp_fds: 98 * @s: #QTestState instance to operate on. 99 * @fds: array of file descriptors 100 * @fds_num: number of elements in @fds 101 * @fmt: QMP message to send to qemu, formatted like 102 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 103 * supported after '%'. 104 * 105 * Sends a QMP message to QEMU with fds and returns the response. 106 */ 107 QDict *qtest_qmp_fds(QTestState *s, int *fds, size_t fds_num, 108 const char *fmt, ...) 109 G_GNUC_PRINTF(4, 5); 110 111 /** 112 * qtest_qmp: 113 * @s: #QTestState instance to operate on. 114 * @fmt: QMP message to send to qemu, formatted like 115 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 116 * supported after '%'. 117 * 118 * Sends a QMP message to QEMU and returns the response. 119 */ 120 QDict *qtest_qmp(QTestState *s, const char *fmt, ...) 121 G_GNUC_PRINTF(2, 3); 122 123 /** 124 * qtest_qmp_send: 125 * @s: #QTestState instance to operate on. 126 * @fmt: QMP message to send to qemu, formatted like 127 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 128 * supported after '%'. 129 * 130 * Sends a QMP message to QEMU and leaves the response in the stream. 131 */ 132 void qtest_qmp_send(QTestState *s, const char *fmt, ...) 133 G_GNUC_PRINTF(2, 3); 134 135 /** 136 * qtest_qmp_send_raw: 137 * @s: #QTestState instance to operate on. 138 * @fmt: text to send, formatted like sprintf() 139 * 140 * Sends text to the QMP monitor verbatim. Need not be valid JSON; 141 * this is useful for negative tests. 142 */ 143 void qtest_qmp_send_raw(QTestState *s, const char *fmt, ...) 144 G_GNUC_PRINTF(2, 3); 145 146 /** 147 * qtest_socket_server: 148 * @socket_path: the UNIX domain socket path 149 * 150 * Create and return a listen socket file descriptor, or abort on failure. 151 */ 152 int qtest_socket_server(const char *socket_path); 153 154 /** 155 * qtest_vqmp_fds: 156 * @s: #QTestState instance to operate on. 157 * @fds: array of file descriptors 158 * @fds_num: number of elements in @fds 159 * @fmt: QMP message to send to QEMU, formatted like 160 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 161 * supported after '%'. 162 * @ap: QMP message arguments 163 * 164 * Sends a QMP message to QEMU with fds and returns the response. 165 */ 166 QDict *qtest_vqmp_fds(QTestState *s, int *fds, size_t fds_num, 167 const char *fmt, va_list ap) 168 G_GNUC_PRINTF(4, 0); 169 170 /** 171 * qtest_vqmp: 172 * @s: #QTestState instance to operate on. 173 * @fmt: QMP message to send to QEMU, formatted like 174 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 175 * supported after '%'. 176 * @ap: QMP message arguments 177 * 178 * Sends a QMP message to QEMU and returns the response. 179 */ 180 QDict *qtest_vqmp(QTestState *s, const char *fmt, va_list ap) 181 G_GNUC_PRINTF(2, 0); 182 183 /** 184 * qtest_qmp_vsend_fds: 185 * @s: #QTestState instance to operate on. 186 * @fds: array of file descriptors 187 * @fds_num: number of elements in @fds 188 * @fmt: QMP message to send to QEMU, formatted like 189 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 190 * supported after '%'. 191 * @ap: QMP message arguments 192 * 193 * Sends a QMP message to QEMU and leaves the response in the stream. 194 */ 195 void qtest_qmp_vsend_fds(QTestState *s, int *fds, size_t fds_num, 196 const char *fmt, va_list ap) 197 G_GNUC_PRINTF(4, 0); 198 199 /** 200 * qtest_qmp_vsend: 201 * @s: #QTestState instance to operate on. 202 * @fmt: QMP message to send to QEMU, formatted like 203 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 204 * supported after '%'. 205 * @ap: QMP message arguments 206 * 207 * Sends a QMP message to QEMU and leaves the response in the stream. 208 */ 209 void qtest_qmp_vsend(QTestState *s, const char *fmt, va_list ap) 210 G_GNUC_PRINTF(2, 0); 211 212 /** 213 * qtest_qmp_receive_dict: 214 * @s: #QTestState instance to operate on. 215 * 216 * Reads a QMP message from QEMU and returns the response. 217 */ 218 QDict *qtest_qmp_receive_dict(QTestState *s); 219 220 /** 221 * qtest_qmp_receive: 222 * @s: #QTestState instance to operate on. 223 * 224 * Reads a QMP message from QEMU and returns the response. 225 * Buffers all the events received meanwhile, until a 226 * call to qtest_qmp_eventwait 227 */ 228 QDict *qtest_qmp_receive(QTestState *s); 229 230 /** 231 * qtest_qmp_eventwait: 232 * @s: #QTestState instance to operate on. 233 * @event: event to wait for. 234 * 235 * Continuously polls for QMP responses until it receives the desired event. 236 */ 237 void qtest_qmp_eventwait(QTestState *s, const char *event); 238 239 /** 240 * qtest_qmp_eventwait_ref: 241 * @s: #QTestState instance to operate on. 242 * @event: event to wait for. 243 * 244 * Continuously polls for QMP responses until it receives the desired event. 245 * Returns a copy of the event for further investigation. 246 */ 247 QDict *qtest_qmp_eventwait_ref(QTestState *s, const char *event); 248 249 /** 250 * qtest_qmp_event_ref: 251 * @s: #QTestState instance to operate on. 252 * @event: event to return. 253 * 254 * Removes non-matching events from the buffer that was set by 255 * qtest_qmp_receive, until an event bearing the given name is found, 256 * and returns it. 257 * If no event matches, clears the buffer and returns NULL. 258 * 259 */ 260 QDict *qtest_qmp_event_ref(QTestState *s, const char *event); 261 262 /** 263 * qtest_hmp: 264 * @s: #QTestState instance to operate on. 265 * @fmt: HMP command to send to QEMU, formats arguments like sprintf(). 266 * 267 * Send HMP command to QEMU via QMP's human-monitor-command. 268 * QMP events are discarded. 269 * 270 * Returns: the command's output. The caller should g_free() it. 271 */ 272 char *qtest_hmp(QTestState *s, const char *fmt, ...) G_GNUC_PRINTF(2, 3); 273 274 /** 275 * qtest_hmpv: 276 * @s: #QTestState instance to operate on. 277 * @fmt: HMP command to send to QEMU, formats arguments like vsprintf(). 278 * @ap: HMP command arguments 279 * 280 * Send HMP command to QEMU via QMP's human-monitor-command. 281 * QMP events are discarded. 282 * 283 * Returns: the command's output. The caller should g_free() it. 284 */ 285 char *qtest_vhmp(QTestState *s, const char *fmt, va_list ap) 286 G_GNUC_PRINTF(2, 0); 287 288 void qtest_module_load(QTestState *s, const char *prefix, const char *libname); 289 290 /** 291 * qtest_get_irq: 292 * @s: #QTestState instance to operate on. 293 * @num: Interrupt to observe. 294 * 295 * Returns: The level of the @num interrupt. 296 */ 297 bool qtest_get_irq(QTestState *s, int num); 298 299 /** 300 * qtest_irq_intercept_in: 301 * @s: #QTestState instance to operate on. 302 * @string: QOM path of a device. 303 * 304 * Associate qtest irqs with the GPIO-in pins of the device 305 * whose path is specified by @string. 306 */ 307 void qtest_irq_intercept_in(QTestState *s, const char *string); 308 309 /** 310 * qtest_irq_intercept_out: 311 * @s: #QTestState instance to operate on. 312 * @string: QOM path of a device. 313 * 314 * Associate qtest irqs with the GPIO-out pins of the device 315 * whose path is specified by @string. 316 */ 317 void qtest_irq_intercept_out(QTestState *s, const char *string); 318 319 /** 320 * qtest_set_irq_in: 321 * @s: QTestState instance to operate on. 322 * @string: QOM path of a device 323 * @name: IRQ name 324 * @irq: IRQ number 325 * @level: IRQ level 326 * 327 * Force given device/irq GPIO-in pin to the given level. 328 */ 329 void qtest_set_irq_in(QTestState *s, const char *string, const char *name, 330 int irq, int level); 331 332 /** 333 * qtest_outb: 334 * @s: #QTestState instance to operate on. 335 * @addr: I/O port to write to. 336 * @value: Value being written. 337 * 338 * Write an 8-bit value to an I/O port. 339 */ 340 void qtest_outb(QTestState *s, uint16_t addr, uint8_t value); 341 342 /** 343 * qtest_outw: 344 * @s: #QTestState instance to operate on. 345 * @addr: I/O port to write to. 346 * @value: Value being written. 347 * 348 * Write a 16-bit value to an I/O port. 349 */ 350 void qtest_outw(QTestState *s, uint16_t addr, uint16_t value); 351 352 /** 353 * qtest_outl: 354 * @s: #QTestState instance to operate on. 355 * @addr: I/O port to write to. 356 * @value: Value being written. 357 * 358 * Write a 32-bit value to an I/O port. 359 */ 360 void qtest_outl(QTestState *s, uint16_t addr, uint32_t value); 361 362 /** 363 * qtest_inb: 364 * @s: #QTestState instance to operate on. 365 * @addr: I/O port to read from. 366 * 367 * Returns an 8-bit value from an I/O port. 368 */ 369 uint8_t qtest_inb(QTestState *s, uint16_t addr); 370 371 /** 372 * qtest_inw: 373 * @s: #QTestState instance to operate on. 374 * @addr: I/O port to read from. 375 * 376 * Returns a 16-bit value from an I/O port. 377 */ 378 uint16_t qtest_inw(QTestState *s, uint16_t addr); 379 380 /** 381 * qtest_inl: 382 * @s: #QTestState instance to operate on. 383 * @addr: I/O port to read from. 384 * 385 * Returns a 32-bit value from an I/O port. 386 */ 387 uint32_t qtest_inl(QTestState *s, uint16_t addr); 388 389 /** 390 * qtest_writeb: 391 * @s: #QTestState instance to operate on. 392 * @addr: Guest address to write to. 393 * @value: Value being written. 394 * 395 * Writes an 8-bit value to memory. 396 */ 397 void qtest_writeb(QTestState *s, uint64_t addr, uint8_t value); 398 399 /** 400 * qtest_writew: 401 * @s: #QTestState instance to operate on. 402 * @addr: Guest address to write to. 403 * @value: Value being written. 404 * 405 * Writes a 16-bit value to memory. 406 */ 407 void qtest_writew(QTestState *s, uint64_t addr, uint16_t value); 408 409 /** 410 * qtest_writel: 411 * @s: #QTestState instance to operate on. 412 * @addr: Guest address to write to. 413 * @value: Value being written. 414 * 415 * Writes a 32-bit value to memory. 416 */ 417 void qtest_writel(QTestState *s, uint64_t addr, uint32_t value); 418 419 /** 420 * qtest_writeq: 421 * @s: #QTestState instance to operate on. 422 * @addr: Guest address to write to. 423 * @value: Value being written. 424 * 425 * Writes a 64-bit value to memory. 426 */ 427 void qtest_writeq(QTestState *s, uint64_t addr, uint64_t value); 428 429 /** 430 * qtest_readb: 431 * @s: #QTestState instance to operate on. 432 * @addr: Guest address to read from. 433 * 434 * Reads an 8-bit value from memory. 435 * 436 * Returns: Value read. 437 */ 438 uint8_t qtest_readb(QTestState *s, uint64_t addr); 439 440 /** 441 * qtest_readw: 442 * @s: #QTestState instance to operate on. 443 * @addr: Guest address to read from. 444 * 445 * Reads a 16-bit value from memory. 446 * 447 * Returns: Value read. 448 */ 449 uint16_t qtest_readw(QTestState *s, uint64_t addr); 450 451 /** 452 * qtest_readl: 453 * @s: #QTestState instance to operate on. 454 * @addr: Guest address to read from. 455 * 456 * Reads a 32-bit value from memory. 457 * 458 * Returns: Value read. 459 */ 460 uint32_t qtest_readl(QTestState *s, uint64_t addr); 461 462 /** 463 * qtest_readq: 464 * @s: #QTestState instance to operate on. 465 * @addr: Guest address to read from. 466 * 467 * Reads a 64-bit value from memory. 468 * 469 * Returns: Value read. 470 */ 471 uint64_t qtest_readq(QTestState *s, uint64_t addr); 472 473 /** 474 * qtest_memread: 475 * @s: #QTestState instance to operate on. 476 * @addr: Guest address to read from. 477 * @data: Pointer to where memory contents will be stored. 478 * @size: Number of bytes to read. 479 * 480 * Read guest memory into a buffer. 481 */ 482 void qtest_memread(QTestState *s, uint64_t addr, void *data, size_t size); 483 484 /** 485 * qtest_rtas_call: 486 * @s: #QTestState instance to operate on. 487 * @name: name of the command to call. 488 * @nargs: Number of args. 489 * @args: Guest address to read args from. 490 * @nret: Number of return value. 491 * @ret: Guest address to write return values to. 492 * 493 * Call an RTAS function 494 */ 495 uint64_t qtest_rtas_call(QTestState *s, const char *name, 496 uint32_t nargs, uint64_t args, 497 uint32_t nret, uint64_t ret); 498 499 /** 500 * qtest_bufread: 501 * @s: #QTestState instance to operate on. 502 * @addr: Guest address to read from. 503 * @data: Pointer to where memory contents will be stored. 504 * @size: Number of bytes to read. 505 * 506 * Read guest memory into a buffer and receive using a base64 encoding. 507 */ 508 void qtest_bufread(QTestState *s, uint64_t addr, void *data, size_t size); 509 510 /** 511 * qtest_memwrite: 512 * @s: #QTestState instance to operate on. 513 * @addr: Guest address to write to. 514 * @data: Pointer to the bytes that will be written to guest memory. 515 * @size: Number of bytes to write. 516 * 517 * Write a buffer to guest memory. 518 */ 519 void qtest_memwrite(QTestState *s, uint64_t addr, const void *data, size_t size); 520 521 /** 522 * qtest_bufwrite: 523 * @s: #QTestState instance to operate on. 524 * @addr: Guest address to write to. 525 * @data: Pointer to the bytes that will be written to guest memory. 526 * @size: Number of bytes to write. 527 * 528 * Write a buffer to guest memory and transmit using a base64 encoding. 529 */ 530 void qtest_bufwrite(QTestState *s, uint64_t addr, 531 const void *data, size_t size); 532 533 /** 534 * qtest_memset: 535 * @s: #QTestState instance to operate on. 536 * @addr: Guest address to write to. 537 * @patt: Byte pattern to fill the guest memory region with. 538 * @size: Number of bytes to write. 539 * 540 * Write a pattern to guest memory. 541 */ 542 void qtest_memset(QTestState *s, uint64_t addr, uint8_t patt, size_t size); 543 544 /** 545 * qtest_clock_step_next: 546 * @s: #QTestState instance to operate on. 547 * 548 * Advance the QEMU_CLOCK_VIRTUAL to the next deadline. 549 * 550 * Returns: The current value of the QEMU_CLOCK_VIRTUAL in nanoseconds. 551 */ 552 int64_t qtest_clock_step_next(QTestState *s); 553 554 /** 555 * qtest_clock_step: 556 * @s: QTestState instance to operate on. 557 * @step: Number of nanoseconds to advance the clock by. 558 * 559 * Advance the QEMU_CLOCK_VIRTUAL by @step nanoseconds. 560 * 561 * Returns: The current value of the QEMU_CLOCK_VIRTUAL in nanoseconds. 562 */ 563 int64_t qtest_clock_step(QTestState *s, int64_t step); 564 565 /** 566 * qtest_clock_set: 567 * @s: QTestState instance to operate on. 568 * @val: Nanoseconds value to advance the clock to. 569 * 570 * Advance the QEMU_CLOCK_VIRTUAL to @val nanoseconds since the VM was launched. 571 * 572 * Returns: The current value of the QEMU_CLOCK_VIRTUAL in nanoseconds. 573 */ 574 int64_t qtest_clock_set(QTestState *s, int64_t val); 575 576 /** 577 * qtest_big_endian: 578 * @s: QTestState instance to operate on. 579 * 580 * Returns: True if the architecture under test has a big endian configuration. 581 */ 582 bool qtest_big_endian(QTestState *s); 583 584 /** 585 * qtest_get_arch: 586 * 587 * Returns: The architecture for the QEMU executable under test. 588 */ 589 const char *qtest_get_arch(void); 590 591 /** 592 * qtest_has_accel: 593 * @accel_name: Accelerator name to check for. 594 * 595 * Returns: true if the accelerator is built in. 596 */ 597 bool qtest_has_accel(const char *accel_name); 598 599 /** 600 * qtest_add_func: 601 * @str: Test case path. 602 * @fn: Test case function 603 * 604 * Add a GTester testcase with the given name and function. 605 * The path is prefixed with the architecture under test, as 606 * returned by qtest_get_arch(). 607 */ 608 void qtest_add_func(const char *str, void (*fn)(void)); 609 610 /** 611 * qtest_add_data_func: 612 * @str: Test case path. 613 * @data: Test case data 614 * @fn: Test case function 615 * 616 * Add a GTester testcase with the given name, data and function. 617 * The path is prefixed with the architecture under test, as 618 * returned by qtest_get_arch(). 619 */ 620 void qtest_add_data_func(const char *str, const void *data, 621 void (*fn)(const void *)); 622 623 /** 624 * qtest_add_data_func_full: 625 * @str: Test case path. 626 * @data: Test case data 627 * @fn: Test case function 628 * @data_free_func: GDestroyNotify for data 629 * 630 * Add a GTester testcase with the given name, data and function. 631 * The path is prefixed with the architecture under test, as 632 * returned by qtest_get_arch(). 633 * 634 * @data is passed to @data_free_func() on test completion. 635 */ 636 void qtest_add_data_func_full(const char *str, void *data, 637 void (*fn)(const void *), 638 GDestroyNotify data_free_func); 639 640 /** 641 * qtest_add: 642 * @testpath: Test case path 643 * @Fixture: Fixture type 644 * @tdata: Test case data 645 * @fsetup: Test case setup function 646 * @ftest: Test case function 647 * @fteardown: Test case teardown function 648 * 649 * Add a GTester testcase with the given name, data and functions. 650 * The path is prefixed with the architecture under test, as 651 * returned by qtest_get_arch(). 652 */ 653 #define qtest_add(testpath, Fixture, tdata, fsetup, ftest, fteardown) \ 654 do { \ 655 char *path = g_strdup_printf("/%s/%s", qtest_get_arch(), testpath); \ 656 g_test_add(path, Fixture, tdata, fsetup, ftest, fteardown); \ 657 g_free(path); \ 658 } while (0) 659 660 /** 661 * qtest_add_abrt_handler: 662 * @fn: Handler function 663 * @data: Argument that is passed to the handler 664 * 665 * Add a handler function that is invoked on SIGABRT. This can be used to 666 * terminate processes and perform other cleanup. The handler can be removed 667 * with qtest_remove_abrt_handler(). 668 */ 669 void qtest_add_abrt_handler(GHookFunc fn, const void *data); 670 671 /** 672 * qtest_remove_abrt_handler: 673 * @data: Argument previously passed to qtest_add_abrt_handler() 674 * 675 * Remove an abrt handler that was previously added with 676 * qtest_add_abrt_handler(). 677 */ 678 void qtest_remove_abrt_handler(void *data); 679 680 /** 681 * qtest_qmp_assert_success: 682 * @qts: QTestState instance to operate on 683 * @fmt: QMP message to send to qemu, formatted like 684 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 685 * supported after '%'. 686 * 687 * Sends a QMP message to QEMU and asserts that a 'return' key is present in 688 * the response. 689 */ 690 void qtest_qmp_assert_success(QTestState *qts, const char *fmt, ...) 691 G_GNUC_PRINTF(2, 3); 692 693 QDict *qmp_fd_receive(int fd); 694 void qmp_fd_vsend_fds(int fd, int *fds, size_t fds_num, 695 const char *fmt, va_list ap) G_GNUC_PRINTF(4, 0); 696 void qmp_fd_vsend(int fd, const char *fmt, va_list ap) G_GNUC_PRINTF(2, 0); 697 void qmp_fd_send(int fd, const char *fmt, ...) G_GNUC_PRINTF(2, 3); 698 void qmp_fd_send_raw(int fd, const char *fmt, ...) G_GNUC_PRINTF(2, 3); 699 void qmp_fd_vsend_raw(int fd, const char *fmt, va_list ap) G_GNUC_PRINTF(2, 0); 700 QDict *qmp_fdv(int fd, const char *fmt, va_list ap) G_GNUC_PRINTF(2, 0); 701 QDict *qmp_fd(int fd, const char *fmt, ...) G_GNUC_PRINTF(2, 3); 702 703 /** 704 * qtest_cb_for_every_machine: 705 * @cb: Pointer to the callback function 706 * @skip_old_versioned: true if versioned old machine types should be skipped 707 * 708 * Call a callback function for every name of all available machines. 709 */ 710 void qtest_cb_for_every_machine(void (*cb)(const char *machine), 711 bool skip_old_versioned); 712 713 /** 714 * qtest_has_machine: 715 * @machine: The machine to look for 716 * 717 * Returns: true if the machine is available in the target binary. 718 */ 719 bool qtest_has_machine(const char *machine); 720 721 /** 722 * qtest_has_device: 723 * @device: The device to look for 724 * 725 * Returns: true if the device is available in the target binary. 726 */ 727 bool qtest_has_device(const char *device); 728 729 /** 730 * qtest_qmp_device_add_qdict: 731 * @qts: QTestState instance to operate on 732 * @drv: Name of the device that should be added 733 * @arguments: QDict with properties for the device to intialize 734 * 735 * Generic hot-plugging test via the device_add QMP command with properties 736 * supplied in form of QDict. Use NULL for empty properties list. 737 */ 738 void qtest_qmp_device_add_qdict(QTestState *qts, const char *drv, 739 const QDict *arguments); 740 741 /** 742 * qtest_qmp_device_add: 743 * @qts: QTestState instance to operate on 744 * @driver: Name of the device that should be added 745 * @id: Identification string 746 * @fmt: QMP message to send to qemu, formatted like 747 * qobject_from_jsonf_nofail(). See parse_interpolation() for what's 748 * supported after '%'. 749 * 750 * Generic hot-plugging test via the device_add QMP command. 751 */ 752 void qtest_qmp_device_add(QTestState *qts, const char *driver, const char *id, 753 const char *fmt, ...) G_GNUC_PRINTF(4, 5); 754 755 /** 756 * qtest_qmp_add_client: 757 * @qts: QTestState instance to operate on 758 * @protocol: the protocol to add to 759 * @fd: the client file-descriptor 760 * 761 * Call QMP ``getfd`` followed by ``add_client`` with the given @fd. 762 */ 763 void qtest_qmp_add_client(QTestState *qts, const char *protocol, int fd); 764 765 /** 766 * qtest_qmp_device_del: 767 * @qts: QTestState instance to operate on 768 * @id: Identification string 769 * 770 * Generic hot-unplugging test via the device_del QMP command. 771 */ 772 void qtest_qmp_device_del(QTestState *qts, const char *id); 773 774 /** 775 * qmp_rsp_is_err: 776 * @rsp: QMP response to check for error 777 * 778 * Test @rsp for error and discard @rsp. 779 * Returns 'true' if there is error in @rsp and 'false' otherwise. 780 */ 781 bool qmp_rsp_is_err(QDict *rsp); 782 783 /** 784 * qmp_expect_error_and_unref: 785 * @rsp: QMP response to check for error 786 * @class: an error class 787 * 788 * Assert the response has the given error class and discard @rsp. 789 */ 790 void qmp_expect_error_and_unref(QDict *rsp, const char *class); 791 792 /** 793 * qtest_probe_child: 794 * @s: QTestState instance to operate on. 795 * 796 * Returns: true if the child is still alive. 797 */ 798 bool qtest_probe_child(QTestState *s); 799 800 /** 801 * qtest_set_expected_status: 802 * @s: QTestState instance to operate on. 803 * @status: an expected exit status. 804 * 805 * Set expected exit status of the child. 806 */ 807 void qtest_set_expected_status(QTestState *s, int status); 808 809 QTestState *qtest_inproc_init(QTestState **s, bool log, const char* arch, 810 void (*send)(void*, const char*)); 811 812 void qtest_client_inproc_recv(void *opaque, const char *str); 813 #endif 814