On Sat, Jun 01, 2019 at 02:46:56PM +0200, Ilias Stamatis wrote: > Validate @keycodes and sleep for @holdtime before successfully > returning. > > Signed-off-by: Ilias Stamatis <stamatis.iliass@xxxxxxxxx> > --- > src/test/test_driver.c | 40 ++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 40 insertions(+) > > diff --git a/src/test/test_driver.c b/src/test/test_driver.c > index 2f58a1da95..51ded256be 100644 > --- a/src/test/test_driver.c > +++ b/src/test/test_driver.c > @@ -64,6 +64,7 @@ > #include "virinterfaceobj.h" > #include "virhostcpu.h" > #include "virdomainsnapshotobjlist.h" > +#include "virkeycode.h" > > #define VIR_FROM_THIS VIR_FROM_TEST > > @@ -5980,6 +5981,44 @@ testDomainScreenshot(virDomainPtr dom ATTRIBUTE_UNUSED, > return ret; > } > > +static int > +testDomainSendKey(virDomainPtr domain, > + unsigned int codeset, > + unsigned int holdtime, > + unsigned int *keycodes, > + int nkeycodes, > + unsigned int flags) > +{ > + int ret = -1; > + size_t i; > + virDomainObjPtr vm = NULL; > + > + virCheckFlags(0, -1); > + > + if (!(vm = testDomObjFromDomain(domain))) > + goto cleanup; > + > + if (virDomainObjCheckActive(vm) < 0) > + goto cleanup; > + > + for (i = 0; i < nkeycodes; i++) { > + if (virKeycodeValueTranslate(codeset, codeset, keycodes[i]) < 0) { > + virReportError(VIR_ERR_INTERNAL_ERROR, > + _("invalid keycode %u of %s codeset"), > + keycodes[i], > + virKeycodeSetTypeToString(codeset)); > + goto cleanup; > + } > + } > + > + usleep(holdtime * 1000); I think this API should be merely about translating the value, because this way you're just blocking a synchronous API for no apparent benefit. I believe it should return instantaneously. On the other hand, I'm just wondering what value it brings having an API translating keycodes, but I guess for consistency reasons, we can happily introduce it. Otherwise looking good. Erik -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list