From 353ad4a81b8beaca3236b78feb8352ffdd20eacf Mon Sep 17 00:00:00 2001 From: nstreltsov Date: Sun, 11 Jun 2023 16:30:34 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D0=B0=20=D0=B2=D0=BE=D0=B7=D0=BC=D0=BE=D0=B6=D0=BD=D0=BE?= =?UTF-8?q?=D1=81=D1=82=D1=8C=20=D0=B4=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D1=8F?= =?UTF-8?q?=D1=82=D1=8C=20=D1=84=D0=B8=D0=BB=D1=8C=D1=82=D1=80=D1=8B=20?= =?UTF-8?q?=D0=B4=D0=BB=D1=8F=20=D0=B7=D0=B0=D0=BF=D1=80=D0=BE=D1=81=D0=BE?= =?UTF-8?q?=D0=B2=20=D0=B4=D0=BB=D1=8F=20restassured.=20=D0=A2=D0=B5=D0=BF?= =?UTF-8?q?=D0=B5=D1=80=D1=8C=20=D0=BC=D0=BE=D0=B6=D0=BD=D0=BE=20=D0=BC?= =?UTF-8?q?=D0=BE=D0=B4=D0=B8=D1=84=D0=B8=D1=86=D0=B8=D1=80=D0=BE=D0=B2?= =?UTF-8?q?=D0=B0=D1=82=D1=8C=20=D0=B7=D0=B0=D0=BF=D1=80=D0=BE=D1=81=D1=8B?= =?UTF-8?q?=20=D0=B8=20=D0=BE=D1=82=D0=B2=D0=B5=D1=82=D1=8B=20=D1=87=D0=B5?= =?UTF-8?q?=D1=80=D0=B5=D0=B7=20=D0=BE=D0=B4=D0=B8=D0=BD=20=D0=BE=D0=B1?= =?UTF-8?q?=D1=89=D0=B8=D0=B9=20=D0=BA=D0=BB=D0=B0=D1=81=D1=81,=20=D0=B0?= =?UTF-8?q?=20=D1=82=D0=B0=D0=BA=20=D0=B6=D0=B5=20=D0=B8=D1=81=D0=BF=D0=BE?= =?UTF-8?q?=D0=BB=D1=8C=D0=B7=D0=BE=D0=B2=D0=B0=D1=82=D1=8C=20=D0=B1=D0=B8?= =?UTF-8?q?=D0=B1=D0=BB=D0=B8=D0=BE=D1=82=D0=B5=D0=BA=D1=83=20swagger-cove?= =?UTF-8?q?rage-rest-assured?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/main/asciidoc/rest-plugin.asciidoc | 10 +++++++ .../main/asciidoc/rest_properties.asciidoc | 8 ++++++ .../java/ru/sbtqa/tag/api/EndpointEntry.java | 26 ++++++++++++++++++- .../tag/api/properties/ApiConfiguration.java | 6 +++++ 4 files changed, 49 insertions(+), 1 deletion(-) diff --git a/page-factory-doc/src/main/asciidoc/rest-plugin.asciidoc b/page-factory-doc/src/main/asciidoc/rest-plugin.asciidoc index 0a677a33..57c75da4 100644 --- a/page-factory-doc/src/main/asciidoc/rest-plugin.asciidoc +++ b/page-factory-doc/src/main/asciidoc/rest-plugin.asciidoc @@ -44,5 +44,15 @@ api.ssl.relaxed = true Подробнее об этом можно узнать в документации https://github.com/rest-assured/rest-assured/wiki/Usage#ssl[rest-assured^, role="ext-link"] +=== Филтрация запросов +Фильтр позволяет проверять и изменять запрос до того, как он будет отправлен, а также проверять и изменять ответ до того, как он вернется. Фильтры можно использовать для реализации пользовательских схем аутентификации, управления сеансами, ведения журналов и т. д. Чтобы создать фильтр, вам необходимо реализовать интерфейс `io.restassured.filter.Filter` +Чтобы использовать фильтр, вы можете указать в параметре классы фильтров (если несколько, то необходимо указывать через запятую): + +[source,] +---- +api.request.filters = ru.sbtqa.tag.api.TestFilter +---- + +Подробнее об этом можно узнать в документации https://github.com/rest-assured/rest-assured/wiki/Usage#filters[rest-assured^, role="ext-link"] diff --git a/page-factory-doc/src/main/asciidoc/rest_properties.asciidoc b/page-factory-doc/src/main/asciidoc/rest_properties.asciidoc index e2f6ad3a..7c180943 100644 --- a/page-factory-doc/src/main/asciidoc/rest_properties.asciidoc +++ b/page-factory-doc/src/main/asciidoc/rest_properties.asciidoc @@ -35,4 +35,12 @@ Возможные значения: true или false. | false + +| api.request.filters +| Фильтры для запросов + +Возможные значения: путь до классов, которые реализуют интерфейс `io.restassured.filter.Filter` + +Если используется несколько фильтров, то указываются через запятую +| |==================== \ No newline at end of file diff --git a/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/EndpointEntry.java b/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/EndpointEntry.java index 5e4147cb..91d9f1c0 100644 --- a/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/EndpointEntry.java +++ b/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/EndpointEntry.java @@ -1,26 +1,37 @@ package ru.sbtqa.tag.api; +import io.restassured.filter.Filter; import io.restassured.response.Response; import io.restassured.response.ValidatableResponse; import io.restassured.specification.RequestSpecification; + +import java.lang.reflect.InvocationTargetException; +import java.util.Arrays; import java.util.HashMap; +import java.util.List; import java.util.Map; +import java.util.stream.Collectors; + import ru.sbtqa.tag.api.annotation.FromResponse; import ru.sbtqa.tag.api.annotation.Mutator; import ru.sbtqa.tag.api.annotation.Query; import ru.sbtqa.tag.api.annotation.Stashed; import ru.sbtqa.tag.api.environment.ApiEnvironment; +import ru.sbtqa.tag.api.exception.RestPluginException; import ru.sbtqa.tag.api.properties.ApiConfiguration; import ru.sbtqa.tag.api.repository.ApiPair; import ru.sbtqa.tag.api.storage.BlankStorage; import ru.sbtqa.tag.api.utils.PlaceholderUtils; +import ru.sbtqa.tag.api.utils.ReflectionUtils; import ru.sbtqa.tag.api.utils.TemplateUtils; import ru.sbtqa.tag.pagefactory.ApiEndpoint; import ru.sbtqa.tag.pagefactory.Rest; import ru.sbtqa.tag.pagefactory.annotations.rest.Endpoint; import ru.sbtqa.tag.pagefactory.utils.PathUtils; +import static io.restassured.RestAssured.filters; import static io.restassured.RestAssured.given; +import static java.lang.String.format; import static ru.sbtqa.tag.api.annotation.ParameterType.*; /** @@ -109,7 +120,10 @@ public void send() { } private RequestSpecification buildRequest() { - RequestSpecification request = given().log().all(true); + RequestSpecification request = given() + .filters(getFilters()) + .log() + .all(true); request.queryParams(getQueryParameters()); request.headers(getHeaders()); @@ -124,6 +138,16 @@ private RequestSpecification buildRequest() { return request; } + private List getFilters(){ + return PROPERTIES.getRequestFilters().stream().map(filter -> { + try { + return (Filter)Class.forName(filter).getConstructor().newInstance(); + } catch (InstantiationException | IllegalAccessException | InvocationTargetException | + NoSuchMethodException | ClassNotFoundException e) { + throw new RestPluginException(format("Failed to create filter instance \"%s\"", filter), e); + } + }).collect(Collectors.toList()); + } private Map getQueryParameters() { Map queries = new HashMap<>(); diff --git a/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/properties/ApiConfiguration.java b/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/properties/ApiConfiguration.java index c54093b9..bcf9af7a 100644 --- a/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/properties/ApiConfiguration.java +++ b/plugins/rest-plugin/src/main/java/ru/sbtqa/tag/api/properties/ApiConfiguration.java @@ -3,6 +3,8 @@ import org.aeonbits.owner.Config; import ru.sbtqa.tag.pagefactory.properties.Configuration; +import java.util.List; + public interface ApiConfiguration extends Config { @Key("api.baseURI") @@ -28,6 +30,10 @@ public interface ApiConfiguration extends Config { @DefaultValue("false") boolean shouldRemoveEmptyObjects(); + @Key("api.request.filters") + @DefaultValue("") + List getRequestFilters(); + static ApiConfiguration create() { return Configuration.init(ApiConfiguration.class); }