VirtualBox

Changeset 56688 in vbox


Ignore:
Timestamp:
Jun 29, 2015 8:07:38 PM (10 years ago)
Author:
vboxsync
Message:

tdAddGuestCtrl.py: Fixed up the session environment change test.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/ValidationKit/tests/additions/tdAddGuestCtrl.py

    r56687 r56688  
    9191    Provides credentials to pass to the guest.
    9292    """
    93     def __init__(self, sUser, sPassword, sDomain):
    94         self.sUser = sUser;
    95         self.sPassword = sPassword;
    96         self.sDomain = sDomain;
     93    def __init__(self, sUser = None, sPassword = None, sDomain = None, oTestVm = None):
     94        # If no user is specified, select the default user and
     95        # password for the given test VM.
     96        if sUser is None:
     97            assert sPassword is None;
     98            assert sDomain is None;
     99            assert oTestVm is not None;
     100
     101            ## @todo fix this so all VMs have several usable test users with the same passwords (or none).
     102            sUser     = 'test';
     103            sPassword = 'password';
     104            if oTestVm.isWindows():
     105                #sPassword = ''; # stupid config mistake.
     106                sPassword = 'password';
     107                sUser     = 'Administrator';
     108            sDomain   = '';
     109
     110        self.sUser     = sUser;
     111        self.sPassword = sPassword if sPassword is not None else '';
     112        self.sDomain   = sDomain if sDomain is not None else '';
    97113
    98114class tdTestGuestCtrlBase(object):
     
    137153
    138154            try:
    139                 reporter.log('Waiting for session "%s" to start within %ldms...' % (sName, self.timeoutMS));
     155                reporter.log('Waiting for session "%s" to start within %dms...' % (sName, self.timeoutMS));
    140156                fWaitFor = [ vboxcon.GuestSessionWaitForFlag_Start ];
    141157                waitResult = self.oGuestSession.waitForArray(fWaitFor, self.timeoutMS);
     
    147163                    and waitResult != vboxcon.GuestSessionWaitResult_WaitFlagNotSupported:
    148164                    # Just log, don't assume an error here (will be done in the main loop then).
    149                     reporter.log('Session did not start successfully, returned wait result: %ld' \
    150                                   % (waitResult));
     165                    reporter.log('Session did not start successfully, returned wait result: %d' \
     166                                  % (waitResult,));
    151167                    return (False, None);
    152168                reporter.log('Session "%s" successfully started' % (sName,));
    153169            except:
    154170                # Just log, don't assume an error here (will be done in the main loop then).
    155                 reporter.logXcpt('Waiting for guest session "%s" to start failed:' % (sName));
     171                reporter.logXcpt('Waiting for guest session "%s" (usr=%s;pw=%s;dom=%s) to start failed:'
     172                                 % (sName, self.oCreds.sUser, self.oCreds.sPassword, self.oCreds.sDomain,));
    156173                return (False, None);
    157174        else:
     
    382399        return len(aoSession);
    383400
    384 class tdTestSessionEnv(tdTestGuestCtrlBase):
    385     """
    386     Test the guest session environment.
    387     """
    388     def __init__(self, sUser = "", sPassword = "", aEnv = None):
     401class tdTestSessionEx(tdTestGuestCtrlBase):
     402    """
     403    Test the guest session.
     404    """
     405    def __init__(self, aoSteps = None, enmUser = None):
    389406        tdTestGuestCtrlBase.__init__(self);
    390         self.oCreds = tdCtxCreds(sUser, sPassword, sDomain = "");
    391         self.aEnv = aEnv or [];
     407        assert enmUser == None; # For later.
     408        self.enmUser = enmUser;
     409        self.aoSteps = aoSteps if aoSteps is not None else [];
     410
     411    def execute(self, oTstDrv, oVmSession, oTxsSession, oTestVm, sMsgPrefix):
     412        """
     413        Executes the test.
     414        """
     415        #
     416        # Create a session.
     417        #
     418        assert self.enmUser == None; # For later.
     419        self.oCreds = tdCtxCreds(oTestVm = oTestVm);
     420        self.setEnvironment(oVmSession, oTxsSession, oTestVm);
     421        reporter.log2('%s: %s steps' % (sMsgPrefix, len(self.aoSteps),));
     422        fRc, oCurSession = self.createSession(sMsgPrefix);
     423        if fRc is True:
     424            #
     425            # Execute the tests.
     426            #
     427            try:
     428                fRc = self.executeSteps(oTstDrv, oCurSession, sMsgPrefix);
     429            except:
     430                reporter.errorXcpt('%s: Unexpected exception executing test steps' % (sMsgPrefix,));
     431                fRc = False;
     432
     433            fRc2 = self.closeSession();
     434            if fRc2 is False:
     435                reporter.error('%s: Session could not be closed' % (sMsgPrefix,));
     436                fRc = False;
     437        else:
     438            reporter.error('%s: Session creation failed' % (sMsgPrefix,));
     439            fRc = False;
     440        return fRc;
     441
     442    def executeSteps(self, oTstDrv, oGstCtrlSession, sMsgPrefix):
     443        """
     444        Executes just the steps.
     445        Returns True on success, False on test failure.
     446        """
     447        fRc = True;
     448        for (i, oStep) in enumerate(self.aoSteps):
     449            fRc2 = oStep.execute(oTstDrv, oGstCtrlSession, sMsgPrefix + ', step #%d' % i);
     450            if fRc2 is False:
     451                fRc = False;
     452        return fRc;
     453
     454
     455#
     456# Scheduling Environment Changes with the Guest Control Session.
     457#
     458
     459class tdStepSessionSetEnv(object):
     460    """
     461    Guest session environment: schedule putenv
     462    """
     463    def __init__(self, sVar, sValue, hrcExpected = 0):
     464        self.sVar        = sVar;
     465        self.sValue      = sValue;
     466        self.hrcExpected = hrcExpected;
     467
     468    def execute(self, oTstDrv, oGstCtrlSession, sMsgPrefix):
     469        """
     470        Executes the step.
     471        Returns True on success, False on test failure.
     472        """
     473        reporter.log2('tdStepSessionSetEnv: sVar=%s sValue=%s hrcExpected=%#x' % (self.sVar, self.sValue, self.hrcExpected,));
     474        try:
     475            if oTstDrv.fpApiVer >= 5.0:
     476                oGstCtrlSession.environmentScheduleSet(self.sVar, self.sValue);
     477            else:
     478                oGstCtrlSession.environmentSet(self.sVar, self.sValue);
     479        except vbox.ComException, oXcpt:
     480            # Is this an expected failure?
     481            if vbox.ComError.equal(oXcpt, self.hrcExpected):
     482                return True;
     483            reporter.errorXcpt('%s: Expected hrc=%#x (%s) got %#x (%s) instead (setenv %s=%s)'
     484                               % (sMsgPrefix, self.hrcExpected, vbox.ComError.toString(self.hrcExpected),
     485                                  vbox.ComError.getXcptResult(oXcpt),
     486                                  vbox.ComError.toString(vbox.ComError.getXcptResult(oXcpt)),
     487                                  self.sVar, self.sValue,));
     488            return False;
     489        except:
     490            reporter.errorXcpt('%s: Unexpected exception in tdStepSessionSetEnv::execute (%s=%s)'
     491                               % (sMsgPrefix, self.sVar, self.sValue,));
     492            return False;
     493
     494        # Should we succeed?
     495        if self.hrcExpected != 0:
     496            reporter.error('%s: Expected hrcExpected=%#x, got S_OK (putenv %s=%s)'
     497                           % (sMsgPrefix, self.hrcExpected, self.sVar, self.sValue,));
     498            return False;
     499        return True;
     500
     501class tdStepSessionUnsetEnv(object):
     502    """
     503    Guest session environment: schedule unset.
     504    """
     505    def __init__(self, sVar, hrcExpected = 0):
     506        self.sVar        = sVar;
     507        self.hrcExpected = hrcExpected;
     508
     509    def execute(self, oTstDrv, oGstCtrlSession, sMsgPrefix):
     510        """
     511        Executes the step.
     512        Returns True on success, False on test failure.
     513        """
     514        reporter.log2('tdStepSessionUnsetEnv: sVar=%s hrcExpected=%#x' % (self.sVar, self.hrcExpected,));
     515        try:
     516            if oTstDrv.fpApiVer >= 5.0:
     517                oGstCtrlSession.environmentScheduleUnset(self.sVar);
     518            else:
     519                oGstCtrlSession.environmentUnset(self.sVar);
     520        except vbox.ComException, oXcpt:
     521            # Is this an expected failure?
     522            if vbox.ComError.equal(oXcpt, self.hrcExpected):
     523                return True;
     524            reporter.errorXcpt('%s: Expected hrc=%#x (%s) got %#x (%s) instead (unsetenv %s)'
     525                               % (sMsgPrefix, self.hrcExpected, vbox.ComError.toString(self.hrcExpected),
     526                                  vbox.ComError.getXcptResult(oXcpt),
     527                                  vbox.ComError.toString(vbox.ComError.getXcptResult(oXcpt)),
     528                                  self.sVar,));
     529            return False;
     530        except:
     531            reporter.errorXcpt('%s: Unexpected exception in tdStepSessionUnsetEnv::execute (%s)'
     532                               % (sMsgPrefix, self.sVar,));
     533            return False;
     534
     535        # Should we succeed?
     536        if self.hrcExpected != 0:
     537            reporter.error('%s: Expected hrcExpected=%#x, got S_OK (unsetenv %s)'
     538                           % (sMsgPrefix, self.hrcExpected, self.sVar,));
     539            return False;
     540        return True;
     541
     542class tdStepSessionBulkEnv(object):
     543    """
     544    Guest session environment: Bulk environment changes.
     545    """
     546    def __init__(self, asEnv = None, hrcExpected = 0):
     547        self.asEnv = asEnv if asEnv is not None else [];
     548        self.hrcExpected = hrcExpected;
     549
     550    def execute(self, oTstDrv, oGstCtrlSession, sMsgPrefix):
     551        """
     552        Executes the step.
     553        Returns True on success, False on test failure.
     554        """
     555        reporter.log2('tdStepSessionBulkEnv: asEnv=%s hrcExpected=%#x' % (self.asEnv, self.hrcExpected,));
     556        try:
     557            if oTstDrv.fpApiVer >= 5.0:
     558                oTstDrv.oVBoxMgr.setArray(oGstCtrlSession, 'environmentChanges', self.asEnv);
     559            else:
     560                oTstDrv.oVBoxMgr.setArray(oGstCtrlSession, 'environment', self.asEnv);
     561        except vbox.ComException, oXcpt:
     562            # Is this an expected failure?
     563            if vbox.ComError.equal(oXcpt, self.hrcExpected):
     564                return True;
     565            reporter.errorXcpt('%s: Expected hrc=%#x (%s) got %#x (%s) instead (asEnv=%s)'
     566                               % (sMsgPrefix, self.hrcExpected, vbox.ComError.toString(self.hrcExpected),
     567                                  vbox.ComError.getXcptResult(oXcpt),
     568                                  vbox.ComError.toString(vbox.ComError.getXcptResult(oXcpt)),
     569                                  self.asEnv,));
     570            return False;
     571        except:
     572            reporter.errorXcpt('%s: Unexpected exception writing the environmentChanges property (asEnv=%s).'
     573                               % (sMsgPrefix, self.asEnv));
     574            return False;
     575        return True;
     576
     577class tdStepSessionClearEnv(tdStepSessionBulkEnv):
     578    """
     579    Guest session environment: clears the scheduled environment changes.
     580    """
     581    def __init__(self):
     582        tdStepSessionBulkEnv.__init__(self);
     583
     584
     585class tdStepSessionCheckEnv(object):
     586    """
     587    Check the currently scheduled environment changes of a guest control session.
     588    """
     589    def __init__(self, asEnv = None):
     590        self.asEnv = asEnv if asEnv is not None else [];
     591
     592    def execute(self, oTstDrv, oGstCtrlSession, sMsgPrefix):
     593        """
     594        Executes the step.
     595        Returns True on success, False on test failure.
     596        """
     597        reporter.log2('tdStepSessionCheckEnv: asEnv=%s' % (self.asEnv,));
     598
     599        #
     600        # Get the environment change list.
     601        #
     602        try:
     603            if oTstDrv.fpApiVer >= 5.0:
     604                asCurEnv = oTstDrv.oVBoxMgr.getArray(oGstCtrlSession, 'environmentChanges');
     605            else:
     606                asCurEnv = oTstDrv.oVBoxMgr.getArray(oGstCtrlSession, 'environment');
     607        except:
     608            reporter.errorXcpt('%s: Unexpected exception reading the environmentChanges property.' % (sMsgPrefix,));
     609            return False;
     610
     611        #
     612        # Compare it with the expected one by trying to remove each expected value
     613        # and the list anything unexpected.
     614        #
     615        fRc = True;
     616        asCopy = list(asCurEnv); # just in case asCurEnv is immutable
     617        for sExpected in self.asEnv:
     618            try:
     619                asCopy.remove(sExpected);
     620            except:
     621                reporter.error('%s: Expected "%s" to be in the resulting environment' % (sMsgPrefix, sExpected,));
     622                fRc = False;
     623        for sUnexpected in asCopy:
     624            reporter.error('%d: Unexpected "%s" in the resulting environment' % (sMsgPrefix, sUnexpected,));
     625            fRc = False;
     626
     627        if fRc is not True:
     628            reporter.log2('%s: Current environment: %s' % (sMsgPrefix, asCurEnv));
     629        return fRc;
     630
     631#
     632#
     633#
    392634
    393635class tdTestSessionFileRefs(tdTestGuestCtrlBase):
     
    496738        tdTestResult.__init__(self, fRc = fRc);
    497739        self.cNumSessions = cNumSessions;
    498 
    499 class tdTestResultSessionEnv(tdTestResult):
    500     """
    501     Test result for guest session environment tests.
    502     """
    503     def __init__(self, fRc = False, cNumVars = 0):
    504         tdTestResult.__init__(self, fRc = fRc);
    505         self.cNumVars = cNumVars;
    506 
    507740
    508741class SubTstDrvAddGuestCtrl(base.SubTestDriverBase):
     
    9821215                if     oTest.uExitStatus != oRes.uExitStatus \
    9831216                    or oTest.iExitCode   != oRes.iExitCode:
    984                     reporter.error('Test #%d failed: Got exit status + code %d,%d, expected %d,%d' % \
    985                                    (i, oTest.uExitStatus, oTest.iExitCode, \
    986                                        oRes.uExitStatus,  oRes.iExitCode));
     1217                    reporter.error('Test #%d failed: Got exit status + code %d,%d, expected %d,%d'
     1218                                   % (i, oTest.uExitStatus, oTest.iExitCode, oRes.uExitStatus,  oRes.iExitCode));
    9871219                    return False;
    9881220            if fRc is True:
     
    9911223                    and oRes.sBuf is not None:
    9921224                    if bytes(oTest.sBuf) != bytes(oRes.sBuf):
    993                         reporter.error('Test #%d failed: Got buffer\n%s (%ld bytes), expected\n%s (%ld bytes)' %
    994                                        (i, map(hex, map(ord, oTest.sBuf)), len(oTest.sBuf), \
    995                                            map(hex, map(ord, oRes.sBuf)), len(oRes.sBuf)));
     1225                        reporter.error('Test #%d failed: Got buffer\n%s (%d bytes), expected\n%s (%d bytes)'
     1226                                       % (i, map(hex, map(ord, oTest.sBuf)), len(oTest.sBuf), \
     1227                                          map(hex, map(ord, oRes.sBuf)), len(oRes.sBuf)));
    9961228                        return False;
    9971229                    else:
    998                         reporter.log2('Test #%d passed: Buffers match (%ld bytes)' % (i, len(oRes.sBuf)));
     1230                        reporter.log2('Test #%d passed: Buffers match (%d bytes)' % (i, len(oRes.sBuf)));
    9991231                elif     oRes.sBuf is not None \
    10001232                     and len(oRes.sBuf):
     
    10041236                elif     oRes.cbStdOut > 0 \
    10051237                     and oRes.cbStdOut != oTest.cbStdOut:
    1006                     reporter.error('Test #%d failed: Got %ld stdout data, expected %ld'
     1238                    reporter.error('Test #%d failed: Got %d stdout data, expected %d'
    10071239                                   % (i, oTest.cbStdOut, oRes.cbStdOut));
    10081240                    return False;
     
    10221254        #tsStart = base.timestampMilli();
    10231255
    1024         reporter.log2('Using session user=%s, sDomain=%s, session name=%s, session timeout=%ld' \
     1256        reporter.log2('Using session user=%s, sDomain=%s, session name=%s, session timeout=%d' \
    10251257                      % (oGuestSession.user, oGuestSession.domain, \
    10261258                         oGuestSession.name, oGuestSession.timeout));
    1027         reporter.log2('Executing cmd=%s, aFlags=%s, timeout=%ld, args=%s, env=%s' \
     1259        reporter.log2('Executing cmd=%s, aFlags=%s, timeout=%d, args=%s, env=%s' \
    10281260                      % (oTest.sCmd, oTest.aFlags, oTest.timeoutMS, \
    10291261                         oTest.aArgs, oTest.aEnv));
     
    10331265                                                  oTest.aEnv, oTest.aFlags, oTest.timeoutMS);
    10341266            if curProc is not None:
    1035                 reporter.log2('Process start requested, waiting for start (%ldms) ...' % (oTest.timeoutMS,));
     1267                reporter.log2('Process start requested, waiting for start (%dms) ...' % (oTest.timeoutMS,));
    10361268                fWaitFor = [ vboxcon.ProcessWaitForFlag_Start ];
    10371269                waitResult = curProc.waitForArray(fWaitFor, oTest.timeoutMS);
    1038                 reporter.log2('Wait result returned: %d, current process status is: %ld' % (waitResult, curProc.status));
     1270                reporter.log2('Wait result returned: %d, current process status is: %d' % (waitResult, curProc.status));
    10391271
    10401272                if curProc.status == vboxcon.ProcessStatus_Started:
     
    10451277                        fWaitFor.append(vboxcon.ProcessWaitForFlag_StdErr);
    10461278                    ## @todo Add vboxcon.ProcessWaitForFlag_StdIn.
    1047                     reporter.log2('Process (PID %ld) started, waiting for termination (%dms), waitFlags=%s ...' \
     1279                    reporter.log2('Process (PID %d) started, waiting for termination (%dms), waitFlags=%s ...' \
    10481280                                  % (curProc.PID, oTest.timeoutMS, fWaitFor));
    10491281                    while True:
     
    10571289                                buf = curProc.Read(1, 64 * 1024, oTest.timeoutMS);
    10581290                                if len(buf):
    1059                                     reporter.log2('Process (PID %ld) got %ld bytes of stdout data' % (curProc.PID, len(buf)));
     1291                                    reporter.log2('Process (PID %d) got %d bytes of stdout data' % (curProc.PID, len(buf)));
    10601292                                    oTest.cbStdOut += len(buf);
    10611293                                    oTest.sBuf = buf; # Appending does *not* work atm, so just assign it. No time now.
     
    10661298                                buf = curProc.Read(2, 64 * 1024, oTest.timeoutMS);
    10671299                                if len(buf):
    1068                                     reporter.log2('Process (PID %ld) got %ld bytes of stderr data' % (curProc.PID, len(buf)));
     1300                                    reporter.log2('Process (PID %d) got %d bytes of stderr data' % (curProc.PID, len(buf)));
    10691301                                    oTest.cbStdErr += len(buf);
    10701302                                    oTest.sBuf = buf; # Appending does *not* work atm, so just assign it. No time now.
     
    10721304                            if     waitResult == vboxcon.ProcessWaitResult_StdIn \
    10731305                                or waitResult == vboxcon.ProcessWaitResult_WaitFlagNotSupported:
    1074                                 pass; #reporter.log2('Process (PID %ld) needs stdin data' % (curProc.pid,));
     1306                                pass; #reporter.log2('Process (PID %d) needs stdin data' % (curProc.pid,));
    10751307                            # Termination or error?
    10761308                            if     waitResult == vboxcon.ProcessWaitResult_Terminate \
    10771309                                or waitResult == vboxcon.ProcessWaitResult_Error \
    10781310                                or waitResult == vboxcon.ProcessWaitResult_Timeout:
    1079                                 reporter.log2('Process (PID %ld) reported terminate/error/timeout: %ld, status: %ld' \
     1311                                reporter.log2('Process (PID %d) reported terminate/error/timeout: %d, status: %d' \
    10801312                                              % (curProc.PID, waitResult, curProc.status));
    10811313                                break;
     
    10831315                            # Just skip reads which returned nothing.
    10841316                            pass;
    1085                     reporter.log2('Final process status (PID %ld) is: %ld' % (curProc.PID, curProc.status));
    1086                     reporter.log2('Process (PID %ld) %ld stdout, %ld stderr' % (curProc.PID, oTest.cbStdOut, oTest.cbStdErr));
     1317                    reporter.log2('Final process status (PID %d) is: %d' % (curProc.PID, curProc.status));
     1318                    reporter.log2('Process (PID %d) %d stdout, %d stderr' % (curProc.PID, oTest.cbStdOut, oTest.cbStdErr));
    10871319            oTest.uExitStatus = curProc.status;
    10881320            oTest.iExitCode = curProc.exitCode;
    1089             reporter.log2('Process (PID %ld) has exit code: %ld' % (curProc.PID, oTest.iExitCode));
     1321            reporter.log2('Process (PID %d) has exit code: %d' % (curProc.PID, oTest.iExitCode));
    10901322        except KeyboardInterrupt:
    1091             reporter.error('Process (PID %ld) execution interrupted' % (curProc.PID,));
     1323            reporter.error('Process (PID %d) execution interrupted' % (curProc.PID,));
    10921324            if curProc is not None:
    10931325                curProc.close();
     
    11041336        """
    11051337
    1106         if oTestVm.isWindows():
    1107             sUser = "Administrator";
    1108         else:
    1109             sUser = "vbox";
    1110         sPassword = "password";
    1111 
    11121338        aaTests = [
    1113             # No environment set.
    1114             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword),
    1115               tdTestResultSessionEnv(fRc = False) ],
    1116             # Invalid stuff.
    1117             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ '=FOO' ]),
    1118               tdTestResultSessionEnv(fRc = False) ],
    1119             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ '====' ]),
    1120               tdTestResultSessionEnv(fRc = False) ],
    1121             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ '=BAR' ]),
    1122               tdTestResultSessionEnv(fRc = False) ],
    1123             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ u'ß$%ß&' ]),
    1124               tdTestResultSessionEnv(fRc = False) ],
    1125             # Key only.
    1126             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ 'FOO=' ]),
    1127               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ],
    1128             # Values.
    1129             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ 'FOO' ]),
    1130               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ],
    1131             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ 'FOO=BAR' ]),
    1132               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ],
    1133             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ 'FOO=BAR', 'BAR=BAZ' ]),
    1134               tdTestResultSessionEnv(fRc = True, cNumVars = 2) ],
     1339            # Check basic operations.
     1340            tdTestSessionEx([ # Initial environment is empty.
     1341                              tdStepSessionCheckEnv(),
     1342                              # Check clearing empty env.
     1343                              tdStepSessionClearEnv(),
     1344                              tdStepSessionCheckEnv(),
     1345                              # Check set.
     1346                              tdStepSessionSetEnv('FOO', 'BAR'),
     1347                              tdStepSessionCheckEnv(['FOO=BAR',]),
     1348                              tdStepSessionClearEnv(),
     1349                              tdStepSessionCheckEnv(),
     1350                              # Check unset.
     1351                              tdStepSessionUnsetEnv('BAR'),
     1352                              tdStepSessionCheckEnv(['BAR']),
     1353                              tdStepSessionClearEnv(),
     1354                              tdStepSessionCheckEnv(),
     1355                              # Set + unset.
     1356                              tdStepSessionSetEnv('FOO', 'BAR'),
     1357                              tdStepSessionCheckEnv(['FOO=BAR',]),
     1358                              tdStepSessionUnsetEnv('FOO'),
     1359                              tdStepSessionCheckEnv(['FOO']),
     1360                              # Bulk environment changes (via attrib) (shall replace existing 'FOO').
     1361                              tdStepSessionBulkEnv( ['PATH=/bin:/usr/bin', 'TMPDIR=/var/tmp', 'USER=root']),
     1362                              tdStepSessionCheckEnv(['PATH=/bin:/usr/bin', 'TMPDIR=/var/tmp', 'USER=root']),
     1363                              ]),
     1364            tdTestSessionEx([ # Check that setting the same value several times works.
     1365                              tdStepSessionSetEnv('FOO','BAR'),
     1366                              tdStepSessionCheckEnv([ 'FOO=BAR',]),
     1367                              tdStepSessionSetEnv('FOO','BAR2'),
     1368                              tdStepSessionCheckEnv([ 'FOO=BAR2',]),
     1369                              tdStepSessionSetEnv('FOO','BAR3'),
     1370                              tdStepSessionCheckEnv([ 'FOO=BAR3',]),
     1371                              # Add a little unsetting to the mix.
     1372                              tdStepSessionSetEnv('BAR', 'BEAR'),
     1373                              tdStepSessionCheckEnv([ 'FOO=BAR3', 'BAR=BEAR',]),
     1374                              tdStepSessionUnsetEnv('FOO'),
     1375                              tdStepSessionCheckEnv([ 'FOO', 'BAR=BEAR',]),
     1376                              tdStepSessionSetEnv('FOO','BAR4'),
     1377                              tdStepSessionCheckEnv([ 'FOO=BAR4', 'BAR=BEAR',]),
     1378                              # The environment is case sensitive.
     1379                              tdStepSessionSetEnv('foo','BAR5'),
     1380                              tdStepSessionCheckEnv([ 'FOO=BAR4', 'BAR=BEAR', 'foo=BAR5']),
     1381                              tdStepSessionUnsetEnv('foo'),
     1382                              tdStepSessionCheckEnv([ 'FOO=BAR4', 'BAR=BEAR', 'foo']),
     1383                              ]),
     1384            tdTestSessionEx([ # Bulk settings merges stuff, last entry standing.
     1385                              tdStepSessionBulkEnv(['FOO=bar', 'foo=bar', 'FOO=doofus', 'TMPDIR=/tmp', 'foo=bar2']),
     1386                              tdStepSessionCheckEnv(['FOO=doofus', 'TMPDIR=/tmp', 'foo=bar2']),
     1387                              ]),
     1388            # Invalid variable names.
     1389            tdTestSessionEx([ tdStepSessionSetEnv('', 'FOO', vbox.ComError.E_INVALIDARG),
     1390                              tdStepSessionCheckEnv(),
     1391                              tdStepSessionSetEnv('=', '===', vbox.ComError.E_INVALIDARG),
     1392                              tdStepSessionCheckEnv(),
     1393                              tdStepSessionSetEnv('FOO=', 'BAR', vbox.ComError.E_INVALIDARG),
     1394                              tdStepSessionCheckEnv(),
     1395                              tdStepSessionSetEnv('=FOO', 'BAR', vbox.ComError.E_INVALIDARG),
     1396                              tdStepSessionCheckEnv(),
     1397                              tdStepSessionBulkEnv(['=', 'foo=bar'], vbox.ComError.E_INVALIDARG),
     1398                              tdStepSessionCheckEnv(),
     1399                              tdStepSessionBulkEnv(['=FOO', 'foo=bar'], vbox.ComError.E_INVALIDARG),
     1400                              tdStepSessionCheckEnv(),
     1401                              ]),
    11351402            # A bit more weird keys/values.
    1136             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ '$$$=' ]),
    1137               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ],
    1138             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ '$$$=%%%' ]),
    1139               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ],
    1140             # Same stuff.
    1141             [ tdTestSessionEnv(sUser = sUser, sPassword = sPassword, aEnv = [ 'FOO=BAR', 'FOO=BAR' ]),
    1142               tdTestResultSessionEnv(fRc = True, cNumVars = 1) ]
     1403            tdTestSessionEx([ tdStepSessionSetEnv('$$$', ''),
     1404                              tdStepSessionCheckEnv([ '$$$=',]), ]),
     1405            tdTestSessionEx([ tdStepSessionSetEnv('$$$', '%%%'),
     1406                              tdStepSessionCheckEnv([ '$$$=%%%',]),
     1407                              ]),
     1408            tdTestSessionEx([ tdStepSessionSetEnv(u'ß$%ß&', ''),
     1409                              tdStepSessionCheckEnv([ u'ß$%ß&=',]),
     1410                              ]),
     1411            # Misc stuff.
     1412            tdTestSessionEx([ tdStepSessionSetEnv('FOO', ''),
     1413                              tdStepSessionCheckEnv(['FOO=',]),
     1414                              ]),
     1415            tdTestSessionEx([ tdStepSessionSetEnv('FOO', 'BAR'),
     1416                              tdStepSessionCheckEnv(['FOO=BAR',])
     1417                              ],),
     1418            tdTestSessionEx([ tdStepSessionSetEnv('FOO', 'BAR'),
     1419                              tdStepSessionSetEnv('BAR', 'BAZ'),
     1420                              tdStepSessionCheckEnv([ 'FOO=BAR', 'BAR=BAZ',]),
     1421                              ]),
    11431422        ];
    11441423
    1145         # The IGuestSession::environment attribute changed late in 5.0 development.
    1146         sEnvironmentChangesAttr = 'environmentChanges' if self.oTstDrv.fpApiVer >= 5.0 else 'environment';
    1147 
    1148         # Parameters.
     1424        #
     1425        # Work through the tests.
     1426        #
    11491427        fRc = True;
    1150         for (i, aTest) in enumerate(aaTests):
    1151             curTest = aTest[0]; # tdTestExec, use an index, later.
    1152             curRes  = aTest[1]; # tdTestResult
    1153             curTest.setEnvironment(oSession, oTxsSession, oTestVm);
    1154             reporter.log('Testing #%d, user="%s", sPassword="%s", env="%s" (%d)...' \
    1155                          % (i, curTest.oCreds.sUser, curTest.oCreds.sPassword, curTest.aEnv, len(curTest.aEnv)));
    1156             curGuestSessionName = 'testGuestCtrlSessionEnvironment: Test #%d' % (i,);
    1157             fRc2, curGuestSession = curTest.createSession(curGuestSessionName);
    1158             if fRc2 is not True:
    1159                 reporter.error('Test #%d failed: Session creation failed: Got %s, expected True' % (i, fRc2));
     1428        for (i, oCurTest) in enumerate(aaTests):
     1429            try:
     1430                fRc2 = oCurTest.execute(self.oTstDrv, oSession, oTxsSession, oTestVm, 'test %#d' % (i,));
     1431                if fRc2 is not True:
     1432                    fRc = False;
     1433            except:
     1434                reporter.errorXcpt('Unexpected exception executing test #%d' % (i,));
    11601435                fRc = False;
    1161                 break;
    1162             # Make sure environment is empty.
    1163             curEnv = self.oTstDrv.oVBoxMgr.getArray(curGuestSession, sEnvironmentChangesAttr);
    1164             reporter.log2('Test #%d: Environment initially has %d elements' % (i, len(curEnv)));
    1165             if len(curEnv) != 0:
    1166                 reporter.error('Test #%d failed: Initial session environment has %d vars, expected 0' % (i, len(curEnv)));
    1167                 fRc = False;
    1168                 break;
    1169             try:
    1170                 for (_, aEnv) in enumerate(curTest.aEnv):
    1171                     aElems = aEnv.split('=');
    1172                     strKey = '';  ## @todo s/Key/Var/g
    1173                     strValue = '';
    1174                     if len(aElems) > 0:
    1175                         strKey = aElems[0];
    1176                     if len(aElems) == 2:
    1177                         strValue = aElems[1];
    1178                     reporter.log2('Test #%d: Single var="%s", value="%s" (%d) ...' \
    1179                                   % (i, strKey, strValue, len(aElems)));
    1180                     try:
    1181                         if self.oTstDrv.fpApiVer >= 5.0:
    1182                             curGuestSession.environmentScheduleSet(strKey, strValue);
    1183                         else:
    1184                             curGuestSession.environmentSet(strKey, strValue);
    1185                     except:
    1186                         # Setting environment variables might fail (e.g. if empty name specified). Check.
    1187                         reporter.logXcpt('Test #%d failed: Setting environment variable failed:' % (i,));
    1188                         curEnv = self.oTstDrv.oVBoxMgr.getArray(curGuestSession, sEnvironmentChangesAttr);
    1189                         if len(curEnv) is not curRes.cNumVars:
    1190                             reporter.error('Test #%d failed: Session environment has %d vars, expected %d' \
    1191                                            % (i, len(curEnv), curRes.cNumVars));
    1192                             fRc = False;
    1193                             break;
    1194                         else:
    1195                             reporter.log('Test #%d: API reported an error (single), good' % (i,));
    1196                     ## @todo environmentGet() has been removed in 5.0 because it's not up to the task of returning all the
    1197                     ## putenv strings forms and gives the impression that the environment is something it isn't. This test
    1198                     ## should be rewritten using the attribute.  What's more, there should be an Unset test here, shouldn't
    1199                     ## there?
    1200                     #
    1201                     #reporter.log2('Getting key="%s" ...' % (strKey,));
    1202                     #try:
    1203                     #    strValue2 = curGuestSession.environmentGet(strKey);
    1204                     #    if      strKey.isalnum() \
    1205                     #        and strValue != strValue2:
    1206                     #        reporter.error('Test #%d failed: Got environment value "%s", expected "%s" (var: "%s")' \
    1207                     #                       % (i, strValue2, strValue, strKey));
    1208                     #        fRc = False;
    1209                     #        break;
    1210                     #    # Getting back an empty value when specifying an invalid key is fine.
    1211                     #    reporter.log2('Got key "%s=%s"' % (strKey, strValue2));
    1212                     #except UnicodeDecodeError: # Might happen on unusal values, fine.
    1213                     #    if strValue != strValue2:
    1214                     #        reporter.error('Test #%d failed: Got (undecoded) environment variable "%s", ' \
    1215                     #                       'expected "%s" (var: "%s")' \
    1216                     #                       % (i, strValue2, strValue, strKey));
    1217                     #        fRc = False;
    1218                     #        break;
    1219                     #except:
    1220                     #    if     strKey == "" \
    1221                     #        or not strKey.isalnum():
    1222                     #        reporter.log('Test #%d: API reported an error (invalid key "%s"), good' % (i, strKey));
    1223                     #    else:
    1224                     #        reporter.errorXcpt('Test #%d failed: Getting environment variable:' % (i));
    1225                 if fRc is False:
    1226                     continue;
    1227                 # Set the same stuff again, this time all at once using the array.
    1228                 if len(curTest.aEnv):
    1229                     reporter.log('Test #%d: Array %s (%d)' % (i, curTest.aEnv, len(curTest.aEnv)));
    1230                     try:
    1231                         ## @todo No return (e.g. boolean) value available thru wrapper.
    1232                         #curGuestSession.environmentSetArray(curTest.aEnv);
    1233                         pass;
    1234                     except:
    1235                         # Setting environment variables might fail (e.g. if empty name specified). Check.
    1236                         curEnv = self.oTstDrv.oVBoxMgr.getArray(curGuestSession, sEnvironmentChangesAttr);
    1237                         if len(curEnv) is not curRes.cNumVars:
    1238                             reporter.error('Test #%d failed: Session environment has %d vars, expected %d (array)' \
    1239                                            % (i, len(curEnv), curRes.cNumVars));
    1240                             fRc = False;
    1241                             break;
    1242                         else:
    1243                             reporter.log('Test #%d: API reported an error (array), good' % (i,));
    1244                 ## @todo Get current system environment and add it to curRes.cNumVars before comparing!
    1245                 reporter.log('Test #%d: Environment size' % (i,));
    1246                 curEnv = self.oTstDrv.oVBoxMgr.getArray(curGuestSession, sEnvironmentChangesAttr);
    1247                 reporter.log2('Test #%d: Environment (%d) -> %s' % (i, len(curEnv), curEnv));
    1248                 if len(curEnv) != curRes.cNumVars:
    1249                     reporter.error('Test #%d failed: Session environment has %d vars (%s), expected %d' \
    1250                                    % (i, len(curEnv), curEnv, curRes.cNumVars));
    1251                     fRc = False;
    1252                     break;
    1253 
    1254                 self.oTstDrv.oVBoxMgr.setArray(curGuestSession, sEnvironmentChangesAttr, []);
    1255                 curEnv = self.oTstDrv.oVBoxMgr.getArray(curGuestSession, sEnvironmentChangesAttr);
    1256                 if len(curEnv) is not 0:
    1257                     reporter.error('Test #%d failed: Session environment has %d vars, expected 0');
    1258                     fRc = False;
    1259                     break;
    1260             except:
    1261                 reporter.errorXcpt('Test #%d failed:' % (i,));
    1262 
    1263             fRc2 = curTest.closeSession();
    1264             if fRc2 is False:
    1265                 reporter.error('Test #%d failed: Session could not be closed' % (i,));
    1266                 fRc = False;
    1267                 break;
    12681436
    12691437        return (fRc, oTxsSession);
     
    13921560
    13931561        try:
     1562            # r=bird: multiSession[0].oGuestSession is None! Why don't you just use 'assert' or 'if' to check
     1563            #         the functioning of the __testcase__?
     1564
    13941565            # Make sure that accessing the first opened guest session does not work anymore because we just removed (closed) it.
    13951566            curSessionName = multiSession[0].oGuestSession.name;
     
    14441615                and waitResult != vboxcon.GuestSessionWaitResult_WaitFlagNotSupported:
    14451616                # Just log, don't assume an error here (will be done in the main loop then).
    1446                 reporter.log('Session did not start successfully, returned wait result: %ld' \
     1617                reporter.log('Session did not start successfully, returned wait result: %d' \
    14471618                              % (waitResult));
    14481619                return (False, oTxsSession);
     
    14641635                    #       do not support terminating guest processes.
    14651636                except:
    1466                     reporter.errorXcpt('Opening stale file #%ld failed:' % (i,));
     1637                    reporter.errorXcpt('Opening stale file #%d failed:' % (i,));
    14671638                    fRc = False;
    14681639                    break;
     
    14711642                cFiles = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'files'));
    14721643                if cFiles != cStaleFiles:
    1473                     reporter.error('Test failed: Got %ld stale files, expected %ld' % (cFiles, cStaleFiles));
     1644                    reporter.error('Test failed: Got %d stale files, expected %d' % (cFiles, cStaleFiles));
    14741645                    fRc = False;
    14751646
     
    14891660                        aaFiles.append(oCurFile);
    14901661                    except:
    1491                         reporter.errorXcpt('Opening non-stale file #%ld failed:' % (i,));
     1662                        reporter.errorXcpt('Opening non-stale file #%d failed:' % (i,));
    14921663                        fRc = False;
    14931664                        break;
     
    14951666                cFiles = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'files'));
    14961667                if cFiles != cStaleFiles * 2:
    1497                     reporter.error('Test failed: Got %ld total files, expected %ld' % (cFiles, cStaleFiles * 2));
     1668                    reporter.error('Test failed: Got %d total files, expected %d' % (cFiles, cStaleFiles * 2));
    14981669                    fRc = False;
    14991670            if fRc:
     
    15031674                        aaFiles[i].close();
    15041675                    except:
    1505                         reporter.errorXcpt('Waiting for non-stale file #%ld failed:' % (i,));
     1676                        reporter.errorXcpt('Waiting for non-stale file #%d failed:' % (i,));
    15061677                        fRc = False;
    15071678                        break;
     
    15111682                # a reference in aaFiles[] for).
    15121683                if cFiles != cStaleFiles:
    1513                     reporter.error('Test failed: Got %ld total files, expected %ld' \
     1684                    reporter.error('Test failed: Got %d total files, expected %d' \
    15141685                                   % (cFiles, cStaleFiles));
    15151686                    fRc = False;
     
    15231694                            curFilesStatus = aaFiles[i].status;
    15241695                            if curFilesStatus != vboxcon.FileStatus_Closed:
    1525                                 reporter.error('Test failed: Non-stale file #%ld has status %ld, expected %ld' \
     1696                                reporter.error('Test failed: Non-stale file #%d has status %d, expected %d' \
    15261697                                       % (i, curFilesStatus, vboxcon.FileStatus_Closed));
    15271698                                fRc = False;
    15281699                        except:
    1529                             reporter.errorXcpt('Checking status of file #%ld failed:' % (i,));
     1700                            reporter.errorXcpt('Checking status of file #%d failed:' % (i,));
    15301701                            fRc = False;
    15311702                            break;
     
    15331704                reporter.log2('All non-stale files closed');
    15341705            cFiles = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'files'));
    1535             reporter.log2('Final guest session file count: %ld' % (cFiles,));
     1706            reporter.log2('Final guest session file count: %d' % (cFiles,));
    15361707            # Now try to close the session and see what happens.
    15371708            reporter.log2('Closing guest session ...');
     
    15801751                and waitResult != vboxcon.GuestSessionWaitResult_WaitFlagNotSupported:
    15811752                # Just log, don't assume an error here (will be done in the main loop then).
    1582                 reporter.log('Session did not start successfully, returned wait result: %ld' \
     1753                reporter.log('Session did not start successfully, returned wait result: %d' \
    15831754                              % (waitResult));
    15841755                return (False, oTxsSession);
     
    16001771                    #       do not support terminating guest processes.
    16011772                except:
    1602                     reporter.logXcpt('Creating stale process #%ld failed:' % (i,));
     1773                    reporter.logXcpt('Creating stale process #%d failed:' % (i,));
    16031774                    fRc = False;
    16041775                    break;
     
    16071778                cProcs = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'processes'));
    16081779                if cProcs != cStaleProcs:
    1609                     reporter.error('Test failed: Got %ld stale processes, expected %ld' % (cProcs, cStaleProcs));
     1780                    reporter.error('Test failed: Got %d stale processes, expected %d' % (cProcs, cStaleProcs));
    16101781                    fRc = False;
    16111782
     
    16241795                        aaProcs.append(oCurProc);
    16251796                    except:
    1626                         reporter.logXcpt('Creating non-stale process #%ld failed:' % (i,));
     1797                        reporter.logXcpt('Creating non-stale process #%d failed:' % (i,));
    16271798                        fRc = False;
    16281799                        break;
     
    16341805                        curProcStatus = aaProcs[i].status;
    16351806                        if aaProcs[i].status != vboxcon.ProcessStatus_TerminatedNormally:
    1636                             reporter.error('Test failed: Waiting for non-stale processes #%ld'
    1637                                            ' resulted in status %ld, expected %ld' \
     1807                            reporter.error('Test failed: Waiting for non-stale processes #%d'
     1808                                           ' resulted in status %d, expected %d' \
    16381809                                   % (i, curProcStatus, vboxcon.ProcessStatus_TerminatedNormally));
    16391810                            fRc = False;
    16401811                    except:
    1641                         reporter.logXcpt('Waiting for non-stale process #%ld failed:' % (i,));
     1812                        reporter.logXcpt('Waiting for non-stale process #%d failed:' % (i,));
    16421813                        fRc = False;
    16431814                        break;
     
    16471818                # a reference in aaProcs[] for).
    16481819                if cProcs != (cStaleProcs * 2):
    1649                     reporter.error('Test failed: Got %ld total processes, expected %ld' \
     1820                    reporter.error('Test failed: Got %d total processes, expected %d' \
    16501821                                   % (cProcs, cStaleProcs));
    16511822                    fRc = False;
     
    16571828                        curProcStatus = aaProcs[i].status;
    16581829                        if aaProcs[i].status != vboxcon.ProcessStatus_TerminatedNormally:
    1659                             reporter.error('Test failed: Non-stale processes #%ld has status %ld, expected %ld' \
     1830                            reporter.error('Test failed: Non-stale processes #%d has status %d, expected %d' \
    16601831                                   % (i, curProcStatus, vboxcon.ProcessStatus_TerminatedNormally));
    16611832                            fRc = False;
     
    16891860                cProcs = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'processes'));
    16901861                if cProcs != (cStaleProcs * 2): # Still should be 20 processes because we terminated the 10 newest ones.
    1691                     reporter.error('Test failed: Got %ld total processes, expected %ld' % (cProcs, cStaleProcs * 2));
     1862                    reporter.error('Test failed: Got %d total processes, expected %d' % (cProcs, cStaleProcs * 2));
    16921863                    fRc = False;
    16931864            cProcs = len(self.oTstDrv.oVBoxMgr.getArray(oGuestSession, 'processes'));
    1694             reporter.log2('Final guest session processes count: %ld' % (cProcs,));
     1865            reporter.log2('Final guest session processes count: %d' % (cProcs,));
    16951866            # Now try to close the session and see what happens.
    16961867            reporter.log2('Closing guest session ...');
     
    19092080                if      waitResult != vboxcon.GuestSessionWaitResult_Start \
    19102081                    and waitResult != vboxcon.GuestSessionWaitResult_WaitFlagNotSupported:
    1911                     reporter.error('Session did not start successfully, returned wait result: %ld' \
     2082                    reporter.error('Session did not start successfully, returned wait result: %d' \
    19122083                                   % (waitResult));
    19132084                    return (False, oTxsSession);
     
    20832254                waitRes = curProc.waitForArray([ vboxcon.ProcessWaitForFlag_Start ], 30 * 1000);
    20842255                if waitRes != vboxcon.ProcessWaitResult_Start:
    2085                     reporter.error('Waiting for process 1 to start failed, got status %ld');
     2256                    reporter.error('Waiting for process 1 to start failed, got status %d');
    20862257                    fRc = False;
    20872258                if fRc:
     
    20972268                    waitRes = curProc.waitForArray([ vboxcon.ProcessWaitForFlag_Terminate ], 5000);
    20982269                    if waitRes != vboxcon.ProcessWaitResult_Timeout:
    2099                         reporter.error('Waiting for process 1 did not time out when it should, got wait result %ld' % (waitRes,));
     2270                        reporter.error('Waiting for process 1 did not time out when it should, got wait result %d' % (waitRes,));
    21002271                        fRc = False;
    21012272                    else:
     
    21142285                    waitRes = curProc.waitForArray([ vboxcon.ProcessWaitForFlag_Start ], 30 * 1000);
    21152286                    if waitRes != vboxcon.ProcessWaitResult_Start:
    2116                         reporter.error('Waiting for process 1 to start failed, got status %ld');
     2287                        reporter.error('Waiting for process 1 to start failed, got status %d');
    21172288                        fRc = False;
    21182289                    if fRc:
     
    21202291                        waitRes = curProc.waitForArray([ vboxcon.ProcessWaitForFlag_Terminate ], 30 * 1000);
    21212292                        if waitRes != vboxcon.ProcessWaitResult_Timeout:
    2122                             reporter.error('Waiting for process 2 did not time out when it should, got wait result %ld' \
     2293                            reporter.error('Waiting for process 2 did not time out when it should, got wait result %d' \
    21232294                                           % (waitRes,));
    21242295                            fRc = False;
     
    21262297                        reporter.log('Waiting for process 2 indicated an error, good');
    21272298                        if curProc.status != vboxcon.ProcessStatus_TimedOutKilled:
    2128                             reporter.error('Status of process 2 wrong; excepted %ld, got %ld' \
     2299                            reporter.error('Status of process 2 wrong; excepted %d, got %d' \
    21292300                                           % (vboxcon.ProcessStatus_TimedOutKilled, curProc.status));
    21302301                            fRc = False;
    21312302                        else:
    2132                             reporter.log('Status of process 2 correct (%ld)' % (vboxcon.ProcessStatus_TimedOutKilled,));
     2303                            reporter.log('Status of process 2 correct (%d)' % (vboxcon.ProcessStatus_TimedOutKilled,));
    21332304                    ## @todo Add curProc.terminate() as soon as it's implemented.
    21342305                except:
     
    24412612            (fRc2, cDirs, cFiles) = self.gctrlReadDir(curTest, curRes, curGuestSession);
    24422613            curTest.closeSession();
    2443             reporter.log2('Test #%d: Returned %ld directories, %ld files total' % (i, cDirs, cFiles));
     2614            reporter.log2('Test #%d: Returned %d directories, %d files total' % (i, cDirs, cFiles));
    24442615            if fRc2 is curRes.fRc:
    24452616                if fRc2 is True:
    24462617                    if curRes.numFiles != cFiles:
    2447                         reporter.error('Test #%d failed: Got %ld files, expected %ld' % (i, cFiles, curRes.numFiles));
     2618                        reporter.error('Test #%d failed: Got %d files, expected %d' % (i, cFiles, curRes.numFiles));
    24482619                        fRc = False;
    24492620                        break;
    24502621                    if curRes.numDirs != cDirs:
    2451                         reporter.error('Test #%d failed: Got %ld directories, expected %ld' % (i, cDirs, curRes.numDirs));
     2622                        reporter.error('Test #%d failed: Got %d directories, expected %d' % (i, cDirs, curRes.numDirs));
    24522623                        fRc = False;
    24532624                        break;
     
    26102781                eFileType = fileObjInfo.type;
    26112782                if curRes.eFileType != eFileType:
    2612                     reporter.error('Test #%d failed: Got file type %ld, expected %ld' % (i, eFileType, curRes.eFileType));
     2783                    reporter.error('Test #%d failed: Got file type %d, expected %d' % (i, eFileType, curRes.eFileType));
    26132784                    fRc = False;
    26142785                    break;
    26152786                cbFile = long(fileObjInfo.objectSize);
    26162787                if curRes.cbSize != cbFile:
    2617                     reporter.error('Test #%d failed: Got %ld bytes size, expected %ld bytes' % (i, cbFile, curRes.cbSize));
     2788                    reporter.error('Test #%d failed: Got %d bytes size, expected %d bytes' % (i, cbFile, curRes.cbSize));
    26182789                    fRc = False;
    26192790                    break;
     
    27122883            curTest = aTest[0]; # tdTestFileReadWrite, use an index, later.
    27132884            curRes  = aTest[1]; # tdTestResult
    2714             reporter.log('Testing #%d, sFile="%s", cbToReadWrite=%d, sOpenMode="%s", sDisposition="%s", cbOffset=%ld ...' % \
     2885            reporter.log('Testing #%d, sFile="%s", cbToReadWrite=%d, sOpenMode="%s", sDisposition="%s", cbOffset=%d ...' % \
    27152886                         (i, curTest.sFile, curTest.cbToReadWrite, curTest.sOpenMode, curTest.sDisposition, curTest.cbOffset));
    27162887            curTest.setEnvironment(oSession, oTxsSession, oTestVm);
     
    27312902                    resOffset = long(curTest.cbOffset);
    27322903                    if curOffset != resOffset:
    2733                         reporter.error('Test #%d failed: Initial offset on open does not match: Got %ld, expected %ld' \
     2904                        reporter.error('Test #%d failed: Initial offset on open does not match: Got %d, expected %d' \
    27342905                                       % (i, curOffset, resOffset));
    27352906                        fRc = False;
     
    27482919                    if  curRes.cbProcessed > 0 \
    27492920                    and curRes.cbProcessed is not len(aBufRead):
    2750                         reporter.error('Test #%d failed: Read buffer length does not match: Got %ld, expected %ld' \
     2921                        reporter.error('Test #%d failed: Read buffer length does not match: Got %d, expected %d' \
    27512922                                       % (i, len(aBufRead), curRes.cbProcessed));
    27522923                        fRc = False;
     
    27542925                        if  curRes.aBuf is not None \
    27552926                        and bytes(curRes.aBuf) != bytes(aBufRead):
    2756                             reporter.error('Test #%d failed: Got buffer\n%s (%ld bytes), expected\n%s (%ld bytes)' \
     2927                            reporter.error('Test #%d failed: Got buffer\n%s (%d bytes), expected\n%s (%d bytes)' \
    27572928                                           % (i, map(hex, map(ord, aBufRead)), len(aBufRead), \
    27582929                                              map(hex, map(ord, curRes.aBuf)), len(curRes.aBuf)));
     
    27642935                resOffset = long(curRes.cbOffset);
    27652936                if curOffset != resOffset:
    2766                     reporter.error('Test #%d failed: Final offset does not match: Got %ld, expected %ld' \
     2937                    reporter.error('Test #%d failed: Final offset does not match: Got %d, expected %d' \
    27672938                                   % (i, curOffset, resOffset));
    27682939                    fRc = False;
     
    28262997            curTest = aTest[0]; # tdTestFileReadWrite, use an index, later.
    28272998            curRes  = aTest[1]; # tdTestResult
    2828             reporter.log('Testing #%d, sFile="%s", cbToReadWrite=%d, sOpenMode="%s", sDisposition="%s", cbOffset=%ld ...' % \
     2999            reporter.log('Testing #%d, sFile="%s", cbToReadWrite=%d, sOpenMode="%s", sDisposition="%s", cbOffset=%d ...' % \
    28293000                         (i, curTest.sFile, curTest.cbToReadWrite, curTest.sOpenMode, curTest.sDisposition, curTest.cbOffset));
    28303001            curTest.setEnvironment(oSession, oTxsSession, oTestVm);
     
    28453016                    resOffset = long(curTest.cbOffset);
    28463017                    if curOffset != resOffset:
    2847                         reporter.error('Test #%d failed: Initial offset on open does not match: Got %ld, expected %ld' \
     3018                        reporter.error('Test #%d failed: Initial offset on open does not match: Got %d, expected %d' \
    28483019                                       % (i, curOffset, resOffset));
    28493020                        fRc = False;
     
    28623033                    if  curRes.cbProcessed > 0 \
    28633034                    and curRes.cbProcessed != cBytesWritten:
    2864                         reporter.error('Test #%d failed: Written buffer length does not match: Got %ld, expected %ld' \
     3035                        reporter.error('Test #%d failed: Written buffer length does not match: Got %d, expected %d' \
    28653036                                       % (i, cBytesWritten, curRes.cbProcessed));
    28663037                        fRc = False;
     
    28793050                        and long(curFile.offset) != curTest.cbOffset:
    28803051                            reporter.error('Test #%d failed: Initial write position does not match current position, \
    2881                                            got %ld, expected %ld' \
     3052                                           got %d, expected %d' \
    28823053                                           % (i, long(curFile.offset), curTest.cbOffset));
    28833054                            fRc = False;
     
    28853056                        aBufRead = curFile.read(curTest.cbToReadWrite, 30 * 1000);
    28863057                        if len(aBufRead) != curTest.cbToReadWrite:
    2887                             reporter.error('Test #%d failed: Got buffer length %ld, expected %ld' \
     3058                            reporter.error('Test #%d failed: Got buffer length %d, expected %d' \
    28883059                                           % (i, len(aBufRead), curTest.cbToReadWrite));
    28893060                            fRc = False;
     
    28983069                resOffset = long(curRes.cbOffset);
    28993070                if curOffset != resOffset:
    2900                     reporter.error('Test #%d failed: Final offset does not match: Got %ld, expected %ld' \
     3071                    reporter.error('Test #%d failed: Final offset does not match: Got %d, expected %d' \
    29013072                                   % (i, curOffset, resOffset));
    29023073                    fRc = False;
Note: See TracChangeset for help on using the changeset viewer.

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