mirror of
https://github.com/baldurk/renderdoc.git
synced 2026-05-12 13:00:32 +00:00
81 lines
2.9 KiB
Python
81 lines
2.9 KiB
Python
import renderdoc as rd
|
|
import rdtest
|
|
|
|
prevProgress = -1.0
|
|
|
|
|
|
def resolve_progress(progress: float):
|
|
global prevProgress
|
|
if progress - prevProgress > 0.01 or progress == 1.0:
|
|
prevProgress = progress
|
|
rdtest.log.print("Resolve progress: {:.2f}%".format(progress*100.0))
|
|
|
|
|
|
class GL_Callstacks(rdtest.TestCase):
|
|
demos_test_name = 'GL_Callstacks'
|
|
|
|
def get_capture_options(self):
|
|
ret = rd.CaptureOptions()
|
|
ret.captureCallstacks = True
|
|
return ret
|
|
|
|
def check_capture(self):
|
|
# Need capture access. Rather than trying to keep the original around, we just open a new one
|
|
cap = rd.OpenCaptureFile()
|
|
|
|
# Open a particular file
|
|
result = cap.OpenFile(self.capture_filename, '', None)
|
|
|
|
# Make sure the file opened successfully
|
|
if result != rd.ResultCode.Succeeded:
|
|
cap.Shutdown()
|
|
raise rdtest.TestFailureException("Couldn't open capture for access: {}".format(self.capture_filename, str(result)))
|
|
|
|
if not cap.HasCallstacks():
|
|
raise rdtest.TestFailureException("Capture does not report having callstacks")
|
|
|
|
if not cap.InitResolver(False, resolve_progress):
|
|
raise rdtest.TestFailureException("Failed to initialise callstack resolver")
|
|
|
|
action = self.find_action("Draw")
|
|
|
|
event: rd.APIEvent = action.events[-1]
|
|
|
|
expected_funcs = [
|
|
"GL_Callstacks::testFunction",
|
|
"GL_Callstacks::main",
|
|
]
|
|
|
|
expected_lines = [
|
|
7000,
|
|
8000
|
|
]
|
|
|
|
sdfile = self.controller.GetStructuredFile()
|
|
|
|
if event.chunkIndex < 0 or event.chunkIndex > len(sdfile.chunks):
|
|
raise rdtest.TestFailureException("Event {} has invalid chunk index {}"
|
|
.format(event.eventId, event.chunkIndex))
|
|
|
|
chunk = sdfile.chunks[event.chunkIndex]
|
|
|
|
callstack = cap.GetResolve(list(chunk.metadata.callstack))
|
|
|
|
if len(callstack) < len(expected_funcs):
|
|
raise rdtest.TestFailureException("Resolved callstack isn't long enough ({} stack frames), expected at least {}".format(len(event.callstack), len(expected_funcs)))
|
|
|
|
for i in range(len(expected_funcs)):
|
|
stack: str = callstack[i]
|
|
if expected_funcs[i] not in stack:
|
|
raise rdtest.TestFailureException("Expected '{}' in '{}'".format(expected_funcs[i], stack))
|
|
idx = callstack[i].find("line")
|
|
if idx < 0:
|
|
raise rdtest.TestFailureException("Expected a line number in '{}'".format(stack))
|
|
|
|
# allow line numbers reported to be off by 1 or 2, to allow for compiler differences.
|
|
line_diff = int(stack[idx+5:]) - expected_lines[i]
|
|
if line_diff < 0 or line_diff > 2:
|
|
raise rdtest.TestFailureException("Expected line number around {} in '{}'".format(expected_lines[i], stack))
|
|
|
|
rdtest.log.success("Callstacks are as expected")
|