VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/tests/usb/tdUsb1.py@ 68708

Last change on this file since 68708 was 67039, checked in by vboxsync, 8 years ago

ValidationKit: eliminate buggy task handling (oSession is always added by starting the VM and remmoved when terminating it, and oTxsSession can only be removed if it was added before)

  • Property svn:eol-style set to LF
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 24.8 KB
Line 
1#!/usr/bin/env python
2# -*- coding: utf-8 -*-
3# $Id: tdUsb1.py 67039 2017-05-23 11:33:27Z vboxsync $
4
5"""
6VirtualBox Validation Kit - USB testcase and benchmark.
7"""
8
9__copyright__ = \
10"""
11Copyright (C) 2014-2016 Oracle Corporation
12
13This file is part of VirtualBox Open Source Edition (OSE), as
14available from http://www.virtualbox.org. This file is free software;
15you can redistribute it and/or modify it under the terms of the GNU
16General Public License (GPL) as published by the Free Software
17Foundation, in version 2 as it comes in the "COPYING" file of the
18VirtualBox OSE distribution. VirtualBox OSE is distributed in the
19hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
20
21The contents of this file may alternatively be used under the terms
22of the Common Development and Distribution License Version 1.0
23(CDDL) only, as it comes in the "COPYING.CDDL" file of the
24VirtualBox OSE distribution, in which case the provisions of the
25CDDL are applicable instead of those of the GPL.
26
27You may elect to license modified versions of this file under the
28terms and conditions of either the GPL or the CDDL or both.
29"""
30__version__ = "$Revision: 67039 $"
31
32
33# Standard Python imports.
34import os;
35import sys;
36import socket;
37
38# Only the main script needs to modify the path.
39try: __file__
40except: __file__ = sys.argv[0];
41g_ksValidationKitDir = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))));
42sys.path.append(g_ksValidationKitDir);
43
44# Validation Kit imports.
45from testdriver import reporter;
46from testdriver import base;
47from testdriver import vbox;
48from testdriver import vboxcon;
49
50# USB gadget control import
51import usbgadget;
52
53class tdUsbBenchmark(vbox.TestDriver): # pylint: disable=R0902
54 """
55 USB benchmark.
56 """
57
58 # The available test devices
59 #
60 # The first key is the hostname of the host the test is running on.
61 # It contains a new dictionary with the attached gadgets based on the
62 # USB speed we want to test (Low, Full, High, Super).
63 # The parameters consist of the hostname of the gadget in the network
64 # and the hardware type.
65 kdGadgetParams = {
66 'adaris': {
67 'Low': ('usbtest.de.oracle.com', None),
68 'Full': ('usbtest.de.oracle.com', None),
69 'High': ('usbtest.de.oracle.com', None),
70 'Super': ('usbtest.de.oracle.com', None)
71 },
72 };
73
74 # Mappings of USB controllers to supported USB device speeds.
75 kdUsbSpeedMappings = {
76 'OHCI': ['Low', 'Full'],
77 'EHCI': ['High'],
78 'XHCI': ['Low', 'Full', 'High', 'Super']
79 };
80
81 # Tests currently disabled because they fail, need investigation.
82 kdUsbTestsDisabled = {
83 'Low': [24],
84 'Full': [24],
85 'High': [24],
86 'Super': [24]
87 };
88
89 def __init__(self):
90 vbox.TestDriver.__init__(self);
91 self.asRsrcs = None;
92 self.asTestVMsDef = ['tst-arch'];
93 self.asTestVMs = self.asTestVMsDef;
94 self.asSkipVMs = [];
95 self.asVirtModesDef = ['hwvirt', 'hwvirt-np', 'raw'];
96 self.asVirtModes = self.asVirtModesDef;
97 self.acCpusDef = [1, 2,];
98 self.acCpus = self.acCpusDef;
99 self.asUsbCtrlsDef = ['OHCI', 'EHCI', 'XHCI'];
100 self.asUsbCtrls = self.asUsbCtrlsDef;
101 self.asUsbSpeedDef = ['Low', 'Full', 'High', 'Super'];
102 self.asUsbSpeed = self.asUsbSpeedDef;
103 self.asUsbTestsDef = ['Compliance', 'Reattach'];
104 self.asUsbTests = self.asUsbTestsDef;
105 self.cUsbReattachCyclesDef = 100;
106 self.cUsbReattachCycles = self.cUsbReattachCyclesDef;
107 self.sHostname = socket.gethostname().lower();
108 self.sGadgetHostnameDef = 'usbtest.de.oracle.com';
109 self.uGadgetPortDef = None;
110 self.sUsbCapturePathDef = self.sScratchPath;
111 self.sUsbCapturePath = self.sUsbCapturePathDef;
112 self.fUsbCapture = False;
113
114 #
115 # Overridden methods.
116 #
117 def showUsage(self):
118 rc = vbox.TestDriver.showUsage(self);
119 reporter.log('');
120 reporter.log('tdUsb1 Options:');
121 reporter.log(' --virt-modes <m1[:m2[:]]');
122 reporter.log(' Default: %s' % (':'.join(self.asVirtModesDef)));
123 reporter.log(' --cpu-counts <c1[:c2[:]]');
124 reporter.log(' Default: %s' % (':'.join(str(c) for c in self.acCpusDef)));
125 reporter.log(' --test-vms <vm1[:vm2[:...]]>');
126 reporter.log(' Test the specified VMs in the given order. Use this to change');
127 reporter.log(' the execution order or limit the choice of VMs');
128 reporter.log(' Default: %s (all)' % (':'.join(self.asTestVMsDef)));
129 reporter.log(' --skip-vms <vm1[:vm2[:...]]>');
130 reporter.log(' Skip the specified VMs when testing.');
131 reporter.log(' --usb-ctrls <u1[:u2[:]]');
132 reporter.log(' Default: %s' % (':'.join(str(c) for c in self.asUsbCtrlsDef)));
133 reporter.log(' --usb-speed <s1[:s2[:]]');
134 reporter.log(' Default: %s' % (':'.join(str(c) for c in self.asUsbSpeedDef)));
135 reporter.log(' --usb-tests <s1[:s2[:]]');
136 reporter.log(' Default: %s' % (':'.join(str(c) for c in self.asUsbTestsDef)));
137 reporter.log(' --usb-reattach-cycles <cycles>');
138 reporter.log(' Default: %s' % (self.cUsbReattachCyclesDef));
139 reporter.log(' --hostname: <hostname>');
140 reporter.log(' Default: %s' % (self.sHostname));
141 reporter.log(' --default-gadget-host <hostname>');
142 reporter.log(' Default: %s' % (self.sGadgetHostnameDef));
143 reporter.log(' --default-gadget-port <port>');
144 reporter.log(' Default: %s' % (6042));
145 reporter.log(' --usb-capture-path <path>');
146 reporter.log(' Default: %s' % (self.sUsbCapturePathDef));
147 reporter.log(' --usb-capture');
148 reporter.log(' Whether to capture the USB traffic for each test');
149 return rc;
150
151 def parseOption(self, asArgs, iArg): # pylint: disable=R0912,R0915
152 if asArgs[iArg] == '--virt-modes':
153 iArg += 1;
154 if iArg >= len(asArgs): raise base.InvalidOption('The "--virt-modes" takes a colon separated list of modes');
155 self.asVirtModes = asArgs[iArg].split(':');
156 for s in self.asVirtModes:
157 if s not in self.asVirtModesDef:
158 raise base.InvalidOption('The "--virt-modes" value "%s" is not valid; valid values are: %s' \
159 % (s, ' '.join(self.asVirtModesDef)));
160 elif asArgs[iArg] == '--cpu-counts':
161 iArg += 1;
162 if iArg >= len(asArgs): raise base.InvalidOption('The "--cpu-counts" takes a colon separated list of cpu counts');
163 self.acCpus = [];
164 for s in asArgs[iArg].split(':'):
165 try: c = int(s);
166 except: raise base.InvalidOption('The "--cpu-counts" value "%s" is not an integer' % (s,));
167 if c <= 0: raise base.InvalidOption('The "--cpu-counts" value "%s" is zero or negative' % (s,));
168 self.acCpus.append(c);
169 elif asArgs[iArg] == '--test-vms':
170 iArg += 1;
171 if iArg >= len(asArgs): raise base.InvalidOption('The "--test-vms" takes colon separated list');
172 self.asTestVMs = asArgs[iArg].split(':');
173 for s in self.asTestVMs:
174 if s not in self.asTestVMsDef:
175 raise base.InvalidOption('The "--test-vms" value "%s" is not valid; valid values are: %s' \
176 % (s, ' '.join(self.asTestVMsDef)));
177 elif asArgs[iArg] == '--skip-vms':
178 iArg += 1;
179 if iArg >= len(asArgs): raise base.InvalidOption('The "--skip-vms" takes colon separated list');
180 self.asSkipVMs = asArgs[iArg].split(':');
181 for s in self.asSkipVMs:
182 if s not in self.asTestVMsDef:
183 reporter.log('warning: The "--test-vms" value "%s" does not specify any of our test VMs.' % (s));
184 elif asArgs[iArg] == '--usb-ctrls':
185 iArg += 1;
186 if iArg >= len(asArgs): raise base.InvalidOption('The "--usb-ctrls" takes a colon separated list of USB controllers');
187 self.asUsbCtrls = asArgs[iArg].split(':');
188 for s in self.asUsbCtrls:
189 if s not in self.asUsbCtrlsDef:
190 reporter.log('warning: The "--usb-ctrls" value "%s" is not a valid USB controller.' % (s));
191 elif asArgs[iArg] == '--usb-speed':
192 iArg += 1;
193 if iArg >= len(asArgs): raise base.InvalidOption('The "--usb-speed" takes a colon separated list of USB speeds');
194 self.asUsbSpeed = asArgs[iArg].split(':');
195 for s in self.asUsbSpeed:
196 if s not in self.asUsbSpeedDef:
197 reporter.log('warning: The "--usb-speed" value "%s" is not a valid USB speed.' % (s));
198 elif asArgs[iArg] == '--usb-tests':
199 iArg += 1;
200 if iArg >= len(asArgs): raise base.InvalidOption('The "--usb-tests" takes a colon separated list of USB tests');
201 self.asUsbTests = asArgs[iArg].split(':');
202 for s in self.asUsbTests:
203 if s not in self.asUsbTestsDef:
204 reporter.log('warning: The "--usb-tests" value "%s" is not a valid USB test.' % (s));
205 elif asArgs[iArg] == '--usb-reattach-cycles':
206 iArg += 1;
207 if iArg >= len(asArgs): raise base.InvalidOption('The "--usb-reattach-cycles" takes cycle count');
208 try: self.cUsbReattachCycles = int(asArgs[iArg]);
209 except: raise base.InvalidOption('The "--usb-reattach-cycles" value "%s" is not an integer' \
210 % (asArgs[iArg],));
211 if self.cUsbReattachCycles <= 0:
212 raise base.InvalidOption('The "--usb-reattach-cycles" value "%s" is zero or negative.' \
213 % (self.cUsbReattachCycles,));
214 elif asArgs[iArg] == '--hostname':
215 iArg += 1;
216 if iArg >= len(asArgs): raise base.InvalidOption('The "--hostname" takes a hostname');
217 self.sHostname = asArgs[iArg];
218 elif asArgs[iArg] == '--default-gadget-host':
219 iArg += 1;
220 if iArg >= len(asArgs): raise base.InvalidOption('The "--default-gadget-host" takes a hostname');
221 self.sGadgetHostnameDef = asArgs[iArg];
222 elif asArgs[iArg] == '--default-gadget-port':
223 iArg += 1;
224 if iArg >= len(asArgs): raise base.InvalidOption('The "--default-gadget-port" takes port number');
225 try: self.uGadgetPortDef = int(asArgs[iArg]);
226 except: raise base.InvalidOption('The "--default-gadget-port" value "%s" is not an integer' \
227 % (asArgs[iArg],));
228 if self.uGadgetPortDef <= 0:
229 raise base.InvalidOption('The "--default-gadget-port" value "%s" is zero or negative.' \
230 % (self.uGadgetPortDef,));
231 elif asArgs[iArg] == '--usb-capture-path':
232 if iArg >= len(asArgs): raise base.InvalidOption('The "--usb-capture-path" takes a path argument');
233 self.sUsbCapturePath = asArgs[iArg];
234 elif asArgs[iArg] == '--usb-capture':
235 self.fUsbCapture = True;
236 else:
237 return vbox.TestDriver.parseOption(self, asArgs, iArg);
238 return iArg + 1;
239
240 def completeOptions(self):
241 # Remove skipped VMs from the test list.
242 for sVM in self.asSkipVMs:
243 try: self.asTestVMs.remove(sVM);
244 except: pass;
245
246 return vbox.TestDriver.completeOptions(self);
247
248 def getResourceSet(self):
249 # Construct the resource list the first time it's queried.
250 if self.asRsrcs is None:
251 self.asRsrcs = [];
252
253 if 'tst-arch' in self.asTestVMs:
254 self.asRsrcs.append('4.2/usb/tst-arch.vdi');
255
256 return self.asRsrcs;
257
258 def actionConfig(self):
259
260 # Some stupid trickery to guess the location of the iso. ## fixme - testsuite unzip ++
261 sVBoxValidationKit_iso = os.path.abspath(os.path.join(os.path.dirname(__file__), '../../VBoxValidationKit.iso'));
262 if not os.path.isfile(sVBoxValidationKit_iso):
263 sVBoxValidationKit_iso = os.path.abspath(os.path.join(os.path.dirname(__file__), '../../VBoxTestSuite.iso'));
264 if not os.path.isfile(sVBoxValidationKit_iso):
265 sVBoxValidationKit_iso = '/mnt/ramdisk/vbox/svn/trunk/validationkit/VBoxValidationKit.iso';
266 if not os.path.isfile(sVBoxValidationKit_iso):
267 sVBoxValidationKit_iso = '/mnt/ramdisk/vbox/svn/trunk/testsuite/VBoxTestSuite.iso';
268 if not os.path.isfile(sVBoxValidationKit_iso):
269 sCur = os.getcwd();
270 for i in range(0, 10):
271 sVBoxValidationKit_iso = os.path.join(sCur, 'validationkit/VBoxValidationKit.iso');
272 if os.path.isfile(sVBoxValidationKit_iso):
273 break;
274 sVBoxValidationKit_iso = os.path.join(sCur, 'testsuite/VBoxTestSuite.iso');
275 if os.path.isfile(sVBoxValidationKit_iso):
276 break;
277 sCur = os.path.abspath(os.path.join(sCur, '..'));
278 if i is None: pass; # shut up pychecker/pylint.
279 if not os.path.isfile(sVBoxValidationKit_iso):
280 sVBoxValidationKit_iso = '/home/bird/validationkit/VBoxValidationKit.iso';
281 if not os.path.isfile(sVBoxValidationKit_iso):
282 sVBoxValidationKit_iso = '/home/bird/testsuite/VBoxTestSuite.iso';
283
284 # Make sure vboxapi has been imported so we can use the constants.
285 if not self.importVBoxApi():
286 return False;
287
288 #
289 # Configure the VMs we're going to use.
290 #
291
292 # Linux VMs
293 if 'tst-arch' in self.asTestVMs:
294 oVM = self.createTestVM('tst-arch', 1, '4.2/usb/tst-arch.vdi', sKind = 'ArchLinux_64', fIoApic = True, \
295 eNic0AttachType = vboxcon.NetworkAttachmentType_NAT, \
296 sDvdImage = sVBoxValidationKit_iso);
297 if oVM is None:
298 return False;
299
300 return True;
301
302 def actionExecute(self):
303 """
304 Execute the testcase.
305 """
306 fRc = self.testUsb();
307 return fRc;
308
309 def getGadgetParams(self, sHostname, sSpeed):
310 """
311 Returns the gadget hostname and port from the
312 given hostname the test is running on and device speed we want to test.
313 """
314 kdGadgetsConfigured = self.kdGadgetParams.get(sHostname);
315 if kdGadgetsConfigured is not None:
316 return kdGadgetsConfigured.get(sSpeed);
317
318 return (self.sGadgetHostnameDef, self.uGadgetPortDef);
319
320 def getCaptureFilePath(self, sUsbCtrl, sSpeed):
321 """
322 Returns capture filename from the given data.
323 """
324
325 return '%s%s%s-%s.pcap' % (self.sUsbCapturePath, os.sep, sUsbCtrl, sSpeed);
326
327 def attachUsbDeviceToVm(self, oSession, sVendorId, sProductId, iBusId,
328 sCaptureFile = None):
329 """
330 Attaches the given USB device to the VM either via a filter
331 or directly if capturing the USB traffic is enabled.
332
333 Returns True on success, False on failure.
334 """
335 fRc = False;
336 if sCaptureFile is None:
337 fRc = oSession.addUsbDeviceFilter('Compliance device', sVendorId = sVendorId, sProductId = sProductId, \
338 sPort = format(iBusId, 'x'));
339 else:
340 # Search for the correct device in the USB device list waiting for some time
341 # to let it appear.
342 iVendorId = int(sVendorId, 16);
343 iProductId = int(sProductId, 16);
344
345 # Try a few times to give VBoxSVC a chance to detect the new device.
346 for _ in xrange(5):
347 fFound = False;
348 aoUsbDevs = self.oVBoxMgr.getArray(self.oVBox.host, 'USBDevices');
349 for oUsbDev in aoUsbDevs:
350 if oUsbDev.vendorId == iVendorId \
351 and oUsbDev.productId == iProductId \
352 and oUsbDev.port == iBusId:
353 fFound = True;
354 fRc = oSession.attachUsbDevice(oUsbDev.id, sCaptureFile);
355 break;
356
357 if fFound:
358 break;
359
360 # Wait a moment until the next try.
361 self.sleep(1);
362
363 if fRc:
364 # Wait a moment to let the USB device appear
365 self.sleep(9);
366
367 return fRc;
368
369 #
370 # Test execution helpers.
371 #
372 def testUsbCompliance(self, oSession, oTxsSession, sUsbCtrl, sSpeed, sCaptureFile = None):
373 """
374 Test VirtualBoxs USB stack in a VM.
375 """
376 # Get configured USB test devices from hostname we are running on
377 sGadgetHost, uGadgetPort = self.getGadgetParams(self.sHostname, sSpeed);
378
379 oUsbGadget = usbgadget.UsbGadget();
380 reporter.log('Connecting to UTS: ' + sGadgetHost);
381 fRc = oUsbGadget.connectTo(30 * 1000, sGadgetHost, uPort = uGadgetPort);
382 if fRc is True:
383 reporter.log('Connect succeeded');
384 self.oVBox.host.addUSBDeviceSource('USBIP', sGadgetHost, sGadgetHost + (':%s' % oUsbGadget.getUsbIpPort()), [], []);
385
386 fSuperSpeed = False;
387 if sSpeed == 'Super':
388 fSuperSpeed = True;
389
390 # Create test device gadget and a filter to attach the device automatically.
391 fRc = oUsbGadget.impersonate(usbgadget.g_ksGadgetImpersonationTest, fSuperSpeed);
392 if fRc is True:
393 iBusId, _ = oUsbGadget.getGadgetBusAndDevId();
394 fRc = self.attachUsbDeviceToVm(oSession, '0525', 'a4a0', iBusId, sCaptureFile);
395 if fRc is True:
396 tupCmdLine = ('UsbTest', );
397 # Exclude a few tests which hang and cause a timeout, need investigation.
398 lstTestsExclude = self.kdUsbTestsDisabled.get(sSpeed);
399 for iTestExclude in lstTestsExclude:
400 tupCmdLine = tupCmdLine + ('--exclude', str(iTestExclude));
401
402 fRc = self.txsRunTest(oTxsSession, 'UsbTest', 3600 * 1000, \
403 '${CDROM}/${OS/ARCH}/UsbTest${EXESUFF}', tupCmdLine);
404 if not fRc:
405 reporter.testFailure('Running USB test utility failed');
406 else:
407 reporter.testFailure('Failed to attach USB device to VM');
408 oUsbGadget.disconnectFrom();
409 else:
410 reporter.testFailure('Failed to impersonate test device');
411
412 self.oVBox.host.removeUSBDeviceSource(sGadgetHost);
413 else:
414 reporter.testFailure('Failed to connect to USB gadget');
415
416 _ = sUsbCtrl;
417 return fRc;
418
419 def testUsbReattach(self, oSession, oTxsSession, sUsbCtrl, sSpeed, sCaptureFile = None): # pylint: disable=W0613
420 """
421 Tests that rapid connect/disconnect cycles work.
422 """
423 # Get configured USB test devices from hostname we are running on
424 sGadgetHost, uGadgetPort = self.getGadgetParams(self.sHostname, sSpeed);
425
426 oUsbGadget = usbgadget.UsbGadget();
427 reporter.log('Connecting to UTS: ' + sGadgetHost);
428 fRc = oUsbGadget.connectTo(30 * 1000, sGadgetHost, uPort = uGadgetPort);
429 if fRc is True:
430 self.oVBox.host.addUSBDeviceSource('USBIP', sGadgetHost, sGadgetHost + (':%s' % oUsbGadget.getUsbIpPort()), [], []);
431
432 fSuperSpeed = False;
433 if sSpeed == 'Super':
434 fSuperSpeed = True;
435
436 # Create test device gadget and a filter to attach the device automatically.
437 fRc = oUsbGadget.impersonate(usbgadget.g_ksGadgetImpersonationTest, fSuperSpeed);
438 if fRc is True:
439 iBusId, _ = oUsbGadget.getGadgetBusAndDevId();
440 fRc = self.attachUsbDeviceToVm(oSession, '0525', 'a4a0', iBusId, sCaptureFile);
441 if fRc is True:
442
443 # Wait a moment to let the USB device appear
444 self.sleep(3);
445
446 # Do a rapid disconnect reconnect cycle. Wait a second before disconnecting
447 # again or it will happen so fast that the VM can't attach the new device.
448 # @todo: Get rid of the constant wait and use an event to get notified when
449 # the device was attached.
450 for iCycle in xrange (0, self.cUsbReattachCycles):
451 fRc = oUsbGadget.disconnectUsb();
452 fRc = fRc and oUsbGadget.connectUsb();
453 if not fRc:
454 reporter.testFailure('Reattach cycle %s failed on the gadget device' % (iCycle));
455 break;
456 self.sleep(1);
457
458 else:
459 reporter.testFailure('Failed to impersonate test device');
460
461 oUsbGadget.disconnectFrom();
462 else:
463 reporter.testFailure('Failed to connect to USB gadget');
464 else:
465 reporter.testFailure('Failed to create USB device filter');
466
467 return fRc;
468
469 def testUsbOneCfg(self, sVmName, sUsbCtrl, sSpeed, sUsbTest):
470 """
471 Runs the specified VM thru one specified test.
472
473 Returns a success indicator on the general test execution. This is not
474 the actual test result.
475 """
476 oVM = self.getVmByName(sVmName);
477
478 # Reconfigure the VM
479 fRc = True;
480 oSession = self.openSession(oVM);
481 if oSession is not None:
482 fRc = fRc and oSession.enableVirtEx(True);
483 fRc = fRc and oSession.enableNestedPaging(True);
484
485 # Make sure controllers are disabled initially.
486 fRc = fRc and oSession.enableUsbOhci(False);
487 fRc = fRc and oSession.enableUsbEhci(False);
488 fRc = fRc and oSession.enableUsbXhci(False);
489
490 if sUsbCtrl == 'OHCI':
491 fRc = fRc and oSession.enableUsbOhci(True);
492 elif sUsbCtrl == 'EHCI':
493 fRc = fRc and oSession.enableUsbEhci(True);
494 elif sUsbCtrl == 'XHCI':
495 fRc = fRc and oSession.enableUsbXhci(True);
496 fRc = fRc and oSession.saveSettings();
497 fRc = oSession.close() and fRc and True; # pychecker hack.
498 oSession = None;
499 else:
500 fRc = False;
501
502 # Start up.
503 if fRc is True:
504 self.logVmInfo(oVM);
505 oSession, oTxsSession = self.startVmAndConnectToTxsViaTcp(sVmName, fCdWait = False, fNatForwardingForTxs = False);
506 if oSession is not None:
507 self.addTask(oTxsSession);
508
509 # Fudge factor - Allow the guest to finish starting up.
510 self.sleep(5);
511
512 sCaptureFile = None;
513 if self.fUsbCapture:
514 sCaptureFile = self.getCaptureFilePath(sUsbCtrl, sSpeed);
515
516 if sUsbTest == 'Compliance':
517 fRc = self.testUsbCompliance(oSession, oTxsSession, sUsbCtrl, sSpeed, sCaptureFile);
518 elif sUsbTest == 'Reattach':
519 fRc = self.testUsbReattach(oSession, oTxsSession, sUsbCtrl, sSpeed, sCaptureFile);
520
521 # cleanup.
522 self.removeTask(oTxsSession);
523 self.terminateVmBySession(oSession)
524
525 # Add the traffic dump if it exists and the test failed
526 if reporter.testErrorCount() > 0 \
527 and sCaptureFile is not None \
528 and os.path.exists(sCaptureFile):
529 reporter.addLogFile(sCaptureFile, 'misc/other', 'USB traffic dump');
530 else:
531 fRc = False;
532 return fRc;
533
534 def testUsbForOneVM(self, sVmName):
535 """
536 Runs one VM thru the various configurations.
537 """
538 fRc = False;
539 reporter.testStart(sVmName);
540 for sUsbCtrl in self.asUsbCtrls:
541 reporter.testStart(sUsbCtrl)
542 for sUsbSpeed in self.asUsbSpeed:
543 asSupportedSpeeds = self.kdUsbSpeedMappings.get(sUsbCtrl);
544 if sUsbSpeed in asSupportedSpeeds:
545 reporter.testStart(sUsbSpeed)
546 for sUsbTest in self.asUsbTests:
547 reporter.testStart(sUsbTest)
548 fRc = self.testUsbOneCfg(sVmName, sUsbCtrl, sUsbSpeed, sUsbTest);
549 reporter.testDone();
550 reporter.testDone();
551 reporter.testDone();
552 reporter.testDone();
553 return fRc;
554
555 def testUsb(self):
556 """
557 Executes USB test.
558 """
559
560 reporter.log("Running on host: " + self.sHostname);
561
562 # Loop thru the test VMs.
563 for sVM in self.asTestVMs:
564 # run test on the VM.
565 fRc = self.testUsbForOneVM(sVM);
566
567 return fRc;
568
569
570
571if __name__ == '__main__':
572 sys.exit(tdUsbBenchmark().main(sys.argv));
573
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette