Skip to content

Commit

Permalink
Adding support for Banner battr object
Browse files Browse the repository at this point in the history
  • Loading branch information
pm-nitin-shirsat committed Jul 1, 2024
1 parent 8761239 commit 6cfb9be
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 0 deletions.
12 changes: 12 additions & 0 deletions modules/pubmaticBidAdapter.js
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,10 @@ const NATIVE_ASSET_IMAGE_TYPE = {
'IMAGE': 3
}

const BANNER_CUSTOM_PARAMS = {
'battr': DATA_TYPES.ARRAY
}

const NET_REVENUE = true;
const dealChannelValues = {
1: 'PMP',
Expand Down Expand Up @@ -551,6 +555,14 @@ function _createBannerRequest(bid) {
}
bannerObj.pos = 0;
bannerObj.topframe = inIframe() ? 0 : 1;

// Adding Banner custom params
for (let key in BANNER_CUSTOM_PARAMS) {
let bannerCustomParams = bid.mediaTypes.banner;
if (bannerCustomParams.hasOwnProperty(key)) {
bannerObj[key] = _checkParamDataType(key, bannerCustomParams[key], BANNER_CUSTOM_PARAMS[key]);
}
}
} else {
logWarn(LOG_WARN_PREFIX + 'Error: mediaTypes.banner.size missing for adunit: ' + bid.params.adUnit + '. Ignoring the banner impression in the adunit.');
bannerObj = UNDEFINED;
Expand Down
40 changes: 40 additions & 0 deletions test/spec/modules/pubmaticBidAdapter_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -4084,6 +4084,46 @@ describe('PubMatic adapter', function () {
})
});
}

describe('Banner Request param battr checking', function() {
it('should add battr params to bannerObj if present in mediaTypes.banner', function() {
let originalBidRequests = utils.deepClone(bidRequests);
let bannerObj = utils.deepClone(originalBidRequests[0].mediaTypes.banner);
originalBidRequests[0].mediaTypes.banner = Object.assign(bannerObj, {
battr: [1, 2]
});

const req = spec.buildRequests(originalBidRequests, {
auctionId: 'new-auction-id'
});
let data = JSON.parse(req.data);
expect(data.imp[0]['banner']['battr']).to.exist.and.to.be.an('array');
expect(data.imp[0]['banner']['battr'][0]).to.equal(originalBidRequests[0].mediaTypes.banner['battr'][0]);
expect(data.imp[0]['banner']['battr'][1]).to.equal(originalBidRequests[0].mediaTypes.banner['battr'][1]);
});

it('should not add battr params to bannerObj if not present in mediaTypes.banner', function() {
const req = spec.buildRequests(bidRequests, {
auctionId: 'new-auction-id'
});
let data = JSON.parse(req.data);
expect(data.imp[0]['banner']['battr']).to.equal(undefined);
});

it('should not add battr params if _checkParamDataType returns undefined (Mismatch data type)', function() {
let originalBidRequests = utils.deepClone(bidRequests);
let bannerObj = utils.deepClone(originalBidRequests[0].mediaTypes.banner);
originalBidRequests[0].mediaTypes.banner = Object.assign(bannerObj, {
battr: 1
});

const req = spec.buildRequests(originalBidRequests, {
auctionId: 'new-auction-id'
});
let data = JSON.parse(req.data);
expect(data.imp[0]['banner']['battr']).to.equal(undefined);
});
});
});

if (FEATURES.VIDEO) {
Expand Down

0 comments on commit 6cfb9be

Please sign in to comment.