VirtualBox

Changeset 79138 in vbox for trunk/src/VBox/ValidationKit


Ignore:
Timestamp:
Jun 14, 2019 1:00:00 AM (6 years ago)
Author:
vboxsync
Message:

ValKit: Hack to try make COM and XPCOM exceptions more readable.

Location:
trunk/src/VBox/ValidationKit/testdriver
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/ValidationKit/testdriver/reporter.py

    r79087 r79138  
    10721072#
    10731073
     1074g_fnComXcptFormatter = None;
     1075
     1076def setComXcptFormatter(fnCallback):
     1077    """
     1078    Install callback for prettier COM exception formatting.
     1079
     1080    The callback replaces the work done by format_exception_only() and
     1081    takes the same arguments.  It returns None if not interested in the
     1082    exception.
     1083    """
     1084    global g_fnComXcptFormatter;
     1085    g_fnComXcptFormatter = fnCallback;
     1086    return True;
     1087
     1088def formatExceptionOnly(oType, oXcpt, sCaller, sTsPrf):
     1089    """
     1090    Wrapper around traceback.format_exception_only and __g_fnComXcptFormatter.
     1091    """
     1092    #asRet = ['oType=%s type(oXcpt)=%s' % (oType, type(oXcpt),)];
     1093    asRet = [];
     1094
     1095    # Try the callback first.
     1096    fnCallback = g_fnComXcptFormatter;
     1097    if fnCallback:
     1098        try:
     1099            asRetCb = fnCallback(oType, oXcpt);
     1100            if asRetCb:
     1101                return asRetCb;
     1102                #asRet += asRetCb;
     1103        except:
     1104            g_oReporter.log(0, '** internal-error: Hit exception #2 in __g_fnComXcptFormatter! %s'
     1105                            % (traceback.format_exc()), sCaller, sTsPrf);
     1106            asRet += ['internal error: exception in __g_fnComXcptFormatter'];
     1107
     1108    # Now try format_exception_only:
     1109    try:
     1110        asRet += traceback.format_exception_only(oType, oXcpt);
     1111    except:
     1112        g_oReporter.log(0, '** internal-error: Hit exception #2 in format_exception_only! %s'
     1113                        % (traceback.format_exc()), sCaller, sTsPrf);
     1114        asRet += ['internal error: Exception in format_exception_only!'];
     1115    return asRet;
     1116
     1117
    10741118def logXcptWorker(iLevel, fIncErrors, sPrefix="", sText=None, cFrames=1):
    10751119    """
     
    10991143                if sText is not None:
    11001144                    rc = g_oReporter.log(iLevel, "%s%s" % (sPrefix, sText), sCaller, sTsPrf);
    1101                 asInfo = [];
     1145                asInfo = None;
    11021146                try:
    1103                     asInfo = asInfo + traceback.format_exception_only(oType, oValue);
     1147                    asInfo = formatExceptionOnly(oType, oValue, sCaller, sTsPrf);
    11041148                    if cFrames is not None and cFrames <= 1:
    11051149                        asInfo = asInfo + traceback.format_tb(oTraceback, 1);
     
    11331177        g_oLock.release();
    11341178    return rc;
     1179
    11351180
    11361181#
     
    15891634    if oType is not None:
    15901635        sCaller = utils.getCallerName(oTraceback.tb_frame);
    1591         sXcpt   = ' '.join(traceback.format_exception_only(oType, oValue));
     1636        sXcpt   = ' '.join(formatExceptionOnly(oType, oValue, sCaller, utils.getTimePrefix()));
    15921637    else:
    15931638        sCaller = utils.getCallerName();
  • trunk/src/VBox/ValidationKit/testdriver/vbox.py

    r79092 r79138  
    182182    return reporter.error(stringifyErrorInfo(oErrObj));
    183183
     184def formatComOrXpComException(oType, oXcpt):
     185    """
     186    Callback installed with the reporter to better format COM exceptions.
     187    Similar to format_exception_only, only it returns None if not interested.
     188    """
     189    _ = oType;
     190    oVBoxMgr = vboxcon.goHackModuleClass.oVBoxMgr;
     191    if oVBoxMgr is None:
     192        return None;
     193    if not oVBoxMgr.xcptIsOurXcptKind(oXcpt):               # pylint: disable=not-callable
     194        return None;
     195
     196    if platform.system() == 'Windows':
     197        hrc = oXcpt.hresult;
     198        if hrc == ComError.DISP_E_EXCEPTION and oXcpt.excepinfo is not None and len(oXcpt.excepinfo) > 5:
     199            hrc    = oXcpt.excepinfo[5];
     200            sWhere = oXcpt.excepinfo[1];
     201            sMsg   = oXcpt.excepinfo[2];
     202        else:
     203            sWhere = None;
     204            sMsg   = oXcpt.strerror;
     205    else:
     206        hrc    = oXcpt.errno;
     207        sWhere = None;
     208        sMsg   = oXcpt.msg;
     209
     210    sHrc = oVBoxMgr.xcptToString(hrc);                      # pylint: disable=not-callable
     211    if sHrc.find('(') < 0:
     212        sHrc = '%s (%#x)' % (sHrc, hrc & 0xffffffff);
     213
     214    asRet = ['COM-Xcpt: %s' % (sHrc,)];
     215    if sMsg and sWhere:
     216        asRet.append('--------- %s: %s' % (sWhere, sMsg,));
     217    elif sMsg:
     218        asRet.append('--------- %s' % (sMsg,));
     219    return asRet;
     220    #if sMsg and sWhere:
     221    #    return ['COM-Xcpt: %s - %s: %s' % (sHrc, sWhere, sMsg,)];
     222    #if sMsg:
     223    #    return ['COM-Xcpt: %s - %s' % (sHrc, sMsg,)];
     224    #return ['COM-Xcpt: %s' % (sHrc,)];
    184225
    185226#
     
    13451386            vboxcon.goHackModuleClass.oVBoxMgr  = self.oVBoxMgr; # VBoxConstantWrappingHack.
    13461387            vboxcon.fpApiVer                    = self.fpApiVer;
     1388            reporter.setComXcptFormatter(formatComOrXpComException);
    13471389
    13481390        except:
     
    14321474        self.oVBox            = None;
    14331475        vboxcon.goHackModuleClass.oVBoxMgr = None; # VBoxConstantWrappingHack.
     1476        reporter.setComXcptFormatter(None);
    14341477
    14351478        # Do garbage collection to try get rid of those objects.
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