e2e: pulling geth log in teardown if setup is failed

This commit is contained in:
Yevheniia Berdnyk 2023-08-10 00:26:13 +03:00
parent 1cb16b4945
commit 8bab9f8f22
No known key found for this signature in database
GPG Key ID: 0642C73C66214825
3 changed files with 44 additions and 35 deletions

View File

@ -12,15 +12,12 @@ import requests
from appium import webdriver from appium import webdriver
from appium.webdriver.common.mobileby import MobileBy from appium.webdriver.common.mobileby import MobileBy
from sauceclient import SauceException from sauceclient import SauceException
from selenium.common.exceptions import NoSuchElementException from selenium.common.exceptions import NoSuchElementException, TimeoutException, WebDriverException
from selenium.common.exceptions import WebDriverException
from selenium.common.exceptions import TimeoutException
from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support.wait import WebDriverWait
from urllib3.exceptions import MaxRetryError, ProtocolError from urllib3.exceptions import MaxRetryError, ProtocolError
from support.api.network_api import NetworkApi from support.api.network_api import NetworkApi
from tests import test_suite_data, start_threads, appium_container, pytest_config_global from tests import test_suite_data, start_threads, appium_container, pytest_config_global, transl
from tests import transl
from tests.conftest import sauce_username, sauce_access_key, apibase, github_report from tests.conftest import sauce_username, sauce_access_key, apibase, github_report
executor_sauce_lab = 'https://%s:%s@ondemand.%s:443/wd/hub' % (sauce_username, sauce_access_key, apibase) executor_sauce_lab = 'https://%s:%s@ondemand.%s:443/wd/hub' % (sauce_username, sauce_access_key, apibase)
@ -90,6 +87,24 @@ def update_capabilities_sauce_lab(new_capabilities: dict):
return caps return caps
def get_app_path():
app_folder = 'im.status.ethereum'
apk = pytest_config_global['apk']
if re.findall(r'pr\d\d\d\d\d', apk) or re.findall(r'\d\d\d\d\d.apk', apk):
app_folder += '.pr'
app_path = '/storage/emulated/0/Android/data/%s/files/Download/' % app_folder
return app_path
def get_geth_path():
return get_app_path() + 'geth.log'
def pull_geth(driver):
result = driver.pull_file(get_geth_path())
return base64.b64decode(result)
class AbstractTestCase: class AbstractTestCase:
__metaclass__ = ABCMeta __metaclass__ = ABCMeta
@ -101,19 +116,6 @@ class AbstractTestCase:
def get_translation_by_key(self, key): def get_translation_by_key(self, key):
return transl[key] return transl[key]
@property
def app_path(self):
app_folder = 'im.status.ethereum'
apk = pytest_config_global['apk']
if re.findall(r'pr\d\d\d\d\d', apk) or re.findall(r'\d\d\d\d\d.apk', apk):
app_folder += '.pr'
app_path = '/storage/emulated/0/Android/data/%s/files/Download/' % app_folder
return app_path
@property
def geth_path(self):
return self.app_path + 'geth.log'
@abstractmethod @abstractmethod
def setup_method(self, method): def setup_method(self, method):
raise NotImplementedError('Should be overridden from a child class') raise NotImplementedError('Should be overridden from a child class')
@ -146,14 +148,6 @@ class AbstractTestCase:
test_suite_data.current_test.testruns[-1].error = "%s; \n RemoteDisconnected" % \ test_suite_data.current_test.testruns[-1].error = "%s; \n RemoteDisconnected" % \
test_suite_data.current_test.testruns[-1].error test_suite_data.current_test.testruns[-1].error
def pull_geth(self, driver):
result = ""
# try:
result = driver.pull_file(self.geth_path)
# except WebDriverException:
# pass
return base64.b64decode(result)
class Driver(webdriver.Remote): class Driver(webdriver.Remote):
@ -207,7 +201,7 @@ class SingleDeviceTestCase(AbstractTestCase):
self.print_sauce_lab_info(self.driver) self.print_sauce_lab_info(self.driver)
try: try:
self.add_alert_text_to_report(self.driver) self.add_alert_text_to_report(self.driver)
geth_content = self.pull_geth(self.driver) geth_content = pull_geth(self.driver)
self.driver.quit() self.driver.quit()
if pytest_config_global['docker']: if pytest_config_global['docker']:
appium_container.stop_container() appium_container.stop_container()
@ -215,7 +209,7 @@ class SingleDeviceTestCase(AbstractTestCase):
pass pass
finally: finally:
github_report.save_test(test_suite_data.current_test, github_report.save_test(test_suite_data.current_test,
{'%s_geth.log' % test_suite_data.current_test.name: geth_content}) {'%s_geth.log' % test_suite_data.current_test.name: geth_content})
class LocalMultipleDeviceTestCase(AbstractTestCase): class LocalMultipleDeviceTestCase(AbstractTestCase):
@ -271,7 +265,7 @@ class SauceMultipleDeviceTestCase(AbstractTestCase):
self.add_alert_text_to_report(self.drivers[driver]) self.add_alert_text_to_report(self.drivers[driver])
geth_names.append( geth_names.append(
'%s_geth%s.log' % (test_suite_data.current_test.name, str(self.drivers[driver].number))) '%s_geth%s.log' % (test_suite_data.current_test.name, str(self.drivers[driver].number)))
geth_contents.append(self.pull_geth(self.drivers[driver])) geth_contents.append(pull_geth(self.drivers[driver]))
self.drivers[driver].quit() self.drivers[driver].quit()
except (WebDriverException, AttributeError): except (WebDriverException, AttributeError):
pass pass
@ -372,7 +366,7 @@ class SauceSharedMultipleDeviceTestCase(AbstractTestCase):
self.add_alert_text_to_report(self.drivers[driver]) self.add_alert_text_to_report(self.drivers[driver])
geth_names.append( geth_names.append(
'%s_geth%s.log' % (test_suite_data.current_test.name, str(self.drivers[driver].number))) '%s_geth%s.log' % (test_suite_data.current_test.name, str(self.drivers[driver].number)))
geth_contents.append(self.pull_geth(self.drivers[driver])) geth_contents.append(pull_geth(self.drivers[driver]))
except (WebDriverException, AttributeError, RemoteDisconnected, ProtocolError): except (WebDriverException, AttributeError, RemoteDisconnected, ProtocolError):
pass pass
@ -396,8 +390,16 @@ class SauceSharedMultipleDeviceTestCase(AbstractTestCase):
from tests.conftest import sauce from tests.conftest import sauce
requests_session = requests.Session() requests_session = requests.Session()
requests_session.auth = (sauce_username, sauce_access_key) requests_session.auth = (sauce_username, sauce_access_key)
if test_suite_data.tests[0].testruns[-1].error and 'setup failed' in test_suite_data.tests[0].testruns[
-1].error:
group_setup_failed = True
else:
group_setup_failed = False
geth_contents = list()
try: try:
for _, driver in cls.drivers.items(): for _, driver in cls.drivers.items():
if group_setup_failed:
geth_contents.append(pull_geth(driver=driver))
session_id = driver.session_id session_id = driver.session_id
try: try:
sauce.jobs.update_job(username=sauce_username, job_id=session_id, name=cls.__name__) sauce.jobs.update_job(username=sauce_username, job_id=session_id, name=cls.__name__)
@ -428,7 +430,14 @@ class SauceSharedMultipleDeviceTestCase(AbstractTestCase):
cls.loop.close() cls.loop.close()
except AttributeError: except AttributeError:
pass pass
geth_names = ['%s_geth%s.log' % (cls.__name__, i) for i in range(len(geth_contents))]
geth = dict(zip(geth_names, geth_contents))
geth_paths = github_report.save_geth(geth)
for test in test_suite_data.tests: for test in test_suite_data.tests:
if group_setup_failed:
test.geth_paths = geth_paths
github_report.save_test(test) github_report.save_test(test)

View File

@ -672,8 +672,8 @@ class BaseView(object):
return items_in_logcat return items_in_logcat
def find_values_in_geth(self, *args): def find_values_in_geth(self, *args):
from tests.base_test_case import AbstractTestCase from tests.base_test_case import pull_geth
b64_log = self.driver.pull_file(AbstractTestCase().geth_path) b64_log = pull_geth(self.driver)
file = base64.b64decode(b64_log) file = base64.b64decode(b64_log)
result = False result = False
for value in args: for value in args:

View File

@ -4,7 +4,7 @@ import os
from selenium.common.exceptions import NoSuchElementException from selenium.common.exceptions import NoSuchElementException
from tests import common_password, appium_root_project_path from tests import common_password, appium_root_project_path
from tests.base_test_case import AbstractTestCase from tests.base_test_case import get_app_path
from views.base_element import Button, EditBox, Text from views.base_element import Button, EditBox, Text
from views.base_view import BaseView from views.base_view import BaseView
@ -324,7 +324,7 @@ class SignInView(BaseView):
self.get_multiaccount_by_position(1).click() self.get_multiaccount_by_position(1).click()
self.password_input.set_value(password) self.password_input.set_value(password)
self.driver.push_file(source_path=full_path_to_file, self.driver.push_file(source_path=full_path_to_file,
destination_path='%s%s' % (AbstractTestCase().app_path, import_file_name)) destination_path='%s%s' % (get_app_path(), import_file_name))
self.options_button.click() self.options_button.click()
self.element_by_text('Import unencrypted').click() self.element_by_text('Import unencrypted').click()
self.element_by_text('Import unencrypted').wait_for_invisibility_of_element(40) self.element_by_text('Import unencrypted').wait_for_invisibility_of_element(40)
@ -345,7 +345,7 @@ class SignInView(BaseView):
self.options_button.click() self.options_button.click()
self.element_by_text('Export unencrypted').wait_and_click(40) self.element_by_text('Export unencrypted').wait_and_click(40)
self.element_by_text('Export unencrypted').wait_for_invisibility_of_element(40) self.element_by_text('Export unencrypted').wait_for_invisibility_of_element(40)
file_base_64 = self.driver.pull_file('%s/export.db' % AbstractTestCase().app_path) file_base_64 = self.driver.pull_file('%s/export.db' % get_app_path())
try: try:
with open(full_path_to_file, "wb") as f: with open(full_path_to_file, "wb") as f:
f.write(base64.b64decode(file_base_64)) f.write(base64.b64decode(file_base_64))