當前位置: 首頁>>代碼示例>>Python>>正文


Python retry.retry方法代碼示例

本文整理匯總了Python中retry.retry方法的典型用法代碼示例。如果您正苦於以下問題:Python retry.retry方法的具體用法?Python retry.retry怎麽用?Python retry.retry使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在retry的用法示例。


在下文中一共展示了retry.retry方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: dump_hierarchy

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def dump_hierarchy(self, compressed=False, pretty=False) -> str:
        """
        Args:
            shell (bool): use "adb shell uiautomator dump" to get hierarchy
            pretty (bool): format xml

        Same as
            content = self.jsonrpc.dumpWindowHierarchy(compressed, None)
        But through GET /dump/hierarchy will be more robust
        when dumpHierarchy fails, the atx-agent will restart uiautomator again, then retry

        v-1.3.4 change back to jsonrpc.dumpWindowHierarchy
        """
        content = self.jsonrpc.dumpWindowHierarchy(compressed, None)
        if content == "":
            raise RetryError("dump hierarchy is empty")

        if pretty and "\n " not in content:
            xml_text = xml.dom.minidom.parseString(content.encode("utf-8"))
            content = xml_text.decode('utf-8').toprettyxml(indent='  ')
        return content 
開發者ID:openatx,項目名稱:uiautomator2,代碼行數:23,代碼來源:__init__.py

示例2: test_unsuccessful_thread

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_unsuccessful_thread():
    """Unsuccessful with function as thread, timed out"""
    retryed = []

    def foo(retryed):
        @retry.retry(timeout=1, success=lambda x: False)
        def bar(retryed):
            sleep(0.2)
            retryed.append(0)

        with pytest.raises(retry.MaximumTimeoutExceeded):
            bar(retryed)

    t = Thread(target=foo, args=[retryed])
    t.start()
    t.join()
    assert 3 <= len(retryed) <= 5 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:19,代碼來源:test_retry.py

示例3: handle_error

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def handle_error(tries=20, delay=0.01):

    def decorate(func):

        @wraps(func)
        @retry(tries=tries, delay=delay)
        def wrapper(*args, **kwargs):
            try:
                func(*args, **kwargs)
            except Exception as error:
                print(f'Raise an error: {error}')
                print(f'Start to retry!!!!!')
                raise Exception

        return wrapper

    return decorate 
開發者ID:Chandlercjy,項目名稱:OnePy,代碼行數:19,代碼來源:awesome_func.py

示例4: request

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def request(self, method, url, **kwargs):
        retry = kwargs.pop("retry", True)
        try:
            url = self.__client.path2url(
                url)  # may raise adbutils.AdbError when device offline
            return super().request(method, url, **kwargs)
        except (requests.ConnectionError, requests.ReadTimeout,
                adbutils.AdbError) as e:
            if not retry:
                raise

            # if atx-agent is already running, just raise error
            if isinstance(e, requests.RequestException) and \
                self.__client._is_agent_alive():
                raise

        if not self.__client._serial:
            raise EnvironmentError(
                "http-request to atx-agent error, can only recover from USB")

        logger.warning("atx-agent has something wrong, auto recovering")
        # ReadTimeout: sometime means atx-agent is running but not responsing
        # one reason is futex_wait_queue: https://stackoverflow.com/questions/9801256/app-hangs-on-futex-wait-queue-me-every-a-couple-of-minutes

        # fix atx-agent and request again
        self.__client._prepare_atx_agent()
        url = self.__client.path2url(url)
        return super().request(method, url, **kwargs) 
開發者ID:openatx,項目名稱:uiautomator2,代碼行數:30,代碼來源:__init__.py

示例5: _invalid_session_err_callback

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def _invalid_session_err_callback(self, hc: HTTPClient, err):
        if self.__is_app and self.__session_id:  # ignore when app is crashed
            return False
        if err.status == Status.INVALID_SESSION_ID:
            # update session id and retry
            # print("Invalid session id,: update session url", self._id)
            self.__session_id = None
            hc.address = self.http.address + "/session/" + self.id
            return True
        return False 
開發者ID:openatx,項目名稱:facebook-wda,代碼行數:12,代碼來源:__init__.py

示例6: __init__

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def __init__(self):
        super(TimeoutRequestsSession, self).__init__()
        # refs: https://stackoverflow.com/questions/33895739/python-requests-cant-load-any-url-remote-end-closed-connection-without-respo
        # refs: https://stackoverflow.com/questions/15431044/can-i-set-max-retries-for-requests-request

        # Is retry necessary, maybe not, so I closed it at 2020/05/29
        # retries = Retry(total=3, connect=3, backoff_factor=0.5)
        # adapter = requests.adapters.HTTPAdapter(max_retries=retries)
        # self.mount("http://", adapter)
        # self.mount("https://", adapter) 
開發者ID:openatx,項目名稱:uiautomator2,代碼行數:12,代碼來源:__init__.py

示例7: _is_alive

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def _is_alive(self):
        try:
            r = self.http.post("/jsonrpc/0", timeout=2, retry=False, data=json.dumps({
                "jsonrpc": "2.0",
                "id": 1,
                "method": "deviceInfo",
            }))
            if r.status_code != 200:
                return False
            if r.json().get("error"):
                return False
            return True
        except (requests.ReadTimeout, EnvironmentError):
            return False 
開發者ID:openatx,項目名稱:uiautomator2,代碼行數:16,代碼來源:__init__.py

示例8: get_original_variable

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def get_original_variable(self, samples, radius, variable):
        try:
            # if we have already calculated the grid, return it
            var = self.grids[(samples, radius)]['original'][variable]
            return var
        except KeyError as e:
            # otherwise, raise.  The function will retry which leads to
            # the above (returning) codepath running
            self.make_basic_grids(samples, radius)
            raise e 
開發者ID:brandondube,項目名稱:prysm,代碼行數:12,代碼來源:coordinates.py

示例9: get_transformed_variable

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def get_transformed_variable(self, samples, radius, transformation):
        try:
            # if we have already calculated the grid, return it
            var = self.grids[(samples, radius)]['transformed'][transformation]
            return var
        except KeyError as e:
            # otherwise, raise.  The function will retry which leads to
            # the above (returning) codepath running
            self.make_transformation(samples, radius, transformation)
            raise e 
開發者ID:brandondube,項目名稱:prysm,代碼行數:12,代碼來源:coordinates.py

示例10: test_success_criteria

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_success_criteria():
    """Success criteria successfully raises MaximumRetriesExceeded"""
    foo_with_success = retry.retry(success=lambda x: x > 0)(foo)
    with pytest.raises(retry.MaximumRetriesExceeded):
        foo_with_success(0) 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:7,代碼來源:test_retry.py

示例11: test_exception_criteria

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_exception_criteria():
    """Exceptions specified are raised on MaximumRetriesExceeded"""
    foo_with_exception = retry.retry(exceptions=(ArithmeticError,))(foo)
    with pytest.raises(ArithmeticError) as exc_info:
        foo_with_exception(-1)
    assert exception_message in str(exc_info.value) 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:8,代碼來源:test_retry.py

示例12: test_execution

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_execution():
    """Expected execution of a successful runstill works"""
    foo_with_both = retry.retry(
        exceptions=(ArithmeticError,), success=lambda x: x > 0)(foo)
    assert foo_with_both(1) == 1 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:7,代碼來源:test_retry.py

示例13: test_interval

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_interval():
    """Interval expected is the interval to complete an action"""
    def _success_interval(in_dict):
        in_dict['num'] += 1
        return in_dict['num']

    baz_with_interval = retry.retry(
        success=lambda x: x > 5, interval=1)(_success_interval)
    start = datetime.now()
    baz_with_interval({'num': 0})
    elapsed = datetime.now() - start
    assert elapsed.seconds >= 5 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:14,代碼來源:test_retry.py

示例14: test_invalid_parameters

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_invalid_parameters():
    """The exceptions and success parameter can not both be None"""
    with pytest.raises(TypeError):
        retry.retry(exceptions=None, success=None)(foo) 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:6,代碼來源:test_retry.py

示例15: test_successful_timeout

# 需要導入模塊: import retry [as 別名]
# 或者: from retry import retry [as 別名]
def test_successful_timeout():
    """Success with a timeout still works"""
    def _success_timeout(in_dict):
        in_dict['num'] += 1
        return in_dict['num']

    try:
        _test_func = retry.retry(
            success=lambda x: x == 5, timeout=10, interval=1)(
                _success_timeout)
        _test_func({'num': 0})
    except retry.MaximumTimeoutExceeded:
        pytest.fail('Expected the timeout not to be exceeded') 
開發者ID:seemethere,項目名稱:retry.it,代碼行數:15,代碼來源:test_retry.py


注:本文中的retry.retry方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。