From 8a9733177963387dc815273bbe476aeb43b80981 Mon Sep 17 00:00:00 2001 From: Churikova Tetiana Date: Fri, 4 Dec 2020 18:32:05 +0100 Subject: [PATCH] e2e: testrail report Signed-off-by: Churikova Tetiana --- test/appium/support/testrail_report.py | 37 +++++++++++++++++++ .../tests/atomic/chats/test_one_to_one.py | 1 - 2 files changed, 37 insertions(+), 1 deletion(-) diff --git a/test/appium/support/testrail_report.py b/test/appium/support/testrail_report.py index ff89a6c1f2..40eacbf2d7 100644 --- a/test/appium/support/testrail_report.py +++ b/test/appium/support/testrail_report.py @@ -106,6 +106,43 @@ class TestrailReport(BaseTestReport): 'comment': '%s' % ('# Error: \n %s \n' % emoji.demojize(last_testrun.error)) + devices + test_steps if last_testrun.error else devices + test_steps} self.post(method, data=data) + self.change_test_run_description() + + def change_test_run_description(self): + tests = self.get_all_tests() + passed_tests = self.get_passed_tests() + failed_tests = self.get_failed_tests() + if len(tests) > 0: + description_title = "# %.0f%% of end-end tests have passed\n" % (len(passed_tests) / len(tests) * 100) + description_title += "\n" + description_title += "Total executed tests: %d\n" % len(tests) + description_title += "Failed tests: %d\n" % len(failed_tests) + description_title += "Passed tests: %d\n" % len(passed_tests) + description_title += "\n" + ids_failed_test = [] + description = '' + if failed_tests: + for i, test in enumerate(failed_tests): + last_testrun = test.testruns[-1] + test_rail_link = self.get_test_result_link(self.run_id, test.testrail_case_id) + ids_failed_test.append(test.testrail_case_id) + case_title = '\n' + case_title += '-------\n' + case_title += "### %s) ID %s: [%s](%s) \n" % (i + 1, test.testrail_case_id, test.name, test_rail_link) + error ="```%s```\n" % last_testrun.error[:255] + for job_id, f in last_testrun.jobs.items(): + case_info = "Logs for device %d: [steps](%s), [failure screenshot](%s)"\ + % (f, + self.get_sauce_job_url(job_id), + self.get_sauce_final_screenshot_url(job_id)) + + description += case_title + error + case_info + description_title += '## Failed tests: %s \n' % ', '.join(map(str, ids_failed_test)) + final_description = description_title + description + + request_body = {'description': final_description} + return self.post('update_run/%s' % self.run_id, request_body) + def get_run_results(self): return self.get('get_results_for_run/%s' % self.run_id) diff --git a/test/appium/tests/atomic/chats/test_one_to_one.py b/test/appium/tests/atomic/chats/test_one_to_one.py index 3396557a48..e728a468e3 100644 --- a/test/appium/tests/atomic/chats/test_one_to_one.py +++ b/test/appium/tests/atomic/chats/test_one_to_one.py @@ -978,4 +978,3 @@ class TestMessagesOneToOneChatSingle(SingleDeviceTestCase): chat_view.get_back_to_home_view() self.errors.verify_no_errors() -