2019-01-10 17:20:45 +01:00
|
|
|
/* PipeWire
|
|
|
|
|
*
|
|
|
|
|
* Copyright © 2019 Wim Taymans
|
|
|
|
|
*
|
|
|
|
|
* 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 (including the next
|
|
|
|
|
* paragraph) 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.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <pipewire/pipewire.h>
|
|
|
|
|
|
|
|
|
|
#define TEST_FUNC(a,b,func) \
|
|
|
|
|
do { \
|
|
|
|
|
a.func = b.func; \
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(SPA_PTRDIFF(&a.func, &a) == SPA_PTRDIFF(&b.func, &b)); \
|
2019-01-10 17:20:45 +01:00
|
|
|
} while(0)
|
|
|
|
|
|
|
|
|
|
static void test_core_abi(void)
|
|
|
|
|
{
|
2021-06-27 17:47:13 +02:00
|
|
|
static const struct {
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 07:46:59 +01:00
|
|
|
const struct pw_core_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-03-01 14:04:05 +01:00
|
|
|
int (*hello) (void *object, uint32_t version);
|
|
|
|
|
int (*sync) (void *object, uint32_t id, int seq);
|
|
|
|
|
int (*pong) (void *object, uint32_t id, int seq);
|
|
|
|
|
int (*error) (void *object, uint32_t id, int seq, int res, const char *error);
|
2019-12-11 09:44:48 +01:00
|
|
|
struct pw_registry * (*get_registry) (void *object,
|
2019-05-20 16:11:23 +02:00
|
|
|
uint32_t version, size_t user_data_size);
|
|
|
|
|
void * (*create_object) (void *object,
|
2019-01-10 17:20:45 +01:00
|
|
|
const char *factory_name,
|
2019-12-19 13:15:10 +01:00
|
|
|
const char *type,
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t version,
|
|
|
|
|
const struct spa_dict *props,
|
2019-05-20 16:11:23 +02:00
|
|
|
size_t user_data_size);
|
|
|
|
|
int (*destroy) (void *object, void *proxy);
|
2019-12-11 07:46:59 +01:00
|
|
|
} methods = { PW_VERSION_CORE_METHODS, };
|
2021-06-27 17:47:13 +02:00
|
|
|
static const struct {
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_core_info *info);
|
|
|
|
|
void (*done) (void *data, uint32_t id, int seq);
|
|
|
|
|
void (*ping) (void *data, uint32_t id, int seq);
|
|
|
|
|
void (*error) (void *data, uint32_t id, int seq, int res, const char *error);
|
|
|
|
|
void (*remove_id) (void *data, uint32_t id);
|
|
|
|
|
void (*bound_id) (void *data, uint32_t id, uint32_t global_id);
|
|
|
|
|
void (*add_mem) (void *data, uint32_t id, uint32_t type, int fd, uint32_t flags);
|
|
|
|
|
void (*remove_mem) (void *data, uint32_t id);
|
2019-12-11 07:46:59 +01:00
|
|
|
} events = { PW_VERSION_CORE_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
2021-06-27 17:47:13 +02:00
|
|
|
struct pw_core_events e;
|
|
|
|
|
struct pw_core_methods m;
|
|
|
|
|
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, hello);
|
|
|
|
|
TEST_FUNC(m, methods, sync);
|
2019-03-01 14:04:05 +01:00
|
|
|
TEST_FUNC(m, methods, pong);
|
|
|
|
|
TEST_FUNC(m, methods, error);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, get_registry);
|
|
|
|
|
TEST_FUNC(m, methods, create_object);
|
|
|
|
|
TEST_FUNC(m, methods, destroy);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_CORE_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
2019-02-18 12:31:36 +01:00
|
|
|
TEST_FUNC(e, events, info);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(e, events, done);
|
2019-03-01 14:04:05 +01:00
|
|
|
TEST_FUNC(e, events, ping);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(e, events, error);
|
|
|
|
|
TEST_FUNC(e, events, remove_id);
|
2019-11-28 11:50:17 +01:00
|
|
|
TEST_FUNC(e, events, bound_id);
|
2019-07-29 17:13:13 +02:00
|
|
|
TEST_FUNC(e, events, add_mem);
|
|
|
|
|
TEST_FUNC(e, events, remove_mem);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_CORE_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_registry_abi(void)
|
|
|
|
|
{
|
2019-12-11 09:44:48 +01:00
|
|
|
struct pw_registry_methods m;
|
|
|
|
|
struct pw_registry_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 09:44:48 +01:00
|
|
|
const struct pw_registry_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-12-19 13:15:10 +01:00
|
|
|
void * (*bind) (void *object, uint32_t id, const char *type, uint32_t version,
|
2019-05-20 16:11:23 +02:00
|
|
|
size_t user_data_size);
|
2019-02-18 12:31:36 +01:00
|
|
|
int (*destroy) (void *object, uint32_t id);
|
2019-12-11 09:44:48 +01:00
|
|
|
} methods = { PW_VERSION_REGISTRY_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*global) (void *data, uint32_t id,
|
2019-12-19 13:15:10 +01:00
|
|
|
uint32_t permissions, const char *type, uint32_t version,
|
2019-01-10 17:20:45 +01:00
|
|
|
const struct spa_dict *props);
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*global_remove) (void *data, uint32_t id);
|
2019-12-11 09:44:48 +01:00
|
|
|
} events = { PW_VERSION_REGISTRY_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, bind);
|
|
|
|
|
TEST_FUNC(m, methods, destroy);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_REGISTRY_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, global);
|
|
|
|
|
TEST_FUNC(e, events, global_remove);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_REGISTRY_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_module_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:16:30 +01:00
|
|
|
struct pw_module_methods m;
|
|
|
|
|
struct pw_module_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:16:30 +01:00
|
|
|
const struct pw_module_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-12-11 15:16:30 +01:00
|
|
|
} methods = { PW_VERSION_MODULE_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_module_info *info);
|
2019-12-11 15:16:30 +01:00
|
|
|
} events = { PW_VERSION_MODULE_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_MODULE_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_MODULE_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_device_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:00:41 +01:00
|
|
|
struct pw_device_methods m;
|
|
|
|
|
struct pw_device_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:00:41 +01:00
|
|
|
const struct pw_device_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2020-02-12 16:05:08 +01:00
|
|
|
int (*subscribe_params) (void *object, uint32_t *ids, uint32_t n_ids);
|
2019-02-25 16:25:27 +01:00
|
|
|
int (*enum_params) (void *object, int seq, uint32_t id,
|
2019-02-25 12:29:57 +01:00
|
|
|
uint32_t start, uint32_t num,
|
2019-01-10 17:20:45 +01:00
|
|
|
const struct spa_pod *filter);
|
2019-02-18 12:31:36 +01:00
|
|
|
int (*set_param) (void *object, uint32_t id, uint32_t flags,
|
2019-01-10 17:20:45 +01:00
|
|
|
const struct spa_pod *param);
|
2019-12-11 15:00:41 +01:00
|
|
|
} methods = { PW_VERSION_DEVICE_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_device_info *info);
|
|
|
|
|
void (*param) (void *data, int seq,
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t id, uint32_t index, uint32_t next,
|
|
|
|
|
const struct spa_pod *param);
|
2019-12-11 15:00:41 +01:00
|
|
|
} events = { PW_VERSION_DEVICE_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2020-02-12 16:05:08 +01:00
|
|
|
TEST_FUNC(m, methods, subscribe_params);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, enum_params);
|
|
|
|
|
TEST_FUNC(m, methods, set_param);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_DEVICE_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
|
|
|
|
TEST_FUNC(e, events, param);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_DEVICE_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_node_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:26:11 +01:00
|
|
|
struct pw_node_methods m;
|
|
|
|
|
struct pw_node_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:26:11 +01:00
|
|
|
const struct pw_node_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-03-18 16:34:07 +01:00
|
|
|
int (*subscribe_params) (void *object, uint32_t *ids, uint32_t n_ids);
|
2019-02-25 16:25:27 +01:00
|
|
|
int (*enum_params) (void *object, int seq, uint32_t id,
|
2019-02-25 12:29:57 +01:00
|
|
|
uint32_t start, uint32_t num, const struct spa_pod *filter);
|
2019-02-18 12:31:36 +01:00
|
|
|
int (*set_param) (void *object, uint32_t id, uint32_t flags,
|
2019-01-10 17:20:45 +01:00
|
|
|
const struct spa_pod *param);
|
2019-02-18 12:31:36 +01:00
|
|
|
int (*send_command) (void *object, const struct spa_command *command);
|
2019-12-11 15:26:11 +01:00
|
|
|
} methods = { PW_VERSION_NODE_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_node_info *info);
|
|
|
|
|
void (*param) (void *data, int seq,
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t id, uint32_t index, uint32_t next,
|
|
|
|
|
const struct spa_pod *param);
|
2019-12-11 15:26:11 +01:00
|
|
|
} events = { PW_VERSION_NODE_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2019-03-18 16:34:07 +01:00
|
|
|
TEST_FUNC(m, methods, subscribe_params);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, enum_params);
|
|
|
|
|
TEST_FUNC(m, methods, set_param);
|
|
|
|
|
TEST_FUNC(m, methods, send_command);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_NODE_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
|
|
|
|
TEST_FUNC(e, events, param);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_NODE_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_port_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:59:26 +01:00
|
|
|
struct pw_port_methods m;
|
|
|
|
|
struct pw_port_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:59:26 +01:00
|
|
|
const struct pw_port_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-03-18 16:34:07 +01:00
|
|
|
int (*subscribe_params) (void *object, uint32_t *ids, uint32_t n_ids);
|
2019-02-25 16:25:27 +01:00
|
|
|
int (*enum_params) (void *object, int seq, uint32_t id,
|
2019-02-25 12:29:57 +01:00
|
|
|
uint32_t start, uint32_t num, const struct spa_pod *filter);
|
2019-12-11 15:59:26 +01:00
|
|
|
} methods = { PW_VERSION_PORT_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_port_info *info);
|
|
|
|
|
void (*param) (void *data, int seq,
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t id, uint32_t index, uint32_t next,
|
|
|
|
|
const struct spa_pod *param);
|
2019-12-11 15:59:26 +01:00
|
|
|
} events = { PW_VERSION_PORT_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, enum_params);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_PORT_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
|
|
|
|
TEST_FUNC(e, events, param);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_PORT_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_factory_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:06:00 +01:00
|
|
|
struct pw_factory_methods m;
|
|
|
|
|
struct pw_factory_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:06:00 +01:00
|
|
|
const struct pw_factory_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-12-11 15:06:00 +01:00
|
|
|
} methods = { PW_VERSION_FACTORY_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_factory_info *info);
|
2019-12-11 15:06:00 +01:00
|
|
|
} events = { PW_VERSION_FACTORY_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_FACTORY_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_FACTORY_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_client_abi(void)
|
|
|
|
|
{
|
2019-12-11 14:53:39 +01:00
|
|
|
struct pw_client_methods m;
|
|
|
|
|
struct pw_client_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 14:53:39 +01:00
|
|
|
const struct pw_client_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-02-18 12:31:36 +01:00
|
|
|
int (*error) (void *object, uint32_t id, int res, const char *error);
|
|
|
|
|
int (*update_properties) (void *object, const struct spa_dict *props);
|
|
|
|
|
int (*get_permissions) (void *object, uint32_t index, uint32_t num);
|
|
|
|
|
int (*update_permissions) (void *object, uint32_t n_permissions,
|
2019-01-10 17:20:45 +01:00
|
|
|
const struct pw_permission *permissions);
|
2019-12-11 14:53:39 +01:00
|
|
|
} methods = { PW_VERSION_CLIENT_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_client_info *info);
|
|
|
|
|
void (*permissions) (void *data, uint32_t index,
|
2019-01-10 17:20:45 +01:00
|
|
|
uint32_t n_permissions, const struct pw_permission *permissions);
|
2019-12-11 14:53:39 +01:00
|
|
|
} events = { PW_VERSION_CLIENT_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
|
|
|
|
TEST_FUNC(m, methods, error);
|
2019-01-10 17:20:45 +01:00
|
|
|
TEST_FUNC(m, methods, update_properties);
|
|
|
|
|
TEST_FUNC(m, methods, get_permissions);
|
|
|
|
|
TEST_FUNC(m, methods, update_permissions);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_CLIENT_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
|
|
|
|
TEST_FUNC(e, events, permissions);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_CLIENT_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void test_link_abi(void)
|
|
|
|
|
{
|
2019-12-11 15:11:56 +01:00
|
|
|
struct pw_link_methods m;
|
|
|
|
|
struct pw_link_events e;
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2019-05-20 16:11:23 +02:00
|
|
|
int (*add_listener) (void *object,
|
|
|
|
|
struct spa_hook *listener,
|
2019-12-11 15:11:56 +01:00
|
|
|
const struct pw_link_events *events,
|
2019-05-20 16:11:23 +02:00
|
|
|
void *data);
|
2019-12-11 15:11:56 +01:00
|
|
|
} methods = { PW_VERSION_LINK_METHODS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
struct {
|
|
|
|
|
uint32_t version;
|
2021-09-27 15:09:32 +02:00
|
|
|
void (*info) (void *data, const struct pw_link_info *info);
|
2019-12-11 15:11:56 +01:00
|
|
|
} events = { PW_VERSION_LINK_EVENTS, };
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(m, methods, version);
|
2019-05-20 16:11:23 +02:00
|
|
|
TEST_FUNC(m, methods, add_listener);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_LINK_METHODS == 0);
|
|
|
|
|
spa_assert_se(sizeof(m) == sizeof(methods));
|
2019-01-10 17:20:45 +01:00
|
|
|
|
|
|
|
|
TEST_FUNC(e, events, version);
|
|
|
|
|
TEST_FUNC(e, events, info);
|
2021-07-27 09:59:41 +10:00
|
|
|
spa_assert_se(PW_VERSION_LINK_EVENTS == 0);
|
|
|
|
|
spa_assert_se(sizeof(e) == sizeof(events));
|
2019-01-10 17:20:45 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
|
{
|
|
|
|
|
pw_init(&argc, &argv);
|
|
|
|
|
|
|
|
|
|
test_core_abi();
|
|
|
|
|
test_registry_abi();
|
|
|
|
|
test_module_abi();
|
|
|
|
|
test_device_abi();
|
|
|
|
|
test_node_abi();
|
|
|
|
|
test_port_abi();
|
|
|
|
|
test_factory_abi();
|
|
|
|
|
test_client_abi();
|
|
|
|
|
test_link_abi();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|