diff --git a/unit/test-mgmt.c b/unit/test-mgmt.c
index 7bff828..a610d1a 100644
--- a/unit/test-mgmt.c
+++ b/unit/test-mgmt.c
struct context {
GMainLoop *main_loop;
+ int fd;
struct mgmt *mgmt_client;
guint server_source;
GList *handler_list;
err = socketpair(AF_UNIX, SOCK_SEQPACKET | SOCK_CLOEXEC, 0, sv);
g_assert(err == 0);
+ context->fd = sv[0];
channel = g_io_channel_unix_new(sv[0]);
g_io_channel_set_close_on_unref(channel, TRUE);
.rsp_status = MGMT_STATUS_INVALID_INDEX,
};
+static const unsigned char event_index_added[] =
+ { 0x04, 0x00, 0x01, 0x00, 0x00, 0x00 };
+
+static const struct command_test_data event_test_1 = {
+ .opcode = MGMT_EV_INDEX_ADDED,
+ .index = MGMT_INDEX_NONE,
+ .cmd_data = event_index_added,
+ .cmd_size = sizeof(event_index_added),
+};
+
static void test_command(gconstpointer data)
{
const struct command_test_data *test = data;
execute_context(context);
}
+static void event_cb(uint16_t index, uint16_t length, const void *param,
+ void *user_data)
+{
+ struct context *context = user_data;
+
+ context_quit(context);
+}
+
+static void test_event(gconstpointer data)
+{
+ const struct command_test_data *test = data;
+ struct context *context = create_context();
+
+ mgmt_register(context->mgmt_client, test->opcode, test->index,
+ event_cb, context, NULL);
+
+ g_assert_cmpint(write(context->fd, test->cmd_data, test->cmd_size), ==,
+ test->cmd_size);
+
+ execute_context(context);
+}
+
int main(int argc, char *argv[])
{
g_test_init(&argc, &argv, NULL);
g_test_add_data_func("/mgmt/response/2", &command_test_3,
test_response);
+ g_test_add_data_func("/mgmt/event/1", &event_test_1, test_event);
+
return g_test_run();
}