From 138d4825106b744ece1581a7ee763d2a919fd221 Mon Sep 17 00:00:00 2001 From: ejurgensen Date: Wed, 27 May 2020 16:34:15 +0200 Subject: [PATCH] [dummy] Add capability to mock device verification for testing --- src/outputs/dummy.c | 43 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 42 insertions(+), 1 deletion(-) diff --git a/src/outputs/dummy.c b/src/outputs/dummy.c index 9de6e85a..45adf728 100644 --- a/src/outputs/dummy.c +++ b/src/outputs/dummy.c @@ -27,6 +27,7 @@ #include #include +#include #include #include #include @@ -39,6 +40,10 @@ #include "player.h" #include "outputs.h" +// If you set this to 1 you can mock device verification with the dummy output, +// use 1234 as PIN +#define DUMMY_DEVICE_VERIFICATION_TEST 0 + struct dummy_session { enum output_device_state state; @@ -97,7 +102,7 @@ dummy_status(struct dummy_session *ds) { outputs_cb(ds->callback_id, ds->device_id, ds->state); - if (ds->state == OUTPUT_STATE_STOPPED) + if (ds->state <= OUTPUT_STATE_STOPPED) dummy_session_cleanup(ds); } @@ -113,6 +118,10 @@ dummy_device_start(struct output_device *device, int callback_id) if (!ds) return -1; + // Mock a denied connection + if (device->requires_auth && !device->auth_key) + ds->state = OUTPUT_STATE_PASSWORD; + dummy_status(ds); return 1; @@ -156,6 +165,10 @@ dummy_device_probe(struct output_device *device, int callback_id) ds->callback_id = callback_id; ds->state = OUTPUT_STATE_STOPPED; + // Mock a denied connection + if (device->requires_auth && !device->auth_key) + ds->state = OUTPUT_STATE_PASSWORD; + dummy_status(ds); return 1; @@ -175,6 +188,32 @@ dummy_device_volume_set(struct output_device *device, int callback_id) return 1; } +static int +dummy_device_authorize(struct output_device *device, const char *pin, int callback_id) +{ + struct dummy_session *ds; + + ds = dummy_session_make(device, callback_id); + if (!ds) + return -1; + + if (strcmp(pin, "1234") == 0) + { + free(device->auth_key); + device->auth_key = strdup("test"); + ds->state = OUTPUT_STATE_STOPPED; + } + else + { + ds->state = OUTPUT_STATE_PASSWORD; + } + + ds->callback_id = callback_id; + dummy_status(ds); + + return 1; +} + static void dummy_device_cb_set(struct output_device *device, int callback_id) { @@ -205,6 +244,7 @@ dummy_init(void) device->type = OUTPUT_TYPE_DUMMY; device->type_name = outputs_name(device->type); device->has_video = 0; + device->requires_auth = DUMMY_DEVICE_VERIFICATION_TEST; DPRINTF(E_INFO, L_LAUDIO, "Adding dummy output device '%s'\n", nickname); @@ -232,5 +272,6 @@ struct output_definition output_dummy = .device_flush = dummy_device_flush, .device_probe = dummy_device_probe, .device_volume_set = dummy_device_volume_set, + .device_authorize = dummy_device_authorize, .device_cb_set = dummy_device_cb_set, };