[libcamera-devel] [PATCH 2/2] test: meson: Use dictionaries instead of arrays to store test information
Jacopo Mondi
jacopo at jmondi.org
Thu Oct 6 09:25:33 CEST 2022
Hi Laurent
On Wed, Oct 05, 2022 at 10:39:44PM +0300, Laurent Pinchart via libcamera-devel wrote:
> Tests are listed in meson.build using arrays that contain the test name
> and source files at fixed positions. This isn't very readable, leading
> to code using test[0], test[1] and test[2]. Replace the arrays with
> dictionaries to improve readability.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
Thanks! This is much much nicer!
Reviewed-by: Jacopo Mondi <jacopo at jmondi.org>
> ---
> test/camera/meson.build | 16 +++---
> test/controls/meson.build | 12 ++---
> test/gstreamer/meson.build | 8 +--
> test/ipa/meson.build | 8 +--
> test/ipc/meson.build | 8 +--
> test/log/meson.build | 8 +--
> test/media_device/meson.build | 10 ++--
> test/meson.build | 84 +++++++++++++++----------------
> test/pipeline/ipu3/meson.build | 6 +--
> test/pipeline/rkisp1/meson.build | 6 +--
> test/process/meson.build | 6 +--
> test/serialization/meson.build | 8 +--
> test/stream/meson.build | 8 +--
> test/v4l2_subdevice/meson.build | 8 +--
> test/v4l2_videodevice/meson.build | 24 ++++-----
> 15 files changed, 110 insertions(+), 110 deletions(-)
>
> diff --git a/test/camera/meson.build b/test/camera/meson.build
> index df0520293bdb..4f9f8c8c4784 100644
> --- a/test/camera/meson.build
> +++ b/test/camera/meson.build
> @@ -3,18 +3,18 @@
> # Tests are listed in order of complexity.
> # They are not alphabetically sorted.
> camera_tests = [
> - ['configuration_default', 'configuration_default.cpp'],
> - ['configuration_set', 'configuration_set.cpp'],
> - ['buffer_import', 'buffer_import.cpp'],
> - ['statemachine', 'statemachine.cpp'],
> - ['capture', 'capture.cpp'],
> - ['camera_reconfigure', 'camera_reconfigure.cpp'],
> + {'name': 'configuration_default', 'sources': ['configuration_default.cpp']},
> + {'name': 'configuration_set', 'sources': ['configuration_set.cpp']},
> + {'name': 'buffer_import', 'sources': ['buffer_import.cpp']},
> + {'name': 'statemachine', 'sources': ['statemachine.cpp']},
> + {'name': 'capture', 'sources': ['capture.cpp']},
> + {'name': 'camera_reconfigure', 'sources': ['camera_reconfigure.cpp']},
> ]
>
> foreach test : camera_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite : 'camera', is_parallel : false)
> + test(test['name'], exe, suite : 'camera', is_parallel : false)
> endforeach
> diff --git a/test/controls/meson.build b/test/controls/meson.build
> index 8cf23be6487c..763f8905e7c1 100644
> --- a/test/controls/meson.build
> +++ b/test/controls/meson.build
> @@ -1,16 +1,16 @@
> # SPDX-License-Identifier: CC0-1.0
>
> control_tests = [
> - ['control_info', 'control_info.cpp'],
> - ['control_info_map', 'control_info_map.cpp'],
> - ['control_list', 'control_list.cpp'],
> - ['control_value', 'control_value.cpp'],
> + {'name': 'control_info', 'sources': ['control_info.cpp']},
> + {'name': 'control_info_map', 'sources': ['control_info_map.cpp']},
> + {'name': 'control_list', 'sources': ['control_list.cpp']},
> + {'name': 'control_value', 'sources': ['control_value.cpp']},
> ]
>
> foreach test : control_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_public,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite : 'controls', is_parallel : false)
> + test(test['name'], exe, suite : 'controls', is_parallel : false)
> endforeach
> diff --git a/test/gstreamer/meson.build b/test/gstreamer/meson.build
> index 46f6a77a771e..745725864eef 100644
> --- a/test/gstreamer/meson.build
> +++ b/test/gstreamer/meson.build
> @@ -5,16 +5,16 @@ if not gst_enabled
> endif
>
> gstreamer_tests = [
> - ['single_stream_test', 'gstreamer_single_stream_test.cpp'],
> - ['multi_stream_test', 'gstreamer_multi_stream_test.cpp'],
> + {'name': 'single_stream_test', 'sources': ['gstreamer_single_stream_test.cpp']},
> + {'name': 'multi_stream_test', 'sources': ['gstreamer_multi_stream_test.cpp']},
> ]
> gstreamer_dep = dependency('gstreamer-1.0', required: true)
>
> foreach test : gstreamer_tests
> - exe = executable(test[0], test[1], 'gstreamer_test.cpp',
> + exe = executable(test['name'], test['sources'], 'gstreamer_test.cpp',
> dependencies : [libcamera_private, gstreamer_dep],
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'gstreamer', is_parallel : false)
> + test(test['name'], exe, suite : 'gstreamer', is_parallel : false)
> endforeach
> diff --git a/test/ipa/meson.build b/test/ipa/meson.build
> index 295807fd8a45..180b0da0a51a 100644
> --- a/test/ipa/meson.build
> +++ b/test/ipa/meson.build
> @@ -1,15 +1,15 @@
> # SPDX-License-Identifier: CC0-1.0
>
> ipa_test = [
> - ['ipa_module_test', 'ipa_module_test.cpp'],
> - ['ipa_interface_test', 'ipa_interface_test.cpp'],
> + {'name': 'ipa_module_test', 'sources': ['ipa_module_test.cpp']},
> + {'name': 'ipa_interface_test', 'sources': ['ipa_interface_test.cpp']},
> ]
>
> foreach test : ipa_test
> - exe = executable(test[0], [test[1], libcamera_generated_ipa_headers],
> + exe = executable(test['name'], test['sources'], libcamera_generated_ipa_headers,
> dependencies : libcamera_private,
> link_with : [libipa, test_libraries],
> include_directories : [libipa_includes, test_includes_internal])
>
> - test(test[0], exe, suite : 'ipa')
> + test(test['name'], exe, suite : 'ipa')
> endforeach
> diff --git a/test/ipc/meson.build b/test/ipc/meson.build
> index ce21135b701d..8e447d228201 100644
> --- a/test/ipc/meson.build
> +++ b/test/ipc/meson.build
> @@ -1,15 +1,15 @@
> # SPDX-License-Identifier: CC0-1.0
>
> ipc_tests = [
> - ['unixsocket_ipc', 'unixsocket_ipc.cpp'],
> - ['unixsocket', 'unixsocket.cpp'],
> + {'name': 'unixsocket_ipc', 'sources': ['unixsocket_ipc.cpp']},
> + {'name': 'unixsocket', 'sources': ['unixsocket.cpp']},
> ]
>
> foreach test : ipc_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'ipc')
> + test(test['name'], exe, suite : 'ipc')
> endforeach
> diff --git a/test/log/meson.build b/test/log/meson.build
> index d2d51e471d52..2298ff84ee62 100644
> --- a/test/log/meson.build
> +++ b/test/log/meson.build
> @@ -1,15 +1,15 @@
> # SPDX-License-Identifier: CC0-1.0
>
> log_test = [
> - ['log_api', 'log_api.cpp'],
> - ['log_process', 'log_process.cpp'],
> + {'name': 'log_api', 'sources': ['log_api.cpp']},
> + {'name': 'log_process', 'sources': ['log_process.cpp']},
> ]
>
> foreach test : log_test
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'log')
> + test(test['name'], exe, suite : 'log')
> endforeach
> diff --git a/test/media_device/meson.build b/test/media_device/meson.build
> index 7d34509d6797..84966c976192 100644
> --- a/test/media_device/meson.build
> +++ b/test/media_device/meson.build
> @@ -5,9 +5,9 @@ lib_mdev_test_sources = files([
> ])
>
> media_device_tests = [
> - ['media_device_acquire', 'media_device_acquire.cpp'],
> - ['media_device_print_test', 'media_device_print_test.cpp'],
> - ['media_device_link_test', 'media_device_link_test.cpp'],
> + {'name': 'media_device_acquire', 'sources': ['media_device_acquire.cpp']},
> + {'name': 'media_device_print_test', 'sources': ['media_device_print_test.cpp']},
> + {'name': 'media_device_link_test', 'sources': ['media_device_link_test.cpp']},
> ]
>
> lib_mdev_test = static_library('lib_mdev_test', lib_mdev_test_sources,
> @@ -15,10 +15,10 @@ lib_mdev_test = static_library('lib_mdev_test', lib_mdev_test_sources,
> include_directories : test_includes_internal)
>
> foreach test : media_device_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : [test_libraries, lib_mdev_test],
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'media_device', is_parallel : false)
> + test(test['name'], exe, suite : 'media_device', is_parallel : false)
> endforeach
> diff --git a/test/meson.build b/test/meson.build
> index 4bc01d78f4e6..05a54d5cad2f 100644
> --- a/test/meson.build
> +++ b/test/meson.build
> @@ -26,82 +26,82 @@ subdir('v4l2_subdevice')
> subdir('v4l2_videodevice')
>
> public_tests = [
> - ['color-space', 'color-space.cpp'],
> - ['geometry', 'geometry.cpp'],
> - ['public-api', 'public-api.cpp'],
> - ['signal', 'signal.cpp'],
> - ['span', 'span.cpp'],
> + {'name': 'color-space', 'sources': ['color-space.cpp']},
> + {'name': 'geometry', 'sources': ['geometry.cpp']},
> + {'name': 'public-api', 'sources': ['public-api.cpp']},
> + {'name': 'signal', 'sources': ['signal.cpp']},
> + {'name': 'span', 'sources': ['span.cpp']},
> ]
>
> internal_tests = [
> - ['bayer-format', 'bayer-format.cpp'],
> - ['byte-stream-buffer', 'byte-stream-buffer.cpp'],
> - ['camera-sensor', 'camera-sensor.cpp'],
> - ['delayed_controls', 'delayed_controls.cpp'],
> - ['event', 'event.cpp'],
> - ['event-dispatcher', 'event-dispatcher.cpp'],
> - ['event-thread', 'event-thread.cpp'],
> - ['file', 'file.cpp'],
> - ['flags', 'flags.cpp'],
> - ['hotplug-cameras', 'hotplug-cameras.cpp'],
> - ['message', 'message.cpp'],
> - ['object', 'object.cpp'],
> - ['object-delete', 'object-delete.cpp'],
> - ['object-invoke', 'object-invoke.cpp'],
> - ['pixel-format', 'pixel-format.cpp'],
> - ['shared-fd', 'shared-fd.cpp'],
> - ['signal-threads', 'signal-threads.cpp'],
> - ['threads', 'threads.cpp', [libthreads]],
> - ['timer', 'timer.cpp'],
> - ['timer-thread', 'timer-thread.cpp'],
> - ['unique-fd', 'unique-fd.cpp'],
> - ['utils', 'utils.cpp'],
> - ['yaml-parser', 'yaml-parser.cpp'],
> + {'name': 'bayer-format', 'sources': ['bayer-format.cpp']},
> + {'name': 'byte-stream-buffer', 'sources': ['byte-stream-buffer.cpp']},
> + {'name': 'camera-sensor', 'sources': ['camera-sensor.cpp']},
> + {'name': 'delayed_controls', 'sources': ['delayed_controls.cpp']},
> + {'name': 'event', 'sources': ['event.cpp']},
> + {'name': 'event-dispatcher', 'sources': ['event-dispatcher.cpp']},
> + {'name': 'event-thread', 'sources': ['event-thread.cpp']},
> + {'name': 'file', 'sources': ['file.cpp']},
> + {'name': 'flags', 'sources': ['flags.cpp']},
> + {'name': 'hotplug-cameras', 'sources': ['hotplug-cameras.cpp']},
> + {'name': 'message', 'sources': ['message.cpp']},
> + {'name': 'object', 'sources': ['object.cpp']},
> + {'name': 'object-delete', 'sources': ['object-delete.cpp']},
> + {'name': 'object-invoke', 'sources': ['object-invoke.cpp']},
> + {'name': 'pixel-format', 'sources': ['pixel-format.cpp']},
> + {'name': 'shared-fd', 'sources': ['shared-fd.cpp']},
> + {'name': 'signal-threads', 'sources': ['signal-threads.cpp']},
> + {'name': 'threads', 'sources': 'threads.cpp', 'dependencies': [libthreads]},
> + {'name': 'timer', 'sources': ['timer.cpp']},
> + {'name': 'timer-thread', 'sources': ['timer-thread.cpp']},
> + {'name': 'unique-fd', 'sources': ['unique-fd.cpp']},
> + {'name': 'utils', 'sources': ['utils.cpp']},
> + {'name': 'yaml-parser', 'sources': ['yaml-parser.cpp']},
> ]
>
> internal_non_parallel_tests = [
> - ['fence', 'fence.cpp'],
> - ['mapped-buffer', 'mapped-buffer.cpp'],
> + {'name': 'fence', 'sources': ['fence.cpp']},
> + {'name': 'mapped-buffer', 'sources': ['mapped-buffer.cpp']},
> ]
>
> foreach test : public_tests
> deps = [libcamera_public]
> - if test.length() > 2
> - deps += test[2]
> + if 'dependencies' in test
> + deps += test['dependencies']
> endif
>
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : deps,
> link_with : test_libraries,
> include_directories : test_includes_public)
>
> - test(test[0], exe)
> + test(test['name'], exe)
> endforeach
>
> foreach test : internal_tests
> deps = [libcamera_private]
> - if test.length() > 2
> - deps += test[2]
> + if 'dependencies' in test
> + deps += test['dependencies']
> endif
>
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : deps,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe)
> + test(test['name'], exe)
> endforeach
>
> foreach test : internal_non_parallel_tests
> deps = [libcamera_private]
> - if test.length() > 2
> - deps += test[2]
> + if 'dependencies' in test
> + deps += test['dependencies']
> endif
>
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : deps,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, is_parallel : false)
> + test(test['name'], exe, is_parallel : false)
> endforeach
> diff --git a/test/pipeline/ipu3/meson.build b/test/pipeline/ipu3/meson.build
> index 5fcf5730b0b0..af075707f505 100644
> --- a/test/pipeline/ipu3/meson.build
> +++ b/test/pipeline/ipu3/meson.build
> @@ -1,14 +1,14 @@
> # SPDX-License-Identifier: CC0-1.0
>
> ipu3_test = [
> - ['ipu3_pipeline_test', 'ipu3_pipeline_test.cpp'],
> + {'name': 'ipu3_pipeline_test', 'sources': ['ipu3_pipeline_test.cpp']},
> ]
>
> foreach test : ipu3_test
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'ipu3', is_parallel : false)
> + test(test['name'], exe, suite : 'ipu3', is_parallel : false)
> endforeach
> diff --git a/test/pipeline/rkisp1/meson.build b/test/pipeline/rkisp1/meson.build
> index c82cc78972f6..1d178ad9da6f 100644
> --- a/test/pipeline/rkisp1/meson.build
> +++ b/test/pipeline/rkisp1/meson.build
> @@ -1,14 +1,14 @@
> # SPDX-License-Identifier: CC0-1.0
>
> rkisp1_test = [
> - ['rkisp1_pipeline_test', 'rkisp1_pipeline_test.cpp'],
> + {'name': 'rkisp1_pipeline_test', 'sources': ['rkisp1_pipeline_test.cpp']},
> ]
>
> foreach test : rkisp1_test
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'rkisp1', is_parallel : false)
> + test(test['name'], exe, suite : 'rkisp1', is_parallel : false)
> endforeach
> diff --git a/test/process/meson.build b/test/process/meson.build
> index c656d7343e54..a80dc2d99fdd 100644
> --- a/test/process/meson.build
> +++ b/test/process/meson.build
> @@ -1,14 +1,14 @@
> # SPDX-License-Identifier: CC0-1.0
>
> process_tests = [
> - ['process_test', 'process_test.cpp'],
> + {'name': 'process_test', 'sources': ['process_test.cpp']},
> ]
>
> foreach test : process_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
>
> - test(test[0], exe, suite : 'process', is_parallel : false)
> + test(test['name'], exe, suite : 'process', is_parallel : false)
> endforeach
> diff --git a/test/serialization/meson.build b/test/serialization/meson.build
> index c4206cb3632b..a6e8d79358d9 100644
> --- a/test/serialization/meson.build
> +++ b/test/serialization/meson.build
> @@ -3,14 +3,14 @@
> subdir('generated_serializer')
>
> serialization_tests = [
> - ['control_serialization', 'control_serialization.cpp'],
> - ['ipa_data_serializer_test', 'ipa_data_serializer_test.cpp'],
> + {'name': 'control_serialization', 'sources': ['control_serialization.cpp']},
> + {'name': 'ipa_data_serializer_test', 'sources': ['ipa_data_serializer_test.cpp']},
> ]
>
> foreach test : serialization_tests
> - exe = executable(test[0], [test[1], 'serialization_test.cpp'],
> + exe = executable(test['name'], test['sources'], 'serialization_test.cpp',
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite : 'serialization', is_parallel : false)
> + test(test['name'], exe, suite : 'serialization', is_parallel : false)
> endforeach
> diff --git a/test/stream/meson.build b/test/stream/meson.build
> index 3a97868bce1c..a3b19bf592a5 100644
> --- a/test/stream/meson.build
> +++ b/test/stream/meson.build
> @@ -1,14 +1,14 @@
> # SPDX-License-Identifier: CC0-1.0
>
> stream_tests = [
> - ['stream_colorspace', 'stream_colorspace.cpp'],
> - ['stream_formats', 'stream_formats.cpp'],
> + {'name': 'stream_colorspace', 'sources': ['stream_colorspace.cpp']},
> + {'name': 'stream_formats', 'sources': ['stream_formats.cpp']},
> ]
>
> foreach test : stream_tests
> - exe = executable(test[0], test[1],
> + exe = executable(test['name'], test['sources'],
> dependencies : libcamera_public,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite: 'stream')
> + test(test['name'], exe, suite: 'stream')
> endforeach
> diff --git a/test/v4l2_subdevice/meson.build b/test/v4l2_subdevice/meson.build
> index 4e607d41fc54..277f29bbcc41 100644
> --- a/test/v4l2_subdevice/meson.build
> +++ b/test/v4l2_subdevice/meson.build
> @@ -1,14 +1,14 @@
> # SPDX-License-Identifier: CC0-1.0
>
> v4l2_subdevice_tests = [
> - ['list_formats', 'list_formats.cpp'],
> - ['test_formats', 'test_formats.cpp'],
> + {'name': 'list_formats', 'sources': ['list_formats.cpp']},
> + {'name': 'test_formats', 'sources': ['test_formats.cpp']},
> ]
>
> foreach test : v4l2_subdevice_tests
> - exe = executable(test[0], [test[1], 'v4l2_subdevice_test.cpp'],
> + exe = executable(test['name'], test['sources'], 'v4l2_subdevice_test.cpp',
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite : 'v4l2_subdevice', is_parallel : false)
> + test(test['name'], exe, suite : 'v4l2_subdevice', is_parallel : false)
> endforeach
> diff --git a/test/v4l2_videodevice/meson.build b/test/v4l2_videodevice/meson.build
> index f85374854c48..87ea4f966ff1 100644
> --- a/test/v4l2_videodevice/meson.build
> +++ b/test/v4l2_videodevice/meson.build
> @@ -3,22 +3,22 @@
> # Tests are listed in order of complexity.
> # They are not alphabetically sorted.
> v4l2_videodevice_tests = [
> - ['double_open', 'double_open.cpp'],
> - ['controls', 'controls.cpp'],
> - ['formats', 'formats.cpp'],
> - ['dequeue_watchdog', 'dequeue_watchdog.cpp'],
> - ['request_buffers', 'request_buffers.cpp'],
> - ['buffer_cache', 'buffer_cache.cpp'],
> - ['stream_on_off', 'stream_on_off.cpp'],
> - ['capture_async', 'capture_async.cpp'],
> - ['buffer_sharing', 'buffer_sharing.cpp'],
> - ['v4l2_m2mdevice', 'v4l2_m2mdevice.cpp'],
> + {'name': 'double_open', 'sources': ['double_open.cpp']},
> + {'name': 'controls', 'sources': ['controls.cpp']},
> + {'name': 'formats', 'sources': ['formats.cpp']},
> + {'name': 'dequeue_watchdog', 'sources': ['dequeue_watchdog.cpp']},
> + {'name': 'request_buffers', 'sources': ['request_buffers.cpp']},
> + {'name': 'buffer_cache', 'sources': ['buffer_cache.cpp']},
> + {'name': 'stream_on_off', 'sources': ['stream_on_off.cpp']},
> + {'name': 'capture_async', 'sources': ['capture_async.cpp']},
> + {'name': 'buffer_sharing', 'sources': ['buffer_sharing.cpp']},
> + {'name': 'v4l2_m2mdevice', 'sources': ['v4l2_m2mdevice.cpp']},
> ]
>
> foreach test : v4l2_videodevice_tests
> - exe = executable(test[0], [test[1], 'v4l2_videodevice_test.cpp'],
> + exe = executable(test['name'], [test['sources'], 'v4l2_videodevice_test.cpp'],
> dependencies : libcamera_private,
> link_with : test_libraries,
> include_directories : test_includes_internal)
> - test(test[0], exe, suite : 'v4l2_videodevice', is_parallel : false)
> + test(test['name'], exe, suite : 'v4l2_videodevice', is_parallel : false)
> endforeach
> --
> Regards,
>
> Laurent Pinchart
>
More information about the libcamera-devel
mailing list