Files
systems-assistant[bot] 2cfedef6b6 [CI] Increase rocDecode and rocJPEG Code Coverage (#183)
* Increase rocDecode code coverage and add version check

* Update rocJPEG tests

* Fix rocJPEG tests

* Enable building tests/samples in rocm release compat workflow

* Readded rocJPEG test skips

* formatting

* Adding ROCm libraries for the code-coverage job

* Added return value check for error message and updated compatability to enable tests

* Disable rocm_release_compatibility samples and tests until openmp issue is resolved

---------

Co-authored-by: Ian Trowbridge <Ian.Trowbridge@amd.com>
Co-authored-by: Jonathan R. Madsen <jonathanrmadsen@gmail.com>
Co-authored-by: Jonathan R. Madsen <Jonathan.Madsen@amd.com>
2025-09-03 19:20:11 +05:30

169 rindas
5.5 KiB
Python
Izpildāmais fails

#!/usr/bin/env python3
# MIT License
#
# Copyright (c) 2023-2025 Advanced Micro Devices, Inc. All rights reserved.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
import sys
import pytest
import json
from collections import defaultdict
# helper function
def node_exists(name, data, min_len=1):
assert name in data
assert data[name] is not None
if isinstance(data[name], (list, tuple, dict, set)):
assert len(data[name]) >= min_len
def get_operation(record, kind_name, op_name=None):
for idx, itr in enumerate(record["strings"]["buffer_records"]):
if kind_name == itr["kind"]:
if op_name is None:
return idx, itr["operations"]
else:
for oidx, oname in enumerate(itr["operations"]):
if op_name == oname:
return oidx
return None
def test_rocjpeg(json_data):
data = json_data["rocprofiler-sdk-tool"]
buffer_records = data["buffer_records"]
rocjpeg_data = buffer_records["rocjpeg_api"]
# If rocJPEG tracing is not supported, end early
if len(rocjpeg_data) == 0:
return pytest.skip("rocjpeg tracing unavailable")
_, bf_op_names = get_operation(data, "ROCJPEG_API")
assert len(bf_op_names) == 9
rocjpeg_reported_agent_ids = set()
# check buffering data
for node in rocjpeg_data:
assert "size" in node
assert "kind" in node
assert "operation" in node
assert "correlation_id" in node
assert "end_timestamp" in node
assert "start_timestamp" in node
assert "thread_id" in node
assert node.size > 0
assert node.thread_id > 0
assert node.start_timestamp > 0
assert node.end_timestamp > 0
assert node.start_timestamp < node.end_timestamp
assert data.strings.buffer_records[node.kind].kind == "ROCJPEG_API"
assert (
data.strings.buffer_records[node.kind].operations[node.operation]
in bf_op_names
)
def test_csv_data(csv_data):
# If rocJPEG tracing is not supported, end early
if len(csv_data) <= 2:
return pytest.skip("rocjpeg tracing unavailable")
api_calls = []
for row in csv_data:
assert "Domain" in row, "'Domain' was not present in csv data for rocjpeg-trace"
assert (
"Function" in row
), "'Function' was not present in csv data for rocjpeg-trace"
assert (
"Process_Id" in row
), "'Process_Id' was not present in csv data for rocjpeg-trace"
assert (
"Thread_Id" in row
), "'Thread_Id' was not present in csv data for rocjpeg-trace"
assert (
"Correlation_Id" in row
), "'Correlation_Id' was not present in csv data for rocjpeg-trace"
assert (
"Start_Timestamp" in row
), "'Start_Timestamp' was not present in csv data for rocjpeg-trace"
assert (
"End_Timestamp" in row
), "'End_Timestamp' was not present in csv data for rocjpeg-trace"
api_calls.append(row["Function"])
assert row["Domain"] == "ROCJPEG_API"
assert int(row["Process_Id"]) > 0
assert int(row["Thread_Id"]) > 0
assert int(row["Start_Timestamp"]) > 0
assert int(row["End_Timestamp"]) > 0
assert int(row["Start_Timestamp"]) < int(row["End_Timestamp"])
for call in [
"rocJpegCreate",
"rocJpegStreamCreate",
"rocJpegStreamParse",
"rocJpegGetImageInfo",
"rocJpegDecode",
"rocJpegDestroy",
"rocJpegStreamDestroy",
]:
assert call in api_calls
def test_perfetto_data(pftrace_data, json_data):
import rocprofiler_sdk.tests.rocprofv3 as rocprofv3
# If rocJPEG tracing is not supported, end early
if len(json_data["rocprofiler-sdk-tool"]["buffer_records"]["rocjpeg_api"]) == 0:
return pytest.skip("rocjpeg tracing unavailable")
rocprofv3.test_perfetto_data(
pftrace_data,
json_data,
("rocjpeg_api",),
)
def test_otf2_data(otf2_data, json_data):
import rocprofiler_sdk.tests.rocprofv3 as rocprofv3
# If rocJPEG tracing is not supported, end early
if len(json_data["rocprofiler-sdk-tool"]["buffer_records"]["rocjpeg_api"]) == 0:
return pytest.skip("rocjpeg tracing unavailable")
rocprofv3.test_otf2_data(
otf2_data,
json_data,
("rocjpeg_api",),
)
if __name__ == "__main__":
exit_code = pytest.main(["-x", __file__] + sys.argv[1:])
sys.exit(exit_code)