VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/tests/additions/tdAddBasic1.py@ 59548

Last change on this file since 59548 was 59548, checked in by vboxsync, 9 years ago

ValidationKit/tests/additions/tdAddBasic1.py: Initialize fHaveSetupApiDevLog.

  • Property svn:eol-style set to LF
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 12.1 KB
Line 
1#!/usr/bin/env python
2# -*- coding: utf-8 -*-
3# $Id: tdAddBasic1.py 59548 2016-02-01 15:48:54Z vboxsync $
4
5"""
6VirtualBox Validation Kit - Additions Basics #1.
7"""
8
9__copyright__ = \
10"""
11Copyright (C) 2010-2015 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: 59548 $"
31
32
33# Standard Python imports.
34import os;
35import sys;
36
37# Only the main script needs to modify the path.
38try: __file__
39except: __file__ = sys.argv[0];
40g_ksValidationKitDir = os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))));
41sys.path.append(g_ksValidationKitDir);
42
43# Validation Kit imports.
44from testdriver import reporter;
45from testdriver import base;
46from testdriver import vbox;
47from testdriver import vboxcon;
48
49# Sub test driver imports.
50sys.path.append(os.path.dirname(os.path.abspath(__file__))); # For sub-test drivers.
51from tdAddGuestCtrl import SubTstDrvAddGuestCtrl;
52
53
54class tdAddBasic1(vbox.TestDriver): # pylint: disable=R0902
55 """
56 Additions Basics #1.
57 """
58 ## @todo
59 # - More of the settings stuff can e and need to be generalized!
60 #
61
62 def __init__(self):
63 vbox.TestDriver.__init__(self);
64 self.oTestVmSet = self.oTestVmManager.getStandardVmSet('nat');
65 self.asTestsDef = ['guestprops', 'stdguestprops', 'guestcontrol'];
66 self.asTests = self.asTestsDef;
67
68 self.addSubTestDriver(SubTstDrvAddGuestCtrl(self));
69
70 #
71 # Overridden methods.
72 #
73 def showUsage(self):
74 rc = vbox.TestDriver.showUsage(self);
75 reporter.log('');
76 reporter.log('tdAddBasic1 Options:');
77 reporter.log(' --tests <s1[:s2[:]]>');
78 reporter.log(' Default: %s (all)' % (':'.join(self.asTestsDef)));
79 reporter.log(' --quick');
80 reporter.log(' Same as --virt-modes hwvirt --cpu-counts 1.');
81 return rc;
82
83 def parseOption(self, asArgs, iArg): # pylint: disable=R0912,R0915
84 if asArgs[iArg] == '--tests':
85 iArg += 1;
86 if iArg >= len(asArgs): raise base.InvalidOption('The "--tests" takes a colon separated list of tests');
87 self.asTests = asArgs[iArg].split(':');
88 for s in self.asTests:
89 if s not in self.asTestsDef:
90 raise base.InvalidOption('The "--tests" value "%s" is not valid; valid values are: %s' \
91 % (s, ' '.join(self.asTestsDef)));
92
93 elif asArgs[iArg] == '--quick':
94 self.parseOption(['--virt-modes', 'hwvirt'], 0);
95 self.parseOption(['--cpu-counts', '1'], 0);
96
97 else:
98 return vbox.TestDriver.parseOption(self, asArgs, iArg);
99 return iArg + 1;
100
101 def actionConfig(self):
102 if not self.importVBoxApi(): # So we can use the constant below.
103 return False;
104
105 eNic0AttachType = vboxcon.NetworkAttachmentType_NAT;
106 sGaIso = self.getGuestAdditionsIso();
107 return self.oTestVmSet.actionConfig(self, eNic0AttachType = eNic0AttachType, sDvdImage = sGaIso);
108
109 def actionExecute(self):
110 return self.oTestVmSet.actionExecute(self, self.testOneCfg);
111
112
113 #
114 # Test execution helpers.
115 #
116
117 def testOneCfg(self, oVM, oTestVm):
118 """
119 Runs the specified VM thru the tests.
120
121 Returns a success indicator on the general test execution. This is not
122 the actual test result.
123 """
124 fRc = False;
125
126 self.logVmInfo(oVM);
127 oSession, oTxsSession = self.startVmAndConnectToTxsViaTcp(oTestVm.sVmName, fCdWait = True, \
128 sFileCdWait = 'AUTORUN.INF');
129 if oSession is not None:
130 self.addTask(oSession);
131 # Do the testing.
132 reporter.testStart('Install');
133 fRc, oTxsSession = self.testInstallAdditions(oSession, oTxsSession, oTestVm);
134 reporter.testDone();
135 fSkip = not fRc;
136
137 reporter.testStart('Guest Properties');
138 if not fSkip:
139 fRc = self.testGuestProperties(oSession, oTxsSession, oTestVm) and fRc;
140 reporter.testDone(fSkip);
141
142 reporter.testStart('Guest Control');
143 if not fSkip:
144 (fRc2, oTxsSession) = self.aoSubTstDrvs[0].testIt(oTestVm, oSession, oTxsSession);
145 fRc = fRc2 and fRc;
146 reporter.testDone(fSkip);
147
148 ## @todo Save an restore test.
149
150 ## @todo Reset tests.
151
152 ## @todo Final test: Uninstallation.
153
154 # Cleanup.
155 self.removeTask(oTxsSession);
156 #self.terminateVmBySession(oSession)
157 return fRc;
158
159 def testInstallAdditions(self, oSession, oTxsSession, oTestVm):
160 """
161 Tests installing the guest additions
162 """
163 if oTestVm.isWindows():
164 fRc = self.testWindowsInstallAdditions(oSession, oTxsSession, oTestVm);
165 else:
166 reporter.error('Guest Additions installation not implemented for %s yet! (%s)' % \
167 (oTestVm.sKind, oTestVm.sVmName));
168 fRc = False;
169
170 #
171 # Verify installation of Guest Additions using commmon bits.
172 #
173 if fRc is True:
174 #
175 # Wait for the GAs to come up.
176 #
177
178 ## @todo need to signed up for a OnAdditionsStateChanged and wait runlevel to
179 # at least reach Userland.
180
181 #
182 # Check if the additions are operational.
183 #
184 try: oGuest = oSession.o.console.guest;
185 except:
186 reporter.errorXcpt('Getting IGuest failed.');
187 return (False, oTxsSession);
188
189 # Check the additionsVersion attribute. It must not be empty.
190 reporter.testStart('IGuest::additionsVersion');
191 fRc = self.testIGuest_additionsVersion(oGuest);
192 reporter.testDone();
193
194 reporter.testStart('IGuest::additionsRunLevel');
195 self.testIGuest_additionsRunLevel(oGuest, oTestVm);
196 reporter.testDone();
197
198 ## @todo test IAdditionsFacilities.
199
200 return (fRc, oTxsSession);
201
202 def testWindowsInstallAdditions(self, oSession, oTxsSession, oTestVm):
203 """
204 Installs the Windows guest additions using the test execution service.
205 Since this involves rebooting the guest, we will have to create a new TXS session.
206 """
207 asLogFile = [];
208
209 fHaveSetupApiDevLog = False;
210
211 # Delete relevant log files.
212 if oTestVm.sKind in ('WindowsNT4',):
213 sWinDir = 'C:/WinNT/';
214 else:
215 sWinDir = 'C:/Windows/';
216 asLogFile = [sWinDir+'setupapi.log', sWinDir+'setupact.log', sWinDir+'setuperr.log'];
217
218 # Apply The SetupAPI logging level so that we also get the (most verbose) setupapi.dev.log file.
219 ## @todo !!! HACK ALERT !!! Add the value directly into the testing source image. Later.
220 fHaveSetupApiDevLog = self.txsRunTest(oTxsSession, 'Enabling setupapi.dev.log', 30 * 1000, \
221 'c:\\Windows\\System32\\reg.exe', ('c:\\Windows\\System32\\reg.exe', \
222 'add', '"HKLM\\Software\\Microsoft\\Windows\\CurrentVersion\\Setup"', '/v', 'LogLevel', '/t', 'REG_DWORD', \
223 '/d', '0xFF'));
224
225 # On some guests the files in question still can be locked by the OS, so ignore deletion
226 # errors from the guest side (e.g. sharing violations) and just continue.
227 for sFile in asLogFile:
228 self.txsRmFile(oSession, oTxsSession, sFile, 10 * 1000, fIgnoreErrors = True);
229
230 # Install the public signing key.
231 if oTestVm.sKind not in ('WindowsNT4', 'Windows2000', 'WindowsXP', 'Windows2003'):
232 ## TODO
233 pass;
234
235 #
236 # The actual install.
237 # Enable installing the optional auto-logon modules (VBoxGINA/VBoxCredProv) + (Direct)3D support.
238 # Also tell the installer to produce the appropriate log files.
239 #
240 fRc = self.txsRunTest(oTxsSession, 'VBoxWindowsAdditions.exe', 5 * 60 * 1000, \
241 '${CDROM}/VBoxWindowsAdditions.exe', ('${CDROM}/VBoxWindowsAdditions.exe', '/S', '/l', '/with_autologon'));
242 ## @todo For testing the installation (D)3D stuff ('/with_d3d') we need to boot up in safe mode.
243
244 #
245 # Reboot the VM and reconnect the TXS session.
246 #
247 if fRc is True:
248 (fRc, oTxsSession) = self.txsRebootAndReconnectViaTcp(oSession, oTxsSession, cMsTimeout = 3 * 60000);
249
250 # Add the Windows Guest Additions installer files to the files we want to download
251 # from the guest.
252 sGuestAddsDir = 'C:/Program Files/Oracle/VirtualBox Guest Additions/';
253 asLogFile.append(sGuestAddsDir + 'install.log');
254 # Note: There won't be a install_ui.log because of the silent installation.
255 asLogFile.append(sGuestAddsDir + 'install_drivers.log');
256 asLogFile.append('C:/Windows/setupapi.log');
257
258 # Note: setupapi.dev.log only is available since Windows 2000.
259 if fHaveSetupApiDevLog:
260 asLogFile.append('C:/Windows/setupapi.dev.log');
261
262 #
263 # Download log files.
264 # Ignore errors as all files above might not be present (or in different locations)
265 # on different Windows guests.
266 #
267 self.txsDownloadFiles(oSession, oTxsSession, asLogFile, fIgnoreErrors = True);
268
269 return (fRc, oTxsSession);
270
271 def testIGuest_additionsVersion(self, oGuest):
272 """
273 Returns False if no version string could be obtained, otherwise True
274 even though errors are logged.
275 """
276 try:
277 sVer = oGuest.additionsVersion;
278 except:
279 reporter.errorXcpt('Getting the additions version failed.');
280 return False;
281 reporter.log('IGuest::additionsVersion="%s"' % (sVer,));
282
283 if sVer.strip() == '':
284 reporter.error('IGuest::additionsVersion is empty.');
285 return False;
286
287 if sVer != sVer.strip():
288 reporter.error('IGuest::additionsVersion is contains spaces: "%s".' % (sVer,));
289
290 asBits = sVer.split('.');
291 if len(asBits) < 3:
292 reporter.error('IGuest::additionsVersion does not contain at least tree dot separated fields: "%s" (%d).'
293 % (sVer, len(asBits)));
294
295 ## @todo verify the format.
296 return True;
297
298 def testIGuest_additionsRunLevel(self, oGuest, oTestVm):
299 """
300 Do run level tests.
301 """
302 if oTestVm.isLoggedOntoDesktop():
303 eExpectedRunLevel = vboxcon.AdditionsRunLevelType_Desktop;
304 else:
305 eExpectedRunLevel = vboxcon.AdditionsRunLevelType_Userland;
306
307 ## @todo Insert wait for the desired run level.
308 try:
309 iLevel = oGuest.additionsRunLevel;
310 except:
311 reporter.errorXcpt('Getting the additions run level failed.');
312 return False;
313 reporter.log('IGuest::additionsRunLevel=%s' % (iLevel,));
314
315 if iLevel != eExpectedRunLevel:
316 reporter.error('Expected runlevel %d, found %d instead' % (eExpectedRunLevel, iLevel));
317 return True;
318
319
320 def testGuestProperties(self, oSession, oTxsSession, oTestVm):
321 """
322 Test guest properties.
323 """
324 _ = oSession; _ = oTxsSession; _ = oTestVm;
325 return True;
326
327if __name__ == '__main__':
328 sys.exit(tdAddBasic1().main(sys.argv));
329
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