From e7c618e75dccbb3fd5ddceca73a6c7cf0608b5a4 Mon Sep 17 00:00:00 2001 From: Carl Csaposs Date: Tue, 14 May 2024 09:58:15 +0000 Subject: [PATCH] patch(pytest_plugins/microceph): Add retry if microceph not ready (#175) Fixes #171 (on self-hosted runners, microceph is not ready before we create bucket) --- .../microceph/pytest_microceph/_plugin.py | 24 ++++++++++++++----- 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/python/pytest_plugins/microceph/pytest_microceph/_plugin.py b/python/pytest_plugins/microceph/pytest_microceph/_plugin.py index 5a060a59..b789b72b 100644 --- a/python/pytest_plugins/microceph/pytest_microceph/_plugin.py +++ b/python/pytest_plugins/microceph/pytest_microceph/_plugin.py @@ -3,8 +3,10 @@ import logging import os import subprocess +import time import boto3 +import botocore.exceptions import pytest @@ -43,12 +45,22 @@ def microceph(): key_id = key["access_key"] secret_key = key["secret_key"] logger.info("Creating microceph bucket") - boto3.client( - "s3", - endpoint_url="http://localhost", - aws_access_key_id=key_id, - aws_secret_access_key=secret_key, - ).create_bucket(Bucket=_BUCKET) + for attempt in range(3): + try: + boto3.client( + "s3", + endpoint_url="http://localhost", + aws_access_key_id=key_id, + aws_secret_access_key=secret_key, + ).create_bucket(Bucket=_BUCKET) + except botocore.exceptions.EndpointConnectionError: + if attempt == 2: + raise + # microceph is not ready yet + logger.info("Unable to connect to microceph via S3. Retrying") + time.sleep(1) + else: + break logger.info("Set up microceph") return ConnectionInformation(key_id, secret_key, _BUCKET)