Skip to content

Commit f107dcd

Browse files
committed
feat(mdns): Console test: set instance for service
1 parent ee00e97 commit f107dcd

File tree

2 files changed

+39
-2
lines changed

2 files changed

+39
-2
lines changed

components/mdns/mdns_console.c

Lines changed: 18 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -818,6 +818,8 @@ static struct {
818818
struct arg_str *service;
819819
struct arg_str *proto;
820820
struct arg_str *instance;
821+
struct arg_str *host;
822+
struct arg_str *old_instance;
821823
struct arg_end *end;
822824
} mdns_service_instance_set_args;
823825

@@ -833,8 +835,20 @@ static int cmd_mdns_service_instance_set(int argc, char **argv)
833835
printf("ERROR: Bad arguments!\n");
834836
return 1;
835837
}
838+
const char *host = NULL;
839+
if (mdns_service_instance_set_args.host->count && mdns_service_instance_set_args.host->sval[0]) {
840+
host = mdns_service_instance_set_args.host->sval[0];
841+
}
842+
const char *old_instance = NULL;
843+
if (mdns_service_instance_set_args.old_instance->count && mdns_service_instance_set_args.old_instance->sval[0]) {
844+
old_instance = mdns_service_instance_set_args.old_instance->sval[0];
845+
}
846+
esp_err_t err = mdns_service_instance_name_set_for_host(old_instance, mdns_service_instance_set_args.service->sval[0], mdns_service_instance_set_args.proto->sval[0], host, mdns_service_instance_set_args.instance->sval[0]);
847+
if (err != ESP_OK) {
848+
printf("mdns_service_instance_name_set_for_host() failed with %s\n", esp_err_to_name(err));
849+
return 1;
850+
}
836851

837-
ESP_ERROR_CHECK( mdns_service_instance_name_set(mdns_service_instance_set_args.service->sval[0], mdns_service_instance_set_args.proto->sval[0], mdns_service_instance_set_args.instance->sval[0]) );
838852
return 0;
839853
}
840854

@@ -843,7 +857,9 @@ static void register_mdns_service_instance_set(void)
843857
mdns_service_instance_set_args.service = arg_str1(NULL, NULL, "<service>", "MDNS Service");
844858
mdns_service_instance_set_args.proto = arg_str1(NULL, NULL, "<proto>", "IP Protocol");
845859
mdns_service_instance_set_args.instance = arg_str1(NULL, NULL, "<instance>", "Instance name");
846-
mdns_service_instance_set_args.end = arg_end(2);
860+
mdns_service_instance_set_args.host = arg_str0("h", "host", "<hostname>", "Service for this (delegated) host");
861+
mdns_service_instance_set_args.old_instance = arg_str0("i", "old_instance", "<old_instance>", "Instance name before update");
862+
mdns_service_instance_set_args.end = arg_end(4);
847863

848864
const esp_console_cmd_t cmd_add = {
849865
.command = "mdns_service_instance_set",

components/mdns/tests/host_test/pytest_mdns.py

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -155,5 +155,26 @@ def test_service_subtype(mdns_console, dig_app):
155155
dig_app.check_record('_subtest2._sub._test2._tcp.local', query_type='PTR', expected=True)
156156

157157

158+
def test_service_set_instance(mdns_console, dig_app):
159+
dig_app.check_record('local._test._tcp.local', query_type='SRV', expected=True)
160+
mdns_console.send_input('mdns_service_instance_set _test _tcp local2')
161+
dig_app.check_record('local2._test._tcp.local', query_type='SRV', expected=True)
162+
mdns_console.send_input('mdns_service_instance_set _test2 _tcp extern2 -h delegated')
163+
mdns_console.send_input('mdns_service_lookup _test2 _tcp -d')
164+
mdns_console.get_output('PTR : extern2')
165+
dig_app.check_record('extern2._test2._tcp.local', query_type='SRV', expected=True)
166+
mdns_console.send_input('mdns_service_instance_set _test2 _tcp extern3 -h delegated -i extern')
167+
mdns_console.get_output('ESP_ERR_NOT_FOUND')
168+
169+
170+
def test_service_remove_all(mdns_console, dig_app):
171+
mdns_console.send_input('mdns_service_remove_all')
172+
mdns_console.send_input('mdns_service_lookup _test2 _tcp -d')
173+
mdns_console.get_output('No results found!')
174+
mdns_console.send_input('mdns_service_lookup _test _tcp')
175+
mdns_console.get_output('No results found!')
176+
dig_app.check_record('_test._tcp.local', query_type='PTR', expected=False)
177+
178+
158179
if __name__ == '__main__':
159180
pytest.main(['-s', 'test_mdns.py'])

0 commit comments

Comments
 (0)