From ac20ff2d9a2dcfff5b5e3dbe3c7771811f62f712 Mon Sep 17 00:00:00 2001 From: JarbasAi Date: Tue, 3 Oct 2023 03:58:30 +0100 Subject: [PATCH] fix/get_response_reprompting companion to https://github.com/OpenVoiceOS/OVOS-workshop/pull/139 --- requirements/requirements.txt | 2 +- .../session/skill-converse_test/__init__.py | 7 +- .../locale/en-us/test_get_response3.intent | 2 + test/end2end/session/test_get_response.py | 465 ++++++++++++++++-- 4 files changed, 437 insertions(+), 39 deletions(-) create mode 100644 test/end2end/session/skill-converse_test/locale/en-us/test_get_response3.intent diff --git a/requirements/requirements.txt b/requirements/requirements.txt index 572ff93d65df..ecf8b3316e32 100644 --- a/requirements/requirements.txt +++ b/requirements/requirements.txt @@ -12,7 +12,7 @@ ovos-plugin-manager<0.1.0, >=0.0.24a9 ovos-config~=0.0,>=0.0.11a13 ovos-lingua-franca>=0.4.7 ovos-backend-client>=0.1.0a12 -ovos-workshop<0.1.0, >=0.0.13a9 +ovos-workshop<0.1.0, >=0.0.13a10 # provides plugins and classic machine learning framework ovos-classifiers<0.1.0, >=0.0.0a37 diff --git a/test/end2end/session/skill-converse_test/__init__.py b/test/end2end/session/skill-converse_test/__init__.py index 4de290d77046..959ca9da16b5 100644 --- a/test/end2end/session/skill-converse_test/__init__.py +++ b/test/end2end/session/skill-converse_test/__init__.py @@ -38,7 +38,12 @@ def handle_intent_aborted(self): @intent_file_handler("test_get_response.intent") def handle_test_get_response(self, message): - ans = self.get_response("get") + ans = self.get_response("get", num_retries=1) + self.speak(ans or "ERROR") + + @intent_file_handler("test_get_response3.intent") + def handle_test_get_response3(self, message): + ans = self.get_response(num_retries=3) self.speak(ans or "ERROR") @killable_intent(callback=handle_intent_aborted) diff --git a/test/end2end/session/skill-converse_test/locale/en-us/test_get_response3.intent b/test/end2end/session/skill-converse_test/locale/en-us/test_get_response3.intent new file mode 100644 index 000000000000..484272aaa949 --- /dev/null +++ b/test/end2end/session/skill-converse_test/locale/en-us/test_get_response3.intent @@ -0,0 +1,2 @@ +3 prompts +three prompts \ No newline at end of file diff --git a/test/end2end/session/test_get_response.py b/test/end2end/session/test_get_response.py index cbbb41536480..9b641e79d651 100644 --- a/test/end2end/session/test_get_response.py +++ b/test/end2end/session/test_get_response.py @@ -37,7 +37,13 @@ def wait_for_n_messages(n): if time.time() - t > 10: raise RuntimeError("did not get the number of expected messages under 10 seconds") + def on_speak(msg): + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_start")) + sleep(1) # simulate TTS playback + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_end")) + self.core.bus.on("message", new_msg) + self.core.bus.on("speak", on_speak) # trigger get_response utt = Message("recognizer_loop:utterance", @@ -62,11 +68,17 @@ def wait_for_n_messages(n): "ovos.session.update_default", # sync get_response status "enclosure.active_skill", "speak", # 'mycroft.mic.listen' if no dialog passed to get_response + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", + # "recognizer_loop:utterance" would be here if user answered "skill.converse.get_response.disable", # end of get_response "ovos.session.update_default", # sync get_response status "enclosure.active_skill", # from speak inside intent "speak", # speak "ERROR" inside intent + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", + "mycroft.skill.handler.complete", # original intent finished executing # session updated at end of intent pipeline @@ -131,30 +143,35 @@ def wait_for_n_messages(n): self.assertEqual(messages[11].data["lang"], "en-us") self.assertTrue(messages[11].data["expect_response"]) # listen after dialog self.assertEqual(messages[11].data["meta"]["skill"], self.skill_id) + self.assertEqual(messages[12].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[13].msg_type, "recognizer_loop:audio_output_end") # user response would be here # disable get_response for this session - self.assertEqual(messages[12].msg_type, "skill.converse.get_response.disable") - self.assertEqual(messages[13].msg_type, "ovos.session.update_default") + self.assertEqual(messages[14].msg_type, "skill.converse.get_response.disable") + self.assertEqual(messages[15].msg_type, "ovos.session.update_default") # post self.get_response intent code - self.assertEqual(messages[14].msg_type, "enclosure.active_skill") - self.assertEqual(messages[14].data["skill_id"], self.skill_id) - self.assertEqual(messages[15].msg_type, "speak") - self.assertEqual(messages[15].data["lang"], "en-us") - self.assertFalse(messages[15].data["expect_response"]) - self.assertEqual(messages[15].data["utterance"], "ERROR") - self.assertEqual(messages[15].data["meta"]["skill"], self.skill_id) + self.assertEqual(messages[16].msg_type, "enclosure.active_skill") + self.assertEqual(messages[16].data["skill_id"], self.skill_id) + self.assertEqual(messages[17].msg_type, "speak") + self.assertEqual(messages[17].data["lang"], "en-us") + self.assertFalse(messages[17].data["expect_response"]) + self.assertEqual(messages[17].data["utterance"], "ERROR") + self.assertEqual(messages[17].data["meta"]["skill"], self.skill_id) + + self.assertEqual(messages[18].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[19].msg_type, "recognizer_loop:audio_output_end") - self.assertEqual(messages[16].msg_type, "mycroft.skill.handler.complete") - self.assertEqual(messages[16].data["name"], "TestAbortSkill.handle_test_get_response") + self.assertEqual(messages[20].msg_type, "mycroft.skill.handler.complete") + self.assertEqual(messages[20].data["name"], "TestAbortSkill.handle_test_get_response") # verify default session is now updated - self.assertEqual(messages[17].msg_type, "ovos.session.update_default") - self.assertEqual(messages[17].data["session_data"]["session_id"], "default") + self.assertEqual(messages[21].msg_type, "ovos.session.update_default") + self.assertEqual(messages[21].data["session_data"]["session_id"], "default") # test deserialization of payload - sess = Session.deserialize(messages[17].data["session_data"]) + sess = Session.deserialize(messages[21].data["session_data"]) self.assertEqual(sess.session_id, "default") def test_with_response(self): @@ -183,6 +200,9 @@ def wait_for_n_messages(n): self.core.bus.on("message", new_msg) def answer_get_response(msg): + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_start")) + sleep(1) # simulate TTS playback + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_end")) # end wait=True in self.speak if msg.data["utterance"] == "give me an answer": sleep(0.5) utt = Message("recognizer_loop:utterance", @@ -215,6 +235,8 @@ def answer_get_response(msg): "ovos.session.update_default", # sync get_response status "enclosure.active_skill", "speak", # 'mycroft.mic.listen' if no dialog passed to get_response + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", "recognizer_loop:utterance", # answer to get_response from user, # converse pipeline start @@ -233,6 +255,8 @@ def answer_get_response(msg): # intent code post self.get_response "enclosure.active_skill", # from speak inside intent "speak", # speak "ok" inside intent + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", "mycroft.skill.handler.complete", # original intent finished executing # session updated at end of intent pipeline @@ -290,42 +314,409 @@ def answer_get_response(msg): self.assertEqual(messages[11].data["lang"], "en-us") self.assertTrue(messages[11].data["expect_response"]) # listen after dialog self.assertEqual(messages[11].data["meta"]["skill"], self.skill_id) + # ovos-audio speak execution (simulated) + self.assertEqual(messages[12].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[13].msg_type, "recognizer_loop:audio_output_end") # check utterance goes through converse cycle - self.assertEqual(messages[12].msg_type, "recognizer_loop:utterance") - self.assertEqual(messages[13].msg_type, "skill.converse.ping") - self.assertEqual(messages[14].msg_type, "skill.converse.pong") - self.assertEqual(messages[15].msg_type, "skill.converse.pong") + self.assertEqual(messages[14].msg_type, "recognizer_loop:utterance") + self.assertEqual(messages[15].msg_type, "skill.converse.ping") + self.assertEqual(messages[16].msg_type, "skill.converse.pong") + self.assertEqual(messages[17].msg_type, "skill.converse.pong") # captured utterance sent to get_response handler that is waiting - self.assertEqual(messages[16].msg_type, "skill.converse.get_response") - self.assertEqual(messages[16].data["skill_id"], self.skill_id) - self.assertEqual(messages[16].data["utterances"], ["ok"]) + self.assertEqual(messages[18].msg_type, "skill.converse.get_response") + self.assertEqual(messages[18].data["skill_id"], self.skill_id) + self.assertEqual(messages[18].data["utterances"], ["ok"]) # converse pipeline activates the skill last_used timestamp - self.assertEqual(messages[17].msg_type, "intent.service.skills.activated") - self.assertEqual(messages[18].msg_type, f"{self.skill_id}.activate") - self.assertEqual(messages[19].msg_type, "ovos.session.update_default") + self.assertEqual(messages[19].msg_type, "intent.service.skills.activated") + self.assertEqual(messages[20].msg_type, f"{self.skill_id}.activate") + self.assertEqual(messages[21].msg_type, "ovos.session.update_default") # disable get_response for this session - self.assertEqual(messages[20].msg_type, "skill.converse.get_response.disable") + self.assertEqual(messages[22].msg_type, "skill.converse.get_response.disable") + self.assertEqual(messages[23].msg_type, "ovos.session.update_default") + + # post self.get_response intent code + self.assertEqual(messages[24].msg_type, "enclosure.active_skill") + self.assertEqual(messages[24].data["skill_id"], self.skill_id) + self.assertEqual(messages[25].msg_type, "speak") + self.assertEqual(messages[25].data["lang"], "en-us") + self.assertFalse(messages[25].data["expect_response"]) + self.assertEqual(messages[25].data["utterance"], "ok") + self.assertEqual(messages[25].data["meta"]["skill"], self.skill_id) + # ovos-audio speak execution (simulated) + self.assertEqual(messages[26].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[27].msg_type, "recognizer_loop:audio_output_end") + + self.assertEqual(messages[28].msg_type, "mycroft.skill.handler.complete") + self.assertEqual(messages[28].data["name"], "TestAbortSkill.handle_test_get_response") + + # verify default session is now updated + self.assertEqual(messages[29].msg_type, "ovos.session.update_default") + self.assertEqual(messages[29].data["session_data"]["session_id"], "default") + # test deserialization of payload + sess = Session.deserialize(messages[29].data["session_data"]) + self.assertEqual(sess.session_id, "default") + + def test_cancel_response(self): + SessionManager.sessions = {} + SessionManager.default_session = SessionManager.sessions["default"] = Session("default") + SessionManager.default_session.lang = "en-us" + + messages = [] + + def new_msg(msg): + nonlocal messages + m = Message.deserialize(msg) + if m.msg_type in ["ovos.skills.settings_changed"]: + return # skip these, only happen in 1st run + messages.append(m) + print(len(messages), msg) + + def wait_for_n_messages(n): + nonlocal messages + t = time.time() + while len(messages) < n: + sleep(0.1) + if time.time() - t > 10: + raise RuntimeError("did not get the number of expected messages under 10 seconds") + + self.core.bus.on("message", new_msg) + + def answer_get_response(msg): + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_start")) + sleep(1) # simulate TTS playback + self.core.bus.emit(msg.forward("recognizer_loop:audio_output_end")) # end wait=True in self.speak + if msg.data["utterance"] == "give me an answer": + sleep(0.5) + utt = Message("recognizer_loop:utterance", + {"utterances": ["cancel"]}, + {"session": SessionManager.default_session.serialize()}) + self.core.bus.emit(utt) + + self.core.bus.on("speak", answer_get_response) + + # trigger get_response + utt = Message("recognizer_loop:utterance", + {"utterances": ["test get response"]}) + self.core.bus.emit(utt) + + # confirm all expected messages are sent + expected_messages = [ + "recognizer_loop:utterance", # no session + "skill.converse.ping", # default session injected + "skill.converse.pong", # test skill + "skill.converse.pong", # hello world skill + + # skill selected + "intent.service.skills.activated", + f"{self.skill_id}.activate", + f"{self.skill_id}:test_get_response.intent", + + # intent code before self.get_response + "mycroft.skill.handler.start", + "skill.converse.get_response.enable", # start of get_response + "ovos.session.update_default", # sync get_response status + "enclosure.active_skill", + "speak", # 'mycroft.mic.listen' if no dialog passed to get_response + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", + + "recognizer_loop:utterance", # answer to get_response from user, + # converse pipeline start + "skill.converse.ping", + "skill.converse.pong", + "skill.converse.pong", + "skill.converse.get_response", # returning user utterance to running intent self.get_response + # skill selected by converse pipeline + "intent.service.skills.activated", + f"{self.skill_id}.activate", + "ovos.session.update_default", # sync skill activated by converse + + "skill.converse.get_response.disable", # end of get_response + "ovos.session.update_default", # sync get_response status + + # intent code post self.get_response + "enclosure.active_skill", # from speak inside intent + "speak", # speak "ERROR" inside intent + "recognizer_loop:audio_output_start", + "recognizer_loop:audio_output_end", + "mycroft.skill.handler.complete", # original intent finished executing + + # session updated at end of intent pipeline + "ovos.session.update_default" + + ] + wait_for_n_messages(len(expected_messages)) + + self.assertEqual(len(expected_messages), len(messages)) + + mtypes = [m.msg_type for m in messages] + for m in expected_messages: + self.assertTrue(m in mtypes) + + # verify that "session" is injected + # (missing in utterance message) and kept in all messages + for m in messages[1:]: + print(m.msg_type, m.context["session"]["session_id"]) + self.assertEqual(m.context["session"]["session_id"], "default") + + # converse intent pipeline + self.assertEqual(messages[1].msg_type, "skill.converse.ping") + self.assertEqual(messages[2].msg_type, "skill.converse.pong") + self.assertEqual(messages[3].msg_type, "skill.converse.pong") + self.assertEqual(messages[2].data["skill_id"], messages[2].context["skill_id"]) + self.assertEqual(messages[3].data["skill_id"], messages[3].context["skill_id"]) + # assert it reports converse method has been implemented by skill + if messages[2].data["skill_id"] == self.skill_id: # we dont know order of pong responses + self.assertTrue(messages[2].data["can_handle"]) + self.assertFalse(messages[3].data["can_handle"]) + if messages[3].data["skill_id"] == self.skill_id: # we dont know order of pong responses + self.assertTrue(messages[3].data["can_handle"]) + self.assertFalse(messages[2].data["can_handle"]) + + # verify skill is activated by intent service (intent pipeline matched) + self.assertEqual(messages[4].msg_type, "intent.service.skills.activated") + self.assertEqual(messages[4].data["skill_id"], self.skill_id) + self.assertEqual(messages[5].msg_type, f"{self.skill_id}.activate") + + # verify intent triggers + self.assertEqual(messages[6].msg_type, f"{self.skill_id}:test_get_response.intent") + + # verify intent execution + self.assertEqual(messages[7].msg_type, "mycroft.skill.handler.start") + self.assertEqual(messages[7].data["name"], "TestAbortSkill.handle_test_get_response") + + # enable get_response for this session + self.assertEqual(messages[8].msg_type, "skill.converse.get_response.enable") + self.assertEqual(messages[9].msg_type, "ovos.session.update_default") + + self.assertEqual(messages[10].msg_type, "enclosure.active_skill") + self.assertEqual(messages[10].data["skill_id"], self.skill_id) + self.assertEqual(messages[11].msg_type, "speak") + self.assertEqual(messages[11].data["utterance"], "give me an answer", ) + self.assertEqual(messages[11].data["lang"], "en-us") + self.assertTrue(messages[11].data["expect_response"]) # listen after dialog + self.assertEqual(messages[11].data["meta"]["skill"], self.skill_id) + # ovos-audio speak execution (simulated) + self.assertEqual(messages[12].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[13].msg_type, "recognizer_loop:audio_output_end") + + # check utterance goes through converse cycle + self.assertEqual(messages[14].msg_type, "recognizer_loop:utterance") + self.assertEqual(messages[15].msg_type, "skill.converse.ping") + self.assertEqual(messages[16].msg_type, "skill.converse.pong") + self.assertEqual(messages[17].msg_type, "skill.converse.pong") + + # captured utterance sent to get_response handler that is waiting + self.assertEqual(messages[18].msg_type, "skill.converse.get_response") + self.assertEqual(messages[18].data["skill_id"], self.skill_id) + self.assertEqual(messages[18].data["utterances"], ["cancel"]) # was canceled by user, returned None + + # converse pipeline activates the skill last_used timestamp + self.assertEqual(messages[19].msg_type, "intent.service.skills.activated") + self.assertEqual(messages[20].msg_type, f"{self.skill_id}.activate") self.assertEqual(messages[21].msg_type, "ovos.session.update_default") + # disable get_response for this session + self.assertEqual(messages[22].msg_type, "skill.converse.get_response.disable") + self.assertEqual(messages[23].msg_type, "ovos.session.update_default") + + # post self.get_response intent code + self.assertEqual(messages[24].msg_type, "enclosure.active_skill") + self.assertEqual(messages[24].data["skill_id"], self.skill_id) + self.assertEqual(messages[25].msg_type, "speak") + self.assertEqual(messages[25].data["lang"], "en-us") + self.assertFalse(messages[25].data["expect_response"]) + self.assertEqual(messages[25].data["utterance"], "ERROR") + self.assertEqual(messages[25].data["meta"]["skill"], self.skill_id) + # ovos-audio speak execution (simulated) + self.assertEqual(messages[26].msg_type, "recognizer_loop:audio_output_start") + self.assertEqual(messages[27].msg_type, "recognizer_loop:audio_output_end") + + self.assertEqual(messages[28].msg_type, "mycroft.skill.handler.complete") + self.assertEqual(messages[28].data["name"], "TestAbortSkill.handle_test_get_response") + + # verify default session is now updated + self.assertEqual(messages[29].msg_type, "ovos.session.update_default") + self.assertEqual(messages[29].data["session_data"]["session_id"], "default") + # test deserialization of payload + sess = Session.deserialize(messages[29].data["session_data"]) + self.assertEqual(sess.session_id, "default") + + def test_with_reprompt(self): + SessionManager.sessions = {} + SessionManager.default_session = SessionManager.sessions["default"] = Session("default") + SessionManager.default_session.lang = "en-us" + + messages = [] + + def new_msg(msg): + nonlocal messages + m = Message.deserialize(msg) + if m.msg_type in ["ovos.skills.settings_changed"]: + return # skip these, only happen in 1st run + messages.append(m) + print(len(messages), msg) + + def wait_for_n_messages(n): + nonlocal messages + t = time.time() + while len(messages) < n: + sleep(0.1) + if time.time() - t > 10: + raise RuntimeError("did not get the number of expected messages under 10 seconds") + + self.core.bus.on("message", new_msg) + + counter = 0 + + def answer_get_response(msg): + nonlocal counter + counter += 1 + if counter == 3: # answer on 3rd prompt only + sleep(0.5) + utt = Message("recognizer_loop:utterance", + {"utterances": ["ok"]}, + {"session": SessionManager.default_session.serialize()}) + self.core.bus.emit(utt) + + self.core.bus.on("mycroft.mic.listen", answer_get_response) + + # trigger get_response + utt = Message("recognizer_loop:utterance", + {"utterances": ["3 prompts"]}) + self.core.bus.emit(utt) + + # confirm all expected messages are sent + expected_messages = [ + "recognizer_loop:utterance", # no session + "skill.converse.ping", # default session injected + "skill.converse.pong", # test skill + "skill.converse.pong", # hello world skill + + # skill selected + "intent.service.skills.activated", + f"{self.skill_id}.activate", + f"{self.skill_id}:test_get_response3.intent", + + # intent code before self.get_response + "mycroft.skill.handler.start", + "skill.converse.get_response.enable", # start of get_response + "ovos.session.update_default", # sync get_response status + "mycroft.mic.listen", # no dialog in self.get_response + "mycroft.mic.listen", + "mycroft.mic.listen", + + "recognizer_loop:utterance", # answer to get_response from user, + # converse pipeline start + "skill.converse.ping", + "skill.converse.pong", + "skill.converse.pong", + "skill.converse.get_response", # returning user utterance to running intent self.get_response + # skill selected by converse pipeline + "intent.service.skills.activated", + f"{self.skill_id}.activate", + "ovos.session.update_default", # sync skill activated by converse + + "skill.converse.get_response.disable", # end of get_response + "ovos.session.update_default", # sync get_response status + + # intent code post self.get_response + "enclosure.active_skill", # from speak inside intent + "speak", # speak "ok" inside intent + "mycroft.skill.handler.complete", # original intent finished executing + + # session updated at end of intent pipeline + "ovos.session.update_default" + + ] + wait_for_n_messages(len(expected_messages)) + + self.assertEqual(len(expected_messages), len(messages)) + + mtypes = [m.msg_type for m in messages] + for m in expected_messages: + self.assertTrue(m in mtypes) + + # verify that "session" is injected + # (missing in utterance message) and kept in all messages + for m in messages[1:]: + print(m.msg_type, m.context["session"]["session_id"]) + self.assertEqual(m.context["session"]["session_id"], "default") + + # converse intent pipeline + self.assertEqual(messages[1].msg_type, "skill.converse.ping") + self.assertEqual(messages[2].msg_type, "skill.converse.pong") + self.assertEqual(messages[3].msg_type, "skill.converse.pong") + self.assertEqual(messages[2].data["skill_id"], messages[2].context["skill_id"]) + self.assertEqual(messages[3].data["skill_id"], messages[3].context["skill_id"]) + # assert it reports converse method has been implemented by skill + if messages[2].data["skill_id"] == self.skill_id: # we dont know order of pong responses + self.assertTrue(messages[2].data["can_handle"]) + self.assertFalse(messages[3].data["can_handle"]) + if messages[3].data["skill_id"] == self.skill_id: # we dont know order of pong responses + self.assertTrue(messages[3].data["can_handle"]) + self.assertFalse(messages[2].data["can_handle"]) + + # verify skill is activated by intent service (intent pipeline matched) + self.assertEqual(messages[4].msg_type, "intent.service.skills.activated") + self.assertEqual(messages[4].data["skill_id"], self.skill_id) + self.assertEqual(messages[5].msg_type, f"{self.skill_id}.activate") + + # verify intent triggers + self.assertEqual(messages[6].msg_type, f"{self.skill_id}:test_get_response3.intent") + + # verify intent execution + self.assertEqual(messages[7].msg_type, "mycroft.skill.handler.start") + self.assertEqual(messages[7].data["name"], "TestAbortSkill.handle_test_get_response3") + + # enable get_response for this session + self.assertEqual(messages[8].msg_type, "skill.converse.get_response.enable") + self.assertEqual(messages[9].msg_type, "ovos.session.update_default") + + # 3 sound prompts (no dialog in this test) + self.assertEqual(messages[10].msg_type, "mycroft.mic.listen") + self.assertEqual(messages[11].msg_type, "mycroft.mic.listen") + self.assertEqual(messages[12].msg_type, "mycroft.mic.listen") + + # check utterance goes through converse cycle + self.assertEqual(messages[13].msg_type, "recognizer_loop:utterance") + self.assertEqual(messages[14].msg_type, "skill.converse.ping") + self.assertEqual(messages[15].msg_type, "skill.converse.pong") + self.assertEqual(messages[16].msg_type, "skill.converse.pong") + + # captured utterance sent to get_response handler that is waiting + self.assertEqual(messages[17].msg_type, "skill.converse.get_response") + self.assertEqual(messages[17].data["skill_id"], self.skill_id) + self.assertEqual(messages[17].data["utterances"], ["ok"]) + + # converse pipeline activates the skill last_used timestamp + self.assertEqual(messages[18].msg_type, "intent.service.skills.activated") + self.assertEqual(messages[19].msg_type, f"{self.skill_id}.activate") + self.assertEqual(messages[20].msg_type, "ovos.session.update_default") + + # disable get_response for this session + self.assertEqual(messages[21].msg_type, "skill.converse.get_response.disable") + self.assertEqual(messages[22].msg_type, "ovos.session.update_default") + # post self.get_response intent code - self.assertEqual(messages[22].msg_type, "enclosure.active_skill") - self.assertEqual(messages[22].data["skill_id"], self.skill_id) - self.assertEqual(messages[23].msg_type, "speak") - self.assertEqual(messages[23].data["lang"], "en-us") - self.assertFalse(messages[23].data["expect_response"]) - self.assertEqual(messages[23].data["utterance"], "ok") - self.assertEqual(messages[23].data["meta"]["skill"], self.skill_id) + self.assertEqual(messages[23].msg_type, "enclosure.active_skill") + self.assertEqual(messages[23].data["skill_id"], self.skill_id) + self.assertEqual(messages[24].msg_type, "speak") + self.assertEqual(messages[24].data["lang"], "en-us") + self.assertFalse(messages[24].data["expect_response"]) + self.assertEqual(messages[24].data["utterance"], "ok") + self.assertEqual(messages[24].data["meta"]["skill"], self.skill_id) - self.assertEqual(messages[24].msg_type, "mycroft.skill.handler.complete") - self.assertEqual(messages[24].data["name"], "TestAbortSkill.handle_test_get_response") + self.assertEqual(messages[25].msg_type, "mycroft.skill.handler.complete") + self.assertEqual(messages[25].data["name"], "TestAbortSkill.handle_test_get_response3") # verify default session is now updated - self.assertEqual(messages[25].msg_type, "ovos.session.update_default") - self.assertEqual(messages[25].data["session_data"]["session_id"], "default") + self.assertEqual(messages[26].msg_type, "ovos.session.update_default") + self.assertEqual(messages[26].data["session_data"]["session_id"], "default") # test deserialization of payload - sess = Session.deserialize(messages[25].data["session_data"]) + sess = Session.deserialize(messages[26].data["session_data"]) self.assertEqual(sess.session_id, "default")