2018-08-15 15:51:52 +03:00
|
|
|
import time
|
2018-04-26 15:34:15 +03:00
|
|
|
import json
|
|
|
|
import hmac
|
|
|
|
import os
|
|
|
|
from hashlib import md5
|
2018-08-15 15:51:52 +03:00
|
|
|
from sauceclient import SauceException
|
|
|
|
|
2018-04-28 11:02:39 +02:00
|
|
|
from support.test_data import SingleTestData
|
2018-04-26 15:34:15 +03:00
|
|
|
|
|
|
|
|
|
|
|
class BaseTestReport:
|
|
|
|
TEST_REPORT_DIR = "%s/../report" % os.path.dirname(os.path.abspath(__file__))
|
|
|
|
|
|
|
|
def __init__(self, sauce_username, sauce_access_key):
|
|
|
|
self.sauce_username = sauce_username
|
|
|
|
self.sauce_access_key = sauce_access_key
|
|
|
|
self.init_report()
|
|
|
|
|
|
|
|
def init_report(self):
|
|
|
|
if not os.path.exists(self.TEST_REPORT_DIR):
|
|
|
|
os.makedirs(self.TEST_REPORT_DIR)
|
|
|
|
# delete all old files in report dir
|
|
|
|
file_list = [f for f in os.listdir(self.TEST_REPORT_DIR)]
|
|
|
|
for f in file_list:
|
|
|
|
os.remove(os.path.join(self.TEST_REPORT_DIR, f))
|
|
|
|
|
|
|
|
def get_test_report_file_path(self, test_name):
|
|
|
|
file_name = "%s.json" % test_name
|
|
|
|
return os.path.join(self.TEST_REPORT_DIR, file_name)
|
|
|
|
|
|
|
|
def save_test(self, test):
|
|
|
|
file_path = self.get_test_report_file_path(test.name)
|
2018-04-28 11:02:39 +02:00
|
|
|
test_dict = {
|
|
|
|
'testrail_case_id': test.testrail_case_id,
|
|
|
|
'name': test.name,
|
|
|
|
'testruns': list()
|
|
|
|
}
|
|
|
|
for testrun in test.testruns:
|
|
|
|
test_dict['testruns'].append(testrun.__dict__)
|
|
|
|
json.dump(test_dict, open(file_path, 'w'))
|
2018-04-26 15:34:15 +03:00
|
|
|
|
|
|
|
def get_all_tests(self):
|
|
|
|
tests = list()
|
|
|
|
file_list = [f for f in os.listdir(self.TEST_REPORT_DIR)]
|
|
|
|
for file_name in file_list:
|
|
|
|
file_path = os.path.join(self.TEST_REPORT_DIR, file_name)
|
2018-04-28 11:02:39 +02:00
|
|
|
test_data = json.load(open(file_path))
|
|
|
|
testruns = list()
|
|
|
|
for testrun_data in test_data['testruns']:
|
|
|
|
testruns.append(SingleTestData.TestRunData(
|
|
|
|
steps=testrun_data['steps'], jobs=testrun_data['jobs'], error=testrun_data['error']))
|
|
|
|
tests.append(SingleTestData(name=test_data['name'], testruns=testruns,
|
|
|
|
testrail_case_id=test_data['testrail_case_id']))
|
2018-04-26 15:34:15 +03:00
|
|
|
return tests
|
|
|
|
|
|
|
|
def get_failed_tests(self):
|
|
|
|
tests = self.get_all_tests()
|
|
|
|
failed = list()
|
|
|
|
for test in tests:
|
2018-04-28 11:02:39 +02:00
|
|
|
if not self.is_test_successful(test):
|
2018-04-26 15:34:15 +03:00
|
|
|
failed.append(test)
|
|
|
|
return failed
|
|
|
|
|
|
|
|
def get_passed_tests(self):
|
|
|
|
tests = self.get_all_tests()
|
|
|
|
passed = list()
|
|
|
|
for test in tests:
|
2018-04-28 11:02:39 +02:00
|
|
|
if self.is_test_successful(test):
|
2018-04-26 15:34:15 +03:00
|
|
|
passed.append(test)
|
|
|
|
return passed
|
|
|
|
|
2018-08-15 15:51:52 +03:00
|
|
|
def get_sauce_token(self, job_id):
|
|
|
|
return hmac.new(bytes(self.sauce_username + ":" + self.sauce_access_key, 'latin-1'),
|
|
|
|
bytes(job_id, 'latin-1'), md5).hexdigest()
|
|
|
|
|
2018-04-26 15:34:15 +03:00
|
|
|
def get_sauce_job_url(self, job_id):
|
2018-08-15 15:51:52 +03:00
|
|
|
token = self.get_sauce_token(job_id)
|
|
|
|
return 'https://saucelabs.com/jobs/%s?auth=%s' % (job_id, token)
|
|
|
|
|
|
|
|
def get_sauce_final_screenshot_url(self, job_id):
|
|
|
|
token = self.get_sauce_token(job_id)
|
|
|
|
from tests.conftest import sauce
|
|
|
|
for _ in range(10):
|
|
|
|
try:
|
|
|
|
scr_number = sauce.jobs.get_job_assets(job_id)['screenshots'][-1]
|
|
|
|
return 'https://assets.saucelabs.com/jobs/%s/%s?auth=%s' % (job_id, scr_number, token)
|
|
|
|
except SauceException:
|
|
|
|
time.sleep(3)
|
2018-04-28 11:02:39 +02:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def is_test_successful(test):
|
|
|
|
# Test passed if last testrun has passed
|
|
|
|
return test.testruns[-1].error is None
|