From ab2fa42497a02b8ada6116a0e67c861be477e291 Mon Sep 17 00:00:00 2001 From: pkaczmarek Date: Tue, 27 Jan 2026 17:35:10 +0100 Subject: [PATCH 1/3] AdsInteractive: Change to aliases --- src/main/resources/bidder-config/generic.yaml | 18 ------ .../resources/bidder-config/teqblaze.yaml | 17 ++++++ .../static/bidder-params/adsinteractive.json | 15 ----- .../prebid/server/it/AdsinteractiveTest.java | 33 +++++++++++ .../test-adsinteractive-bid-request.json | 56 +++++++++++++++++++ .../test-adsinteractive-bid-response.json | 21 +++++++ .../test-auction-adsinteractive-request.json | 23 ++++++++ .../test-auction-adsinteractive-response.json | 38 +++++++++++++ .../server/it/test-application.properties | 4 +- 9 files changed, 190 insertions(+), 35 deletions(-) delete mode 100644 src/main/resources/static/bidder-params/adsinteractive.json create mode 100644 src/test/java/org/prebid/server/it/AdsinteractiveTest.java create mode 100644 src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-request.json create mode 100644 src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-response.json create mode 100644 src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-request.json create mode 100644 src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-response.json diff --git a/src/main/resources/bidder-config/generic.yaml b/src/main/resources/bidder-config/generic.yaml index d4538733e05..9cd5fd280f7 100644 --- a/src/main/resources/bidder-config/generic.yaml +++ b/src/main/resources/bidder-config/generic.yaml @@ -97,24 +97,6 @@ adapters: url: https://prebid.cwi.re/v1/usersync?gdpr={{gdpr}}&gdpr_consent={{gdpr_consent}}&rd={{redirect_url}} support-cors: false uid-macro: '$UID' - adsinteractive: - enabled: false - endpoint: http://bid.adsinteractive.com/prebid - modifying-vast-xml-allowed: false - meta-info: - maintainer-email: it@adsinteractive.com - app-media-types: - - banner - site-media-types: - - banner - supported-vendors: - vendor-id: 1212 - usersync: - cookie-family-name: adsinteractive - redirect: - url: https://sync.adsinteractive.com/getuid?{{redirect_url}}&gpp={{gpp}}&gpp_sid={{gpp_sid}} - support-cors: false - uid-macro: '$AUID' nativo: enabled: false endpoint: https://exchange.postrelease.com/esi?ntv_epid=7 diff --git a/src/main/resources/bidder-config/teqblaze.yaml b/src/main/resources/bidder-config/teqblaze.yaml index 5e1006433ae..20bdae9b3e7 100644 --- a/src/main/resources/bidder-config/teqblaze.yaml +++ b/src/main/resources/bidder-config/teqblaze.yaml @@ -43,6 +43,23 @@ adapters: mata-info: maintainer-email: support@gravite.net vendor-id: 377 + adsinteractive: + enabled: false + endpoint: https://bntb.adsinteractive.com/pserver + meta-info: + maintainer-email: it@adsinteractive.com + vendor-id: 1212 + usersync: + enabled: true + cookie-family-name: ads_interactive + redirect: + url: https://cstb.adsinteractive.com/pbserver?gdpr={{gdpr}}&gdpr_consent={{gdpr_consent}}&ccpa={{us_privacy}}&gpp={{gpp}}&gpp_sid={{gpp_sid}}&redir={{redirect_url}} + support-cors: false + uid-macro: '[UID]' + iframe: + url: https://cstb.adsinteractive.com/pbserverIframe?gdpr={{gdpr}}&gdpr_consent={{gdpr_consent}}&ccpa={{us_privacy}}&gpp={{gpp}}&gpp_sid={{gpp_sid}}&redir={{redirect_url}} + support-cors: false + uid-macro: '[UID]' meta-info: maintainer-email: github@teqblaze.com app-media-types: diff --git a/src/main/resources/static/bidder-params/adsinteractive.json b/src/main/resources/static/bidder-params/adsinteractive.json deleted file mode 100644 index 7296d802e6a..00000000000 --- a/src/main/resources/static/bidder-params/adsinteractive.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "$schema": "http://json-schema.org/draft-04/schema#", - "title": "Adsinteractive Adapter Params", - "description": "Adsinteractive Bidder Parameter Schema", - "type": "object", - "properties": { - "adUnit": { - "type": "string", - "description": "ad unit name" - } - }, - "required": [ - "adUnit" - ] -} diff --git a/src/test/java/org/prebid/server/it/AdsinteractiveTest.java b/src/test/java/org/prebid/server/it/AdsinteractiveTest.java new file mode 100644 index 00000000000..39c9c90b6c5 --- /dev/null +++ b/src/test/java/org/prebid/server/it/AdsinteractiveTest.java @@ -0,0 +1,33 @@ +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.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 AdsinteractiveTest extends IntegrationTest { + + @Test + public void openrtb2AuctionShouldRespondWithBidsFromAdsinteractive() throws IOException, JSONException { + // given + WIRE_MOCK_RULE.stubFor(post(urlPathEqualTo("/adsinteractive-exchange")) + .withRequestBody(equalToJson(jsonFrom("openrtb2/adsinteractive/test-adsinteractive-bid-request.json"))) + .willReturn(aResponse().withBody(jsonFrom("openrtb2/adsinteractive/test-adsinteractive-bid-response.json")))); + + // when + final Response response = responseFor("openrtb2/adsinteractive/test-auction-adsinteractive-request.json", + Endpoint.openrtb2_auction); + + // then + assertJsonEquals( + "openrtb2/adsinteractive/test-auction-adsinteractive-response.json", response, singletonList("adsinteractive")); + } +} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-request.json b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-request.json new file mode 100644 index 00000000000..dcf904ba566 --- /dev/null +++ b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-request.json @@ -0,0 +1,56 @@ +{ + "id": "request_id", + "imp": [ + { + "id": "imp_id", + "banner": { + "w": 300, + "h": 250 + }, + "secure": 1, + "ext": { + "bidder": { + "type": "publisher", + "placementId": "testPlacementId" + } + } + } + ], + "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" + ], + "source": { + "tid": "${json-unit.any-string}" + }, + "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/adsinteractive/test-adsinteractive-bid-response.json b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-response.json new file mode 100644 index 00000000000..180173549d8 --- /dev/null +++ b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-adsinteractive-bid-response.json @@ -0,0 +1,21 @@ +{ + "id": "request_id", + "seatbid": [ + { + "bid": [ + { + "id": "bid_id", + "impid": "imp_id", + "price": 3.33, + "crid": "creativeId", + "mtype": 1, + "ext": { + "prebid": { + "type": "banner" + } + } + } + ] + } + ] +} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-request.json b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-request.json new file mode 100644 index 00000000000..18426f8e84f --- /dev/null +++ b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-request.json @@ -0,0 +1,23 @@ +{ + "id": "request_id", + "imp": [ + { + "id": "imp_id", + "banner": { + "w": 300, + "h": 250 + }, + "ext": { + "adsinteractive": { + "placementId": "testPlacementId" + } + } + } + ], + "tmax": 5000, + "regs": { + "ext": { + "gdpr": 0 + } + } +} diff --git a/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-response.json b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-response.json new file mode 100644 index 00000000000..b3b542f59e0 --- /dev/null +++ b/src/test/resources/org/prebid/server/it/openrtb2/adsinteractive/test-auction-adsinteractive-response.json @@ -0,0 +1,38 @@ +{ + "id": "request_id", + "seatbid": [ + { + "bid": [ + { + "id": "bid_id", + "impid": "imp_id", + "exp": 300, + "price": 3.33, + "crid": "creativeId", + "mtype": 1, + "ext": { + "origbidcpm": 3.33, + "prebid": { + "type": "banner", + "meta": { + "adaptercode": "adsinteractive" + } + } + } + } + ], + "seat": "adsinteractive", + "group": 0 + } + ], + "cur": "USD", + "ext": { + "responsetimemillis": { + "adsinteractive": "{{ adsinteractive.response_time_ms }}" + }, + "prebid": { + "auctiontimestamp": 0 + }, + "tmaxrequest": 5000 + } +} 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 2a3ffe37083..4be1694dd13 100644 --- a/src/test/resources/org/prebid/server/it/test-application.properties +++ b/src/test/resources/org/prebid/server/it/test-application.properties @@ -583,8 +583,8 @@ adapters.teqblaze.aliases.rocketlab.enabled=true adapters.teqblaze.aliases.rocketlab.endpoint=http://localhost:8090/rocketlab-exchange adapters.teqblaze.aliases.appStockSSP.enabled=true adapters.teqblaze.aliases.appStockSSP.endpoint=http://localhost:8090/appstockssp-exchange -adapters.teqblaze.aliases.gravite.enabled=true -adapters.teqblaze.aliases.gravite.endpoint=http://localhost:8090/gravite-exchange +adapters.teqblaze.aliases.adsinteractive.enabled=true +adapters.teqblaze.aliases.adsinteractive.endpoint=http://localhost:8090/adsinteractive-exchange adapters.theadx.enabled=true adapters.theadx.endpoint=http://localhost:8090/theadx-exchange adapters.tradplus.enabled=true From ce6fe260a7e25b6d41f6fac543d4e4e37584ca3a Mon Sep 17 00:00:00 2001 From: pkaczmarek Date: Tue, 27 Jan 2026 17:56:36 +0100 Subject: [PATCH 2/3] fix checkstyle --- src/test/java/org/prebid/server/it/AdsinteractiveTest.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/test/java/org/prebid/server/it/AdsinteractiveTest.java b/src/test/java/org/prebid/server/it/AdsinteractiveTest.java index 39c9c90b6c5..4468e57a2a8 100644 --- a/src/test/java/org/prebid/server/it/AdsinteractiveTest.java +++ b/src/test/java/org/prebid/server/it/AdsinteractiveTest.java @@ -20,14 +20,15 @@ public void openrtb2AuctionShouldRespondWithBidsFromAdsinteractive() throws IOEx // given WIRE_MOCK_RULE.stubFor(post(urlPathEqualTo("/adsinteractive-exchange")) .withRequestBody(equalToJson(jsonFrom("openrtb2/adsinteractive/test-adsinteractive-bid-request.json"))) - .willReturn(aResponse().withBody(jsonFrom("openrtb2/adsinteractive/test-adsinteractive-bid-response.json")))); + .willReturn(aResponse().withBody( + jsonFrom("openrtb2/adsinteractive/test-adsinteractive-bid-response.json")))); // when final Response response = responseFor("openrtb2/adsinteractive/test-auction-adsinteractive-request.json", Endpoint.openrtb2_auction); // then - assertJsonEquals( - "openrtb2/adsinteractive/test-auction-adsinteractive-response.json", response, singletonList("adsinteractive")); + assertJsonEquals("openrtb2/adsinteractive/test-auction-adsinteractive-response.json", + response, singletonList("adsinteractive")); } } From 1e0a08196ef8acd64bc738aebd2b2322f75b0e68 Mon Sep 17 00:00:00 2001 From: pkaczmarek Date: Tue, 27 Jan 2026 18:11:43 +0100 Subject: [PATCH 3/3] fix --- .../resources/org/prebid/server/it/test-application.properties | 2 ++ 1 file changed, 2 insertions(+) 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 4be1694dd13..63643e7bc6e 100644 --- a/src/test/resources/org/prebid/server/it/test-application.properties +++ b/src/test/resources/org/prebid/server/it/test-application.properties @@ -583,6 +583,8 @@ adapters.teqblaze.aliases.rocketlab.enabled=true adapters.teqblaze.aliases.rocketlab.endpoint=http://localhost:8090/rocketlab-exchange adapters.teqblaze.aliases.appStockSSP.enabled=true adapters.teqblaze.aliases.appStockSSP.endpoint=http://localhost:8090/appstockssp-exchange +adapters.teqblaze.aliases.gravite.enabled=true +adapters.teqblaze.aliases.gravite.endpoint=http://localhost:8090/gravite-exchange adapters.teqblaze.aliases.adsinteractive.enabled=true adapters.teqblaze.aliases.adsinteractive.endpoint=http://localhost:8090/adsinteractive-exchange adapters.theadx.enabled=true