You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
156 lines
7.0 KiB
156 lines
7.0 KiB
3 months ago
|
# License: Apache 2.0. See LICENSE file in root directory.
|
||
|
# Copyright(c) 2023 Intel Corporation. All Rights Reserved.
|
||
|
|
||
|
#test:donotrun:!dds
|
||
|
#test:retries:gha 2
|
||
|
|
||
|
from rspy import log, test
|
||
|
import pyrealsense2 as rs
|
||
|
import dds
|
||
|
|
||
|
if log.is_debug_on():
|
||
|
rs.log_to_console( rs.log_severity.debug )
|
||
|
log.nested = 'C '
|
||
|
|
||
|
context = rs.context( { 'dds': { 'enabled': True, 'domain': 123, 'participant': 'test-formats-conversion' }} )
|
||
|
only_sw_devices = int(rs.product_line.sw_only) | int(rs.product_line.any)
|
||
|
|
||
|
import os.path
|
||
|
cwd = os.path.dirname(os.path.realpath(__file__))
|
||
|
remote_script = os.path.join( cwd, 'formats-conversion-server.py' )
|
||
|
with test.remote( remote_script, nested_indent=" S" ) as remote:
|
||
|
remote.wait_until_ready()
|
||
|
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test setup", on_fail=test.ABORT ):
|
||
|
remote.run( 'create_server()' )
|
||
|
n_devs = 0
|
||
|
for dev in dds.wait_for_devices( context, only_sw_devices ):
|
||
|
n_devs += 1
|
||
|
test.check_equal( n_devs, 1 )
|
||
|
sensors = {sensor.get_info( rs.camera_info.name ) : sensor for sensor in dev.query_sensors()}
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test Y8 conversion"):
|
||
|
if test.check( 'Y8-sensor' in sensors ):
|
||
|
sensor = sensors.get('Y8-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 1 )
|
||
|
test.check_equal( profiles[0].format(), rs.format.y8 )
|
||
|
test.check_equal( profiles[0].stream_index(), 0 )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test YUYV conversion"):
|
||
|
if test.check( 'YUYV-sensor' in sensors ):
|
||
|
sensor = sensors.get('YUYV-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 6 ) # YUYV -> YUYV/RGB8/RGBA8/BGR8/BGRA8/Y8
|
||
|
test.check_equal( profiles[0].format(), rs.format.rgb8 )
|
||
|
test.check_equal( profiles[1].format(), rs.format.y8 )
|
||
|
test.check_equal( profiles[2].format(), rs.format.bgra8 )
|
||
|
test.check_equal( profiles[3].format(), rs.format.rgba8 )
|
||
|
test.check_equal( profiles[4].format(), rs.format.bgr8 )
|
||
|
test.check_equal( profiles[5].format(), rs.format.yuyv )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test UYVY conversion"):
|
||
|
if test.check( 'UYVY-sensor' in sensors ):
|
||
|
sensor = sensors.get('UYVY-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 7 ) # UYVY -> UYVY/YUYV/RGB8/RGBA8/BGR8/BGRA8/Y8
|
||
|
test.check_equal( profiles[0].format(), rs.format.rgb8 )
|
||
|
test.check_equal( profiles[1].format(), rs.format.uyvy )
|
||
|
test.check_equal( profiles[2].format(), rs.format.y8 )
|
||
|
test.check_equal( profiles[3].format(), rs.format.bgra8 )
|
||
|
test.check_equal( profiles[4].format(), rs.format.rgba8 )
|
||
|
test.check_equal( profiles[5].format(), rs.format.bgr8 )
|
||
|
test.check_equal( profiles[6].format(), rs.format.yuyv )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test Z16 conversion"):
|
||
|
if test.check( 'Z16-sensor' in sensors ):
|
||
|
sensor = sensors.get('Z16-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 1 ) # Z16 stays Z16, for depth stream type
|
||
|
test.check_equal( profiles[0].format(), rs.format.z16 )
|
||
|
test.check_equal( profiles[0].stream_type(), rs.stream.depth )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test motion conversion" ):
|
||
|
if test.check( 'motion-sensor' in sensors ):
|
||
|
sensor = sensors.get('motion-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 1 ) # MXYZ stays MXYZ with type based on the dds_stream type
|
||
|
test.check_equal( profiles[0].stream_type(), rs.stream.motion )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test multiple motion profiles one stream" ):
|
||
|
if test.check( 'multiple-motion-sensor' in sensors ):
|
||
|
sensor = sensors.get('multiple-motion-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 4 )
|
||
|
for i in range( len( profiles ) ):
|
||
|
test.check_equal( profiles[i].stream_type(), rs.stream.motion )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test multiple color profiles one stream"):
|
||
|
if test.check( 'multiple-color-sensor' in sensors ):
|
||
|
sensor = sensors.get('multiple-color-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
# Streams are sorted by format then fps:
|
||
|
# RGB8 @ 30/15/5 Hz
|
||
|
# BGRA8 @ 30/15/5 Hz
|
||
|
# RGBA8 @ 30/15/5 Hz
|
||
|
# BGR8 @ 30/15/5 Hz
|
||
|
# YUYV @ 30/15/5 Hz
|
||
|
test.check_equal( len( profiles ), 18 )
|
||
|
for i,f in zip( range(3), (30,15,5) ):
|
||
|
test.check_equal( profiles[0 + i].format(), rs.format.rgb8 )
|
||
|
test.check_equal( profiles[0 + i].fps(), f )
|
||
|
test.check_equal( profiles[3 + i].format(), rs.format.y8 )
|
||
|
test.check_equal( profiles[3 + i].fps(), f )
|
||
|
test.check_equal( profiles[6 + i].format(), rs.format.bgra8 )
|
||
|
test.check_equal( profiles[6 + i].fps(), f )
|
||
|
test.check_equal( profiles[9 + i].format(), rs.format.rgba8 )
|
||
|
test.check_equal( profiles[9 + i].fps(), f )
|
||
|
test.check_equal( profiles[12 + i].format(), rs.format.bgr8 )
|
||
|
test.check_equal( profiles[12 + i].fps(), f )
|
||
|
test.check_equal( profiles[15 + i].format(), rs.format.yuyv )
|
||
|
test.check_equal( profiles[15 + i].fps(), f )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
with test.closure( "Test multiple depth profiles one stream"):
|
||
|
if test.check( 'multiple-depth-sensor' in sensors ):
|
||
|
sensor = sensors.get('multiple-depth-sensor')
|
||
|
profiles = sensor.get_stream_profiles()
|
||
|
|
||
|
test.check_equal( len( profiles ), 5 )
|
||
|
for i in range(5):
|
||
|
test.check_equal( profiles[i].format(), rs.format.z16 )
|
||
|
#
|
||
|
#############################################################################################
|
||
|
#
|
||
|
# Tests tear down
|
||
|
remote.run( 'close_server()' )
|
||
|
dev = None
|
||
|
|
||
|
context = None
|
||
|
|
||
|
test.print_results_and_exit()
|