Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Retry only on specific exception #356

Closed
arturmkr opened this issue Dec 4, 2024 · 1 comment
Closed

Retry only on specific exception #356

arturmkr opened this issue Dec 4, 2024 · 1 comment

Comments

@arturmkr
Copy link

arturmkr commented Dec 4, 2024

Is it possible to configure a retry mechanism in tests to run only on specific exceptions?

For example, in the following code, I want the test to retry only if the UnexpectedStatusCodeException is thrown. If any other assertions (like assertEquals) fail, the test should not retry.

code:

public class MyDemoTest {
    @Test
    void sendDataTest() throws UnexpectedStatusCodeException {
        RestAssured.baseURI = "https://petstore.swagger.io/";

        Response response = given()
                .when()
                .get("v2/pet/" + 1);

        checkStatusCode(response, 200);

        String name = response.jsonPath().getString("name");
        assertEquals("dog", name);
    }
    
    static void checkStatusCode(Response response, int expectedStatusCode) throws UnexpectedStatusCodeException {
        int statusCode = response.getStatusCode();
        if (statusCode != expectedStatusCode) {
            throw new UnexpectedStatusCodeException("Unexpected status code: " + statusCode);
        }
    }

    static class UnexpectedStatusCodeException extends Exception {
        public UnexpectedStatusCodeException(String message) {
            super(message);
        }
    }
}
@pshevche
Copy link
Member

@arturmkr , it is not possible at the moment. We have an issue on our roadmap to make it work. I'll close this issue in favor of that one to avoid duplication in our backlog: #198

@pshevche pshevche reopened this Dec 31, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants