From e5ec68dc6b9818ea95408babf4c61cda3621d83d Mon Sep 17 00:00:00 2001 From: osulzhenko Date: Fri, 20 Mar 2026 13:58:29 +0200 Subject: [PATCH] DXKulture: Remove Adapter --- .../bidder/dxkulture/DxKultureBidder.java | 169 ----------- .../request/dxkulture/ExtImpDxKulture.java | 14 - .../bidder/DxKultureBidderConfiguration.java | 41 --- .../resources/bidder-config/dxkulture.yaml | 19 -- .../static/bidder-params/dxkulture.json | 20 -- .../bidder/dxkulture/DxKultureBidderTest.java | 281 ------------------ .../org/prebid/server/it/DxKultureTest.java | 38 --- .../test-auction-dxkulture-request.json | 24 -- .../test-auction-dxkulture-response.json | 38 --- .../dxkulture/test-dxkulture-bid-request.json | 57 ---- .../test-dxkulture-bid-response.json | 16 - .../server/it/test-application.properties | 2 - 12 files changed, 719 deletions(-) delete mode 100644 src/main/java/org/prebid/server/bidder/dxkulture/DxKultureBidder.java delete mode 100644 src/main/java/org/prebid/server/proto/openrtb/ext/request/dxkulture/ExtImpDxKulture.java delete mode 100644 src/main/java/org/prebid/server/spring/config/bidder/DxKultureBidderConfiguration.java delete mode 100644 src/main/resources/bidder-config/dxkulture.yaml delete mode 100644 src/main/resources/static/bidder-params/dxkulture.json delete mode 100644 src/test/java/org/prebid/server/bidder/dxkulture/DxKultureBidderTest.java delete mode 100644 src/test/java/org/prebid/server/it/DxKultureTest.java delete mode 100644 src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-request.json delete mode 100644 src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-response.json delete mode 100644 src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-request.json delete mode 100644 src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-response.json diff --git a/src/main/java/org/prebid/server/bidder/dxkulture/DxKultureBidder.java b/src/main/java/org/prebid/server/bidder/dxkulture/DxKultureBidder.java deleted file mode 100644 index ad3c146795d..00000000000 --- a/src/main/java/org/prebid/server/bidder/dxkulture/DxKultureBidder.java +++ /dev/null @@ -1,169 +0,0 @@ -package org.prebid.server.bidder.dxkulture; - -import com.fasterxml.jackson.core.type.TypeReference; -import com.iab.openrtb.request.BidRequest; -import com.iab.openrtb.request.Device; -import com.iab.openrtb.request.Imp; -import com.iab.openrtb.request.Site; -import com.iab.openrtb.response.Bid; -import com.iab.openrtb.response.BidResponse; -import com.iab.openrtb.response.SeatBid; -import io.vertx.core.MultiMap; -import org.apache.commons.collections4.CollectionUtils; -import org.apache.http.client.utils.URIBuilder; -import org.prebid.server.bidder.Bidder; -import org.prebid.server.bidder.model.BidderBid; -import org.prebid.server.bidder.model.BidderCall; -import org.prebid.server.bidder.model.BidderError; -import org.prebid.server.bidder.model.HttpRequest; -import org.prebid.server.bidder.model.Result; -import org.prebid.server.exception.PreBidException; -import org.prebid.server.json.DecodeException; -import org.prebid.server.json.JacksonMapper; -import org.prebid.server.proto.openrtb.ext.ExtPrebid; -import org.prebid.server.proto.openrtb.ext.request.dxkulture.ExtImpDxKulture; -import org.prebid.server.proto.openrtb.ext.response.BidType; -import org.prebid.server.util.BidderUtil; -import org.prebid.server.util.HttpUtil; -import org.prebid.server.util.ObjectUtil; - -import java.net.URISyntaxException; -import java.util.ArrayList; -import java.util.Collection; -import java.util.Collections; -import java.util.List; -import java.util.Objects; - -public class DxKultureBidder implements Bidder { - - private static final TypeReference> DXKULTURE_EXT_TYPE_REFERENCE = - new TypeReference<>() { - }; - private static final String X_OPENRTB_VERSION = "2.5"; - - private final String endpointUrl; - private final JacksonMapper mapper; - - public DxKultureBidder(String endpointUrl, JacksonMapper mapper) { - this.endpointUrl = HttpUtil.validateUrl(Objects.requireNonNull(endpointUrl)); - this.mapper = Objects.requireNonNull(mapper); - } - - @Override - public Result>> makeHttpRequests(BidRequest request) { - final List errors = new ArrayList<>(); - final List> result = new ArrayList<>(); - - for (Imp imp : request.getImp()) { - final String uri; - try { - uri = getUri(parseImpExt(imp)); - } catch (PreBidException e) { - errors.add(BidderError.badInput(e.getMessage())); - continue; - } - - result.add(BidderUtil.defaultRequest(request, resolveHeaders(request), uri, mapper)); - } - - return Result.of(result, errors); - } - - private ExtImpDxKulture parseImpExt(Imp imp) { - try { - return mapper.mapper().convertValue(imp.getExt(), DXKULTURE_EXT_TYPE_REFERENCE).getBidder(); - } catch (IllegalArgumentException e) { - throw new PreBidException(e.getMessage(), e); - } - } - - private String getUri(ExtImpDxKulture extImpDxKulture) { - final URIBuilder uriBuilder; - try { - uriBuilder = new URIBuilder(endpointUrl); - } catch (URISyntaxException e) { - throw new PreBidException("Invalid url: %s, error: %s".formatted(endpointUrl, e.getMessage())); - } - - uriBuilder - .addParameter("publisher_id", extImpDxKulture.getPublisherId()) - .addParameter("placement_id", extImpDxKulture.getPlacementId()); - - return uriBuilder.toString(); - } - - private static MultiMap resolveHeaders(BidRequest bidRequest) { - final Device device = bidRequest.getDevice(); - final Site site = bidRequest.getSite(); - final MultiMap headers = HttpUtil.headers(); - - headers.set(HttpUtil.X_OPENRTB_VERSION_HEADER, X_OPENRTB_VERSION); - - HttpUtil.addHeaderIfValueIsNotEmpty(headers, HttpUtil.USER_AGENT_HEADER, - ObjectUtil.getIfNotNull(device, Device::getUa)); - HttpUtil.addHeaderIfValueIsNotEmpty(headers, HttpUtil.X_FORWARDED_FOR_HEADER, - ObjectUtil.getIfNotNull(device, Device::getIpv6)); - HttpUtil.addHeaderIfValueIsNotEmpty(headers, HttpUtil.X_FORWARDED_FOR_HEADER, - ObjectUtil.getIfNotNull(device, Device::getIp)); - - HttpUtil.addHeaderIfValueIsNotEmpty(headers, HttpUtil.REFERER_HEADER, - ObjectUtil.getIfNotNull(site, Site::getRef)); - HttpUtil.addHeaderIfValueIsNotEmpty(headers, HttpUtil.ORIGIN_HEADER, - ObjectUtil.getIfNotNull(site, Site::getDomain)); - - return headers; - } - - @Override - public Result> makeBids(BidderCall httpCall, BidRequest bidRequest) { - final BidResponse bidResponse; - try { - bidResponse = mapper.decodeValue(httpCall.getResponse().getBody(), BidResponse.class); - } catch (DecodeException e) { - return Result.withError(BidderError.badServerResponse(e.getMessage())); - } - - final List errors = new ArrayList<>(); - final List bids = extractBids(bidResponse, errors); - - return Result.of(bids, errors); - } - - private static List extractBids(BidResponse bidResponse, List errors) { - if (bidResponse == null || CollectionUtils.isEmpty(bidResponse.getSeatbid())) { - return Collections.emptyList(); - } - - return bidResponse.getSeatbid().stream() - .filter(Objects::nonNull) - .map(SeatBid::getBid) - .filter(Objects::nonNull) - .flatMap(Collection::stream) - .filter(Objects::nonNull) - .map(bid -> makeBidderBid(bid, bidResponse.getCur(), errors)) - .filter(Objects::nonNull) - .toList(); - } - - private static BidderBid makeBidderBid(Bid bid, String currency, List errors) { - try { - return BidderBid.of(bid, resolveBidType(bid), currency); - } catch (PreBidException e) { - errors.add(BidderError.badServerResponse(e.getMessage())); - return null; - } - } - - private static BidType resolveBidType(Bid bid) throws PreBidException { - final Integer markupType = bid.getMtype(); - if (markupType == null) { - throw new PreBidException("Missing MType for bid: " + bid.getId()); - } - return switch (markupType) { - case 1 -> BidType.banner; - case 2 -> BidType.video; - default -> - throw new PreBidException("Unsupported MType: %s, for bid: %s".formatted(markupType, bid.getId())); - }; - } -} diff --git a/src/main/java/org/prebid/server/proto/openrtb/ext/request/dxkulture/ExtImpDxKulture.java b/src/main/java/org/prebid/server/proto/openrtb/ext/request/dxkulture/ExtImpDxKulture.java deleted file mode 100644 index 98a20befa9a..00000000000 --- a/src/main/java/org/prebid/server/proto/openrtb/ext/request/dxkulture/ExtImpDxKulture.java +++ /dev/null @@ -1,14 +0,0 @@ -package org.prebid.server.proto.openrtb.ext.request.dxkulture; - -import com.fasterxml.jackson.annotation.JsonProperty; -import lombok.Value; - -@Value(staticConstructor = "of") -public class ExtImpDxKulture { - - @JsonProperty("publisherId") - String publisherId; - - @JsonProperty("placementId") - String placementId; -} diff --git a/src/main/java/org/prebid/server/spring/config/bidder/DxKultureBidderConfiguration.java b/src/main/java/org/prebid/server/spring/config/bidder/DxKultureBidderConfiguration.java deleted file mode 100644 index 658a2c8743c..00000000000 --- a/src/main/java/org/prebid/server/spring/config/bidder/DxKultureBidderConfiguration.java +++ /dev/null @@ -1,41 +0,0 @@ -package org.prebid.server.spring.config.bidder; - -import org.prebid.server.bidder.BidderDeps; -import org.prebid.server.bidder.dxkulture.DxKultureBidder; -import org.prebid.server.json.JacksonMapper; -import org.prebid.server.spring.config.bidder.model.BidderConfigurationProperties; -import org.prebid.server.spring.config.bidder.util.BidderDepsAssembler; -import org.prebid.server.spring.config.bidder.util.UsersyncerCreator; -import org.prebid.server.spring.env.YamlPropertySourceFactory; -import org.springframework.beans.factory.annotation.Value; -import org.springframework.boot.context.properties.ConfigurationProperties; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.context.annotation.PropertySource; - -import jakarta.validation.constraints.NotBlank; - -@Configuration -@PropertySource(value = "classpath:/bidder-config/dxkulture.yaml", factory = YamlPropertySourceFactory.class) -public class DxKultureBidderConfiguration { - - private static final String BIDDER_NAME = "dxkulture"; - - @Bean("dxkultureConfigurationProperties") - @ConfigurationProperties("adapters.dxkulture") - BidderConfigurationProperties configurationProperties() { - return new BidderConfigurationProperties(); - } - - @Bean - BidderDeps dxkultureBidderDeps(BidderConfigurationProperties dxkultureConfigurationProperties, - @NotBlank @Value("${external-url}") String externalUrl, - JacksonMapper mapper) { - - return BidderDepsAssembler.forBidder(BIDDER_NAME) - .withConfig(dxkultureConfigurationProperties) - .usersyncerCreator(UsersyncerCreator.create(externalUrl)) - .bidderCreator(config -> new DxKultureBidder(config.getEndpoint(), mapper)) - .assemble(); - } -} diff --git a/src/main/resources/bidder-config/dxkulture.yaml b/src/main/resources/bidder-config/dxkulture.yaml deleted file mode 100644 index 739b2ba00af..00000000000 --- a/src/main/resources/bidder-config/dxkulture.yaml +++ /dev/null @@ -1,19 +0,0 @@ -adapters: - dxkulture: - endpoint: https://ads.dxkulture.com/pbs - meta-info: - maintainer-email: devops@dxkulture.com - app-media-types: - - banner - - video - site-media-types: - - banner - - video - supported-vendors: - vendor-id: 0 - usersync: - cookie-family-name: dxkulture - redirect: - url: https://ads.dxkulture.com/usync?gdpr={{gdpr}}&gdpr_consent={{gdpr_consent}}&us_privacy={{us_privacy}}&cb={{redirect_url}} - support-cors: false - uid-macro: '$UID' diff --git a/src/main/resources/static/bidder-params/dxkulture.json b/src/main/resources/static/bidder-params/dxkulture.json deleted file mode 100644 index 858eefd22e4..00000000000 --- a/src/main/resources/static/bidder-params/dxkulture.json +++ /dev/null @@ -1,20 +0,0 @@ -{ - "$schema": "http://json-schema.org/draft-04/schema#", - "title": "DXKulture Adapter Params", - "description": "A schema which validates params accepted by the DXKulture adapter", - "type": "object", - "properties": { - "publisherId": { - "type": "string", - "description": "The publisher id" - }, - "placementId": { - "type": "string", - "description": "The placement id" - } - }, - "required": [ - "publisherId", - "placementId" - ] -} diff --git a/src/test/java/org/prebid/server/bidder/dxkulture/DxKultureBidderTest.java b/src/test/java/org/prebid/server/bidder/dxkulture/DxKultureBidderTest.java deleted file mode 100644 index 15e4f869c36..00000000000 --- a/src/test/java/org/prebid/server/bidder/dxkulture/DxKultureBidderTest.java +++ /dev/null @@ -1,281 +0,0 @@ -package org.prebid.server.bidder.dxkulture; - -import com.fasterxml.jackson.core.JsonProcessingException; -import com.iab.openrtb.request.Banner; -import com.iab.openrtb.request.BidRequest; -import com.iab.openrtb.request.Device; -import com.iab.openrtb.request.Imp; -import com.iab.openrtb.request.Site; -import com.iab.openrtb.request.Video; -import com.iab.openrtb.response.Bid; -import com.iab.openrtb.response.BidResponse; -import com.iab.openrtb.response.SeatBid; -import io.netty.handler.codec.http.HttpHeaderValues; -import io.vertx.core.MultiMap; -import org.junit.jupiter.api.Test; -import org.prebid.server.VertxTest; -import org.prebid.server.bidder.model.BidderBid; -import org.prebid.server.bidder.model.BidderCall; -import org.prebid.server.bidder.model.BidderError; -import org.prebid.server.bidder.model.HttpRequest; -import org.prebid.server.bidder.model.HttpResponse; -import org.prebid.server.bidder.model.Result; -import org.prebid.server.proto.openrtb.ext.ExtPrebid; -import org.prebid.server.proto.openrtb.ext.request.dxkulture.ExtImpDxKulture; -import org.prebid.server.util.HttpUtil; - -import java.util.List; -import java.util.Map; -import java.util.function.Function; - -import static java.util.Collections.singletonList; -import static java.util.function.Function.identity; -import static org.assertj.core.api.Assertions.assertThat; -import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException; -import static org.assertj.core.api.Assertions.tuple; -import static org.prebid.server.proto.openrtb.ext.response.BidType.banner; -import static org.prebid.server.proto.openrtb.ext.response.BidType.video; - -public class DxKultureBidderTest extends VertxTest { - - public static final String ENDPOINT_URL = "https://test.endpoint.com"; - - private final DxKultureBidder target = new DxKultureBidder(ENDPOINT_URL, jacksonMapper); - - @Test - public void creationShouldFailOnInvalidEndpointUrl() { - assertThatIllegalArgumentException().isThrownBy(() -> new DxKultureBidder("invalid_url", jacksonMapper)); - } - - @Test - public void makeHttpRequestsShouldReturnErrorIfImpExtCouldNotBeParsed() { - // given - final BidRequest bidRequest = BidRequest.builder() - .imp(singletonList(Imp.builder() - .ext(mapper.valueToTree(ExtPrebid.of(null, mapper.createArrayNode()))) - .build())) - .build(); - - // when - final Result>> result = target.makeHttpRequests(bidRequest); - - // then - assertThat(result.getErrors()).hasSize(1); - assertThat(result.getErrors().getFirst().getMessage()).startsWith("Cannot deserialize value"); - assertThat(result.getValue()).isEmpty(); - } - - @Test - public void makeHttpRequestsShouldReturnExpectedBidRequest() { - // given - final BidRequest bidRequest = givenBidRequest(identity()); - - // when - final Result>> result = target.makeHttpRequests(bidRequest); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).hasSize(1) - .extracting(httpRequest -> mapper.readValue(httpRequest.getBody(), BidRequest.class)) - .containsOnly(bidRequest); - } - - @Test - public void makeHttpRequestsShouldCreateCorrectUrl() { - // given - final BidRequest bidRequest = BidRequest.builder() - .imp(singletonList(Imp.builder() - .id("123") - .banner(Banner.builder().build()) - .video(Video.builder().build()) - .ext(mapper.valueToTree(ExtPrebid.of(null, - ExtImpDxKulture.of("testPublisherId", "testPlacementId")))) - .build())) - .build(); - - // when - final Result>> result = target.makeHttpRequests(bidRequest); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).hasSize(1); - assertThat(result.getValue()) - .extracting(HttpRequest::getUri) - .containsExactly("https://test.endpoint.com?publisher_id=testPublisherId&placement_id=testPlacementId"); - } - - @Test - public void makeHttpRequestsShouldCorrectlyAddHeaders() { - // given - final BidRequest bidRequest = givenBidRequest(identity(), - bidRequestBuilder -> bidRequestBuilder - .device(Device.builder() - .ua("testUa") - .ip("testIp") - .ipv6("testIpV6").build()) - .site(Site.builder() - .ref("testRef") - .domain("testDomain").build()) - ); - - // when - final Result>> result = target.makeHttpRequests(bidRequest); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()) - .extracting(HttpRequest::getHeaders) - .flatExtracting(MultiMap::entries) - .extracting(Map.Entry::getKey, Map.Entry::getValue) - .containsExactlyInAnyOrder( - tuple(HttpUtil.CONTENT_TYPE_HEADER.toString(), HttpUtil.APPLICATION_JSON_CONTENT_TYPE), - tuple(HttpUtil.ACCEPT_HEADER.toString(), HttpHeaderValues.APPLICATION_JSON.toString()), - tuple(HttpUtil.REFERER_HEADER.toString(), "testRef"), - tuple(HttpUtil.ORIGIN_HEADER.toString(), "testDomain"), - tuple(HttpUtil.USER_AGENT_HEADER.toString(), "testUa"), - tuple(HttpUtil.X_FORWARDED_FOR_HEADER.toString(), "testIp"), - tuple(HttpUtil.X_FORWARDED_FOR_HEADER.toString(), "testIpV6"), - tuple(HttpUtil.X_OPENRTB_VERSION_HEADER.toString(), "2.5")); - } - - @Test - public void makeBidsShouldReturnErrorIfResponseBodyCouldNotBeParsed() { - // given - final BidderCall httpCall = givenHttpCall(null, "invalid"); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getErrors()).hasSize(1); - assertThat(result.getErrors().getFirst().getMessage()).startsWith("Failed to decode: Unrecognized token"); - assertThat(result.getErrors().getFirst().getType()).isEqualTo(BidderError.Type.bad_server_response); - assertThat(result.getValue()).isEmpty(); - } - - @Test - public void makeBidsShouldReturnEmptyListIfBidResponseIsNull() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall(null, mapper.writeValueAsString(null)); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).isEmpty(); - } - - @Test - public void makeBidsShouldReturnEmptyListIfBidResponseSeatBidIsNull() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall(null, - mapper.writeValueAsString(BidResponse.builder().build())); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).isEmpty(); - } - - @Test - public void makeBidsShouldReturnBannerBidIfMTypeIsOne() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall( - BidRequest.builder().imp(singletonList(Imp.builder().id("123").build())).build(), - mapper.writeValueAsString(givenBidResponse(Bid.builder().mtype(1).build()))); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).containsOnly(BidderBid.of(Bid.builder().mtype(1).build(), banner, "USD")); - } - - @Test - public void makeBidsShouldReturnVideoBidIfMTypeIsTwo() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall( - BidRequest.builder().imp(singletonList(Imp.builder().id("123").build())).build(), - mapper.writeValueAsString(givenBidResponse(Bid.builder().mtype(2).build()))); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getErrors()).isEmpty(); - assertThat(result.getValue()).containsOnly(BidderBid.of(Bid.builder().mtype(2).build(), video, "USD")); - } - - @Test - public void makeBidsShouldReturnErrorsForBidsThatDoesNotContainMType() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall( - BidRequest.builder().imp(singletonList(givenImp(identity()))).build(), - mapper.writeValueAsString(givenBidResponse(Bid.builder().id("123").build(), - Bid.builder().mtype(1).build()))); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getValue()).containsExactly(BidderBid.of(Bid.builder().mtype(1).build(), banner, "USD")); - assertThat(result.getErrors()).hasSize(1) - .extracting(BidderError::getMessage) - .containsExactly("Missing MType for bid: 123"); - } - - @Test - public void makeBidsShouldReturnErrorsForBidsThatDoesNotContainSupportedMType() throws JsonProcessingException { - // given - final BidderCall httpCall = givenHttpCall( - BidRequest.builder().imp(singletonList(givenImp(identity()))).build(), - mapper.writeValueAsString(givenBidResponse(Bid.builder().mtype(1).build(), - Bid.builder().id("123").mtype(3).build()))); - - // when - final Result> result = target.makeBids(httpCall, null); - - // then - assertThat(result.getValue()).containsExactly(BidderBid.of(Bid.builder().mtype(1).build(), banner, "USD")); - assertThat(result.getErrors()).hasSize(1) - .extracting(BidderError::getMessage) - .containsExactly("Unsupported MType: 3, for bid: 123"); - } - - private static BidRequest givenBidRequest( - Function impCustomizer, - Function requestCustomizer) { - - return requestCustomizer.apply(BidRequest.builder().imp(singletonList(givenImp(impCustomizer)))).build(); - } - - private static BidRequest givenBidRequest(Function impCustomizer) { - return givenBidRequest(impCustomizer, identity()); - } - - private static Imp givenImp(Function impCustomizer) { - return impCustomizer.apply(Imp.builder().id("123")) - .banner(Banner.builder().build()) - .video(Video.builder().build()) - .ext(mapper.valueToTree(ExtPrebid.of(null, ExtImpDxKulture.of("testPublisherId", "testPlacementId")))) - .build(); - } - - private static BidResponse givenBidResponse(Bid... bids) { - return BidResponse.builder() - .cur("USD") - .seatbid(singletonList(SeatBid.builder() - .bid(List.of(bids)) - .build())) - .build(); - } - - private static BidderCall givenHttpCall(BidRequest bidRequest, String body) { - return BidderCall.succeededHttp(HttpRequest.builder().payload(bidRequest).build(), - HttpResponse.of(200, null, body), null); - } -} diff --git a/src/test/java/org/prebid/server/it/DxKultureTest.java b/src/test/java/org/prebid/server/it/DxKultureTest.java deleted file mode 100644 index 11bfd21abf8..00000000000 --- a/src/test/java/org/prebid/server/it/DxKultureTest.java +++ /dev/null @@ -1,38 +0,0 @@ -package org.prebid.server.it; - -import io.restassured.response.Response; -import org.json.JSONException; -import org.junit.jupiter.api.Test; -import org.prebid.server.model.Endpoint; - -import java.io.IOException; - -import static com.github.tomakehurst.wiremock.client.WireMock.aResponse; -import static com.github.tomakehurst.wiremock.client.WireMock.equalTo; -import static com.github.tomakehurst.wiremock.client.WireMock.equalToJson; -import static com.github.tomakehurst.wiremock.client.WireMock.post; -import static com.github.tomakehurst.wiremock.client.WireMock.urlPathEqualTo; -import static java.util.Collections.singletonList; - -public class DxKultureTest extends IntegrationTest { - - @Test - public void openrtb2AuctionShouldRespondWithBidsFromTheDxKultureBidder() throws IOException, JSONException { - // given - WIRE_MOCK_RULE.stubFor(post(urlPathEqualTo("/dxkulture-exchange")) - .withQueryParam("publisher_id", equalTo("testPublisherId")) - .withQueryParam("placement_id", equalTo("testPlacementId")) - .withRequestBody(equalToJson( - jsonFrom("openrtb2/dxkulture/test-dxkulture-bid-request.json"))) - .willReturn(aResponse().withBody( - jsonFrom("openrtb2/dxkulture/test-dxkulture-bid-response.json")))); - - // when - final Response response = responseFor("openrtb2/dxkulture/test-auction-dxkulture-request.json", - Endpoint.openrtb2_auction); - - // then - assertJsonEquals("openrtb2/dxkulture/test-auction-dxkulture-response.json", response, - singletonList("dxkulture")); - } -} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-request.json b/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-request.json deleted file mode 100644 index 265d275d931..00000000000 --- a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-request.json +++ /dev/null @@ -1,24 +0,0 @@ -{ - "id": "request_id", - "imp": [ - { - "id": "imp_id", - "banner": { - "w": 300, - "h": 250 - }, - "ext": { - "dxkulture": { - "publisherId": "testPublisherId", - "placementId": "testPlacementId" - } - } - } - ], - "tmax": 5000, - "regs": { - "ext": { - "gdpr": 0 - } - } -} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-response.json b/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-response.json deleted file mode 100644 index 5756bce1878..00000000000 --- a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-auction-dxkulture-response.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "id": "request_id", - "seatbid": [ - { - "bid": [ - { - "id": "bid_id", - "mtype": 1, - "impid": "imp_id", - "exp": 300, - "price": 3.33, - "crid": "creativeId", - "ext": { - "origbidcpm": 3.33, - "prebid": { - "type": "banner", - "meta": { - "adaptercode": "dxkulture" - } - } - } - } - ], - "seat": "dxkulture", - "group": 0 - } - ], - "cur": "USD", - "ext": { - "responsetimemillis": { - "dxkulture": "{{ dxkulture.response_time_ms }}" - }, - "prebid": { - "auctiontimestamp": 0 - }, - "tmaxrequest": 5000 - } -} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-request.json b/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-request.json deleted file mode 100644 index f850efbda61..00000000000 --- a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-request.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "id": "request_id", - "imp": [ - { - "id": "imp_id", - "secure": 1, - "banner": { - "w": 300, - "h": 250 - }, - "ext": { - "tid": "${json-unit.any-string}", - "bidder": { - "publisherId": "testPublisherId", - "placementId": "testPlacementId" - } - } - } - ], - "source": { - "tid": "${json-unit.any-string}" - }, - "site": { - "domain": "www.example.com", - "page": "http://www.example.com", - "publisher": { - "domain": "example.com" - }, - "ext": { - "amp": 0 - } - }, - "device": { - "ua": "userAgent", - "ip": "193.168.244.1" - }, - "at": 1, - "tmax": "${json-unit.any-number}", - "cur": [ - "USD" - ], - "regs": { - "ext": { - "gdpr": 0 - } - }, - "ext": { - "prebid": { - "server": { - "externalurl": "http://localhost:8080", - "gvlid": 1, - "datacenter": "local", - "endpoint": "/openrtb2/auction" - } - } - } -} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-response.json b/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-response.json deleted file mode 100644 index 6922c116b46..00000000000 --- a/src/test/resources/org/prebid/server/it/openrtb2/dxkulture/test-dxkulture-bid-response.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "id": "request_id", - "seatbid": [ - { - "bid": [ - { - "id": "bid_id", - "impid": "imp_id", - "price": 3.33, - "crid": "creativeId", - "mtype": 1 - } - ] - } - ] -} diff --git a/src/test/resources/org/prebid/server/it/test-application.properties b/src/test/resources/org/prebid/server/it/test-application.properties index ffa0e527254..f79d7ee50f4 100644 --- a/src/test/resources/org/prebid/server/it/test-application.properties +++ b/src/test/resources/org/prebid/server/it/test-application.properties @@ -228,8 +228,6 @@ adapters.dmx.enabled=true adapters.dmx.endpoint=http://localhost:8090/dmx-exchange adapters.driftpixel.enabled=true adapters.driftpixel.endpoint=http://localhost:8090/driftpixel-exchange?env={{Host}}&pid={{SourceId}} -adapters.dxkulture.enabled=true -adapters.dxkulture.endpoint=http://localhost:8090/dxkulture-exchange adapters.edge226.enabled=true adapters.edge226.endpoint=http://localhost:8090/edge226-exchange adapters.emtv.enabled=true