1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// Copyright (c) 2025 Contributors to the Eclipse Foundation
//
// See the NOTICE file(s) distributed with this work for additional
// information regarding copyright ownership.
//
// This program and the accompanying materials are made available under the
// terms of the Apache Software License 2.0 which is available at
// https://www.apache.org/licenses/LICENSE-2.0, or the MIT license
// which is available at https://opensource.org/licenses/MIT.
//
// SPDX-License-Identifier: Apache-2.0 OR MIT
/// This macro is used to instantiate conformance tests for a given set of system-under-test (SUT) types.
///
/// It generates a call to the specified conformance test, passing the provided SUT types as arguments
/// to the macro defined within the conformance test module.
///
/// NOTE: If the same conformance test need to be instantiated multiple times in the same file, the
/// macro needs to be wrapped in a Rust module for each instantiation. For this case, it is recommended
/// to use the `instantiate_conformance_tests_with_module`.
///
/// # Parameters
///
/// - `$conformance_test_module_path`: The path to the parent module where the conformance test module is defined.
/// - `$($sut_type:ty),+`: A comma-separated list of one or more system-under-test (SUT) types.
/// This is a convenience macro for `instantiate_conformance_tests`, to instantiate conformance tests
/// for a given set of system-under-test (SUT) types and automatically wrap them in a module.
///
/// It generates a call to the specified conformance test, passing the provided SUT types as arguments
/// to the macro defined within the conformance test module.
///
/// NOTE: If multiple conformance tests need to be instantiated in the same file, the `instantiate_conformance_tests`
/// macro can be used instead to simplify the handling.
///
/// # Parameters
///
/// - `$module_name`: The name of the module the conformance test shall be instantiated.
/// - `$conformance_test_module_path`: The path to the parent module where the conformance test module is defined.
/// - `$($sut_type:ty),+`: A comma-separated list of one or more system-under-test (SUT) types.