-
Notifications
You must be signed in to change notification settings - Fork 190
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
Test: consented_providers_settings
#3577
Changes from 5 commits
ec35946
d9d83bc
e0848e8
a39aef2
09654b1
8ea4c09
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
package org.prebid.server.functional.model.request.auction | ||
|
||
import com.fasterxml.jackson.databind.PropertyNamingStrategies | ||
import com.fasterxml.jackson.databind.annotation.JsonNaming | ||
import groovy.transform.ToString | ||
|
||
@ToString(includeNames = true, ignoreNulls = true) | ||
@JsonNaming(PropertyNamingStrategies.SnakeCaseStrategy) | ||
class ConsentedProvidersSettings { | ||
|
||
String consentedProviders | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,9 +4,12 @@ import org.prebid.server.functional.model.db.StoredRequest | |
import org.prebid.server.functional.model.db.StoredResponse | ||
import org.prebid.server.functional.model.request.amp.AmpRequest | ||
import org.prebid.server.functional.model.request.auction.BidRequest | ||
import org.prebid.server.functional.model.request.auction.ConsentedProvidersSettings | ||
import org.prebid.server.functional.model.request.auction.DistributionChannel | ||
import org.prebid.server.functional.model.request.auction.Site | ||
import org.prebid.server.functional.model.request.auction.StoredAuctionResponse | ||
import org.prebid.server.functional.model.request.auction.User | ||
import org.prebid.server.functional.model.request.auction.UserExt | ||
import org.prebid.server.functional.model.response.auction.SeatBid | ||
import org.prebid.server.functional.service.PrebidServerException | ||
import org.prebid.server.functional.util.PBSUtils | ||
|
@@ -56,7 +59,7 @@ class AmpSpec extends BaseSpec { | |
assert exception.responseBody == "Invalid request format: request.${channel.value.toLowerCase()} must not exist in AMP stored requests." | ||
|
||
where: | ||
channel << [DistributionChannel.APP, DistributionChannel.DOOH] | ||
channel << [DistributionChannel.APP, DistributionChannel.DOOH] | ||
} | ||
|
||
def "PBS should return info from the stored response when it's defined in the stored request"() { | ||
|
@@ -180,4 +183,79 @@ class AmpSpec extends BaseSpec { | |
assert bidderRequest.imp[0]?.banner?.format[0]?.weight == ampStoredRequest.imp[0].banner.format[0].weight | ||
assert bidderRequest.regs?.gdpr == ampStoredRequest.regs.gdpr | ||
} | ||
|
||
def "PBS should pass addtl_consent to user.ext.{consented_providers_settings/ConsentedProvidersSettings}.consented_providers"() { | ||
given: "Default amp request with addtlConsent" | ||
def randomAddtlConsent = PBSUtils.randomString | ||
def ampRequest = AmpRequest.defaultAmpRequest.tap { | ||
addtlConsent = randomAddtlConsent | ||
} | ||
|
||
and: "Save storedRequest into DB" | ||
def ampStoredRequest = BidRequest.defaultBidRequest.tap { | ||
user = new User(ext: new UserExt( | ||
consentedProvidersSettingsKebabCase: new ConsentedProvidersSettings(consentedProviders: PBSUtils.randomString), | ||
consentedProvidersSettings: new ConsentedProvidersSettings(consentedProviders: PBSUtils.randomString))) | ||
} | ||
def storedRequest = StoredRequest.getStoredRequest(ampRequest, ampStoredRequest) | ||
storedRequestDao.save(storedRequest) | ||
|
||
when: "PBS processes amp request" | ||
defaultPbsService.sendAmpRequest(ampRequest) | ||
|
||
then: "Bidder request should contain addtl consent" | ||
def bidderRequest = bidder.getBidderRequest(ampStoredRequest.id) | ||
assert bidderRequest.user.ext.consentedProvidersSettingsKebabCase.consentedProviders == randomAddtlConsent | ||
assert bidderRequest.user.ext.consentedProvidersSettings.consentedProviders == randomAddtlConsent | ||
} | ||
|
||
def "PBS should leave requested user.ext.{consented_providers_settings/ConsentedProvidersSettings}.consented_providers as is"() { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. PBS should process original user.ext.{consented_providers_settings/ConsentedProvidersSettings}.consented_providers when ampRequest doesn't contain addtl_consent |
||
given: "Default amp request with addtlConsent" | ||
def ampRequest = AmpRequest.defaultAmpRequest.tap { | ||
addtlConsent = null | ||
} | ||
|
||
and: "Save storedRequest into DB" | ||
def consentProvidersKebabCase = PBSUtils.randomString | ||
def consentProviders = PBSUtils.randomString | ||
def ampStoredRequest = BidRequest.defaultBidRequest.tap { | ||
user = new User(ext: new UserExt( | ||
consentedProvidersSettingsKebabCase: new ConsentedProvidersSettings(consentedProviders: consentProvidersKebabCase), | ||
consentedProvidersSettings: new ConsentedProvidersSettings(consentedProviders: consentProviders))) | ||
} | ||
def storedRequest = StoredRequest.getStoredRequest(ampRequest, ampStoredRequest) | ||
storedRequestDao.save(storedRequest) | ||
|
||
when: "PBS processes amp request" | ||
defaultPbsService.sendAmpRequest(ampRequest) | ||
|
||
then: "Bidder request should contain requested consent" | ||
def bidderRequest = bidder.getBidderRequest(ampStoredRequest.id) | ||
assert bidderRequest.user.ext.consentedProvidersSettingsKebabCase.consentedProviders == consentProvidersKebabCase | ||
assert bidderRequest.user.ext.consentedProvidersSettings.consentedProviders == consentProviders | ||
} | ||
|
||
def "PBS shouldn't pass addtl_consent to user.ext.{consented_providers_settings/ConsentedProvidersSettings}.consented_providers"() { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. PBS should left user.ext.{consented_providers_settings/ConsentedProvidersSettings}.consented_providers empty when addtl_consent and original fields are empty |
||
given: "Default amp request with addtlConsent" | ||
def ampRequest = AmpRequest.defaultAmpRequest.tap { | ||
addtlConsent = null | ||
} | ||
|
||
and: "Save storedRequest into DB" | ||
def ampStoredRequest = BidRequest.defaultBidRequest.tap { | ||
user = new User(ext: new UserExt( | ||
consentedProvidersSettingsKebabCase: new ConsentedProvidersSettings(consentedProviders: null), | ||
consentedProvidersSettings: new ConsentedProvidersSettings(consentedProviders: null))) | ||
} | ||
def storedRequest = StoredRequest.getStoredRequest(ampRequest, ampStoredRequest) | ||
storedRequestDao.save(storedRequest) | ||
|
||
when: "PBS processes amp request" | ||
defaultPbsService.sendAmpRequest(ampRequest) | ||
|
||
then: "Bidder request shouldn't contain consent" | ||
def bidderRequest = bidder.getBidderRequest(ampStoredRequest.id) | ||
assert !bidderRequest.user.ext.consentedProvidersSettingsKebabCase.consentedProviders | ||
assert !bidderRequest.user.ext.consentedProvidersSettings.consentedProviders | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.