Files
Jake Turner d0b69c7034 Add Python test helper validate_eventids()
Called when loading captures in Iter_Test and Repeat_Load

Checks the consistency of EventIds:

Walk the actions to find all the referenced EventId's:
- Error if any EventId is duplicated
- Error if the EventId's are not contiguous (with no gaps)
2026-04-24 15:50:40 +01:00

62 lines
2.0 KiB
Python

import rdtest
import os
import renderdoc as rd
class Repeat_Load(rdtest.TestCase):
slow_test = True
def repeat_load(self, path):
memory_usage = memory_baseline = 0
for i in range(20):
rdtest.log.print("Loading for iteration {}".format(i+1))
try:
controller = rdtest.open_capture(path)
except RuntimeError as err:
rdtest.log.print("Skipping. Can't open {}: {}".format(path, err))
return
rdtest.log.print("Loaded capture.")
if not self.validate_eventids(controller):
raise rdtest.TestFailureException("ERROR: capture doesn't have valid event IDs.")
# Do nothing, just ensure it's loaded
memory_usage: int = rd.GetCurrentProcessMemoryUsage()
# We measure the baseline memory usage during the second peak to avoid any persistent caches etc that might
# not be full
if i == 2:
memory_baseline = memory_usage
controller.Shutdown()
pct_over = 'N/A'
if memory_baseline > 0:
pct_over = '{:.2f}%'.format((memory_usage / memory_baseline)*100)
rdtest.log.success("Succeeded iteration {}, memory usage was {} ({} of baseline)"
.format(i+1, memory_usage, pct_over))
pct_over = '{:.2f}%'.format((memory_usage / memory_baseline)*100)
msg = 'final memory usage was {}, {} compared to baseline {}'.format(memory_usage, pct_over, memory_baseline)
if memory_baseline * 1.25 < memory_usage:
raise rdtest.TestFailureException(msg)
else:
rdtest.log.success(msg)
def run(self):
dir_path = self.get_ref_path('', extra=True)
for file in os.scandir(dir_path):
section_name = f"Repeat loading {file.name}"
rdtest.log.begin_section(section_name)
self.repeat_load(file.path)
rdtest.log.end_section(section_name)
rdtest.log.success("Repeat loaded all files")