Skip to content
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

New Adapter: ResetDigital #3766

Open
wants to merge 90 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 19 commits
Commits
Show all changes
90 commits
Select commit Hold shift + click to select a range
70de190
New Adapter: ResetDigital
bruno-siira Feb 5, 2024
dd48470
Fix to have the a bid forced on testing
bruno-siira Feb 7, 2024
32551fc
Merge branch 'prebid:master' into master
bruno-siira Feb 7, 2024
125124b
Merge branch 'prebid:master' into master
bruno-siira Feb 9, 2024
5c56e12
Test changes
bruno-siira Feb 9, 2024
fe4ff39
Merge branch 'prebid:master' into master
bruno-siira Feb 13, 2024
664614f
Merge branch 'master' of https://github.com/bruno-siira/prebid-server
bruno-siira Feb 13, 2024
0b44384
Merge branch 'prebid:master' into master
bruno-siira Feb 21, 2024
0775c72
Merge branch 'master' of https://github.com/bruno-siira/prebid-server
bruno-siira Feb 26, 2024
20fa856
Add file
bruno-siira Feb 28, 2024
33f4603
Added schema for adapter
bruno-siira Feb 28, 2024
e468217
Merge branch 'prebid:master' into master
bruno-siira Mar 17, 2024
b8ca566
Unused builder removed
bruno-siira Mar 18, 2024
2de7781
Fix to lack of builder
bruno-siira Mar 24, 2024
eb067f7
Change of data on export
bruno-siira Mar 26, 2024
86206d7
no need to include `required` if its empty
bruno-siira Apr 14, 2024
3fc5455
Resolving https://github.com/prebid/prebid-server/pull/3452
BrunoJacinto May 14, 2024
3762676
Merge branch 'prebid:master' into master
bruno-siira Jun 20, 2024
989c565
New Adapter: ResetDigital #3766
bruno-siira Jul 3, 2024
39905ed
Fix naming
bruno-siira Jul 5, 2024
4482bc9
Fix naming of Var
bruno-siira Jul 5, 2024
d426e8a
Fix PR New Adapter: ResetDigital #3766
bruno-siira Jul 9, 2024
ac2fc01
Fix New Adapter: ResetDigital #3766
bruno-siira Jul 9, 2024
52a6794
Fix multiple comments
bruno-siira Jul 16, 2024
9626103
New tests
bruno-siira Jul 18, 2024
dea6cf7
Fix http.StatusBadRequest and non http.StatusOK codes should not be e…
bruno-siira Jul 24, 2024
5cfe0ae
Not running tests at this momment
bruno-siira Aug 16, 2024
ece8152
Update with help of Xandr Team
bruno-siira Aug 29, 2024
baa553c
Simplify Tests
bruno-siira Aug 29, 2024
ecc90bb
PR of functioning version
bruno-siira Sep 10, 2024
0d54a8d
Added Video and removed unwanted data
bruno-siira Sep 29, 2024
660dba7
created mock test
ogbonnaEmmanuel Oct 25, 2024
5f70f11
delete fake_test.json
ogbonnaEmmanuel Oct 31, 2024
613317a
Merge pull request #1 from ogbonnaEmmanuel/master
dirk-rd Oct 31, 2024
a083c03
Adding support for audio media type and a corresponding simple-audio.…
dirk-rd Nov 3, 2024
bc7caaf
Fix slice append syntax.
dirk-rd Nov 4, 2024
4569e97
Removed zero check for bid response and moved HTTP headers into separ…
dirk-rd Nov 4, 2024
0bc2aeb
Adding test case for missing currency to improve test coverage percen…
dirk-rd Nov 4, 2024
d212d91
Merge pull request #2 from bruno-siira/add-audio
bruno-siira Nov 4, 2024
cff2442
New Adapter: ResetDigital
bruno-siira Feb 5, 2024
44bee69
Fix to have the a bid forced on testing
bruno-siira Feb 7, 2024
96fde76
Test changes
bruno-siira Feb 9, 2024
6e08b5d
Add file
bruno-siira Feb 28, 2024
ec4005d
Added schema for adapter
bruno-siira Feb 28, 2024
fd3ec0d
Unused builder removed
bruno-siira Mar 18, 2024
8bca6ad
Fix to lack of builder
bruno-siira Mar 24, 2024
278be3f
Change of data on export
bruno-siira Mar 26, 2024
56a77a0
no need to include `required` if its empty
bruno-siira Apr 14, 2024
f0e2574
Resolving https://github.com/prebid/prebid-server/pull/3452
BrunoJacinto May 14, 2024
0e365ce
New Adapter: ResetDigital #3766
bruno-siira Jul 3, 2024
f2d3afc
Fix naming
bruno-siira Jul 5, 2024
d6e24d0
Fix naming of Var
bruno-siira Jul 5, 2024
eceef87
Fix PR New Adapter: ResetDigital #3766
bruno-siira Jul 9, 2024
e86d017
Fix New Adapter: ResetDigital #3766
bruno-siira Jul 9, 2024
baa974f
Fix multiple comments
bruno-siira Jul 16, 2024
73c3fe0
New tests
bruno-siira Jul 18, 2024
246010f
Fix http.StatusBadRequest and non http.StatusOK codes should not be e…
bruno-siira Jul 24, 2024
cff5817
Not running tests at this momment
bruno-siira Aug 16, 2024
5ab5517
Update with help of Xandr Team
bruno-siira Aug 29, 2024
d3df8f2
Simplify Tests
bruno-siira Aug 29, 2024
c1795b8
PR of functioning version
bruno-siira Sep 10, 2024
1665bc9
Added Video and removed unwanted data
bruno-siira Sep 29, 2024
0f6f5b1
created mock test
ogbonnaEmmanuel Oct 25, 2024
27863db
delete fake_test.json
ogbonnaEmmanuel Oct 31, 2024
f0da5d7
Adding support for audio media type and a corresponding simple-audio.…
dirk-rd Nov 3, 2024
6c745fb
Fix slice append syntax.
dirk-rd Nov 4, 2024
56b03f1
Removed zero check for bid response and moved HTTP headers into separ…
dirk-rd Nov 4, 2024
21eecdd
Adding test case for missing currency to improve test coverage percen…
dirk-rd Nov 4, 2024
dcd9dad
COmmit
bruno-siira Nov 4, 2024
2584c6b
Changing the version to V3
bruno-siira Nov 4, 2024
123cb13
Renaming test JSON files
dirk-rd Nov 21, 2024
4950da1
Deleting errant -vv file
dirk-rd Nov 21, 2024
cc06d05
Simplying HTML test markup.
dirk-rd Nov 21, 2024
330d84f
Reverting unnecessary changes.
dirk-rd Nov 25, 2024
17cf6c8
Adding test cases via JSON to increase coverage.
dirk-rd Dec 1, 2024
5b44280
Removing keys with null values.
dirk-rd Dec 1, 2024
ee3546c
Removing unnecessary keys and fixing redirect URL.
dirk-rd Dec 1, 2024
2ecc9a8
Ignore test coverage output.
dirk-rd Dec 1, 2024
0a4d9bc
Remove unnecessary test case.
dirk-rd Dec 1, 2024
b93dca3
Formattting; removed comments; simplified GetMediaTypeForImp.
dirk-rd Dec 1, 2024
ef65f7b
Merge branch 'prebid:master' into master
dirk-rd Dec 2, 2024
6bac6cd
Merge pull request #3 from bruno-siira/pr-review-comments-11-13-24
dirk-rd Dec 4, 2024
62f74c1
Move line to restore alpha order.
dirk-rd Dec 22, 2024
4a0ec3f
Removing error return value that is no longer used.
dirk-rd Dec 22, 2024
11c824f
Removing .gitignore file.
dirk-rd Dec 22, 2024
905485d
Adding required file paras_test.go to test for (in)valid parameters.
dirk-rd Dec 22, 2024
0623316
Merge pull request #4 from bruno-siira/pr-review-comments-12-16-24
dirk-rd Dec 22, 2024
e82c838
Refactoring MakeBids() for single bid request and updating JSON tests…
dirk-rd Jan 10, 2025
a96efc8
Uncomment bid count validation.
dirk-rd Jan 10, 2025
8ed4059
Merge pull request #5 from bruno-siira/pr-review-comments-12-16-24
dirk-rd Jan 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
291 changes: 291 additions & 0 deletions adapters/resetdigital/resetdigital.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,291 @@
package resetdigital

import (
"encoding/json"
"fmt"
"net/http"
"strconv"
"text/template"

"github.com/prebid/openrtb/v20/openrtb2"
"github.com/prebid/prebid-server/v2/adapters"
"github.com/prebid/prebid-server/v2/config"
"github.com/prebid/prebid-server/v2/openrtb_ext"
)

// MaximumBids is the maximum number of bids that can be returned by this adapter.
const (
MaxBids = 1
)

type adapter struct {
endpoint *template.Template
endpointUri string
}

type resetDigitalRequest struct {
Site resetDigitalRequestSite `json:"site"`
Imps []resetDigitalRequesImps `json:"imps"`
}

type resetDigitalRequestSite struct {
Domain string `json:"domain"`
Referrer string `json:"referrer"`
}

type resetDigitalRequesImps struct {
ForceBid bool `json:"force_bid"`
ZoneID struct {
PlacementID string `json:"placementId"`
} `json:"zone_id"`
BidID string `json:"bid_id"`
ImpID string `json:"imp_id"`
Ext struct {
Gpid string `json:"gpid"`
} `json:"ext"`
Sizes [][]int64 `json:"sizes"`
MediaTypes struct {
Banner struct {
Sizes [][]int64 `json:"sizes"`
} `json:"banner"`
Video struct {
Sizes [][]int64 `json:"sizes"`
} `json:"video"`
} `json:"media_types"`
}

func Builder(bidderName openrtb_ext.BidderName, config config.Adapter, server config.Server) (adapters.Bidder, error) {
template, err := template.New("endpointTemplate").Parse(config.Endpoint)
if err != nil {
return nil, fmt.Errorf("unable to parse endpoint url template: %v", err)
}

bidder := &adapter{
endpoint: template,
}

return bidder, nil
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}
func getHeaders(request *openrtb2.BidRequest) http.Header {
headers := http.Header{}

if request.Device != nil && request.Site != nil {
addNonEmptyHeaders(&headers, map[string]string{
"Referer": request.Site.Page,
"Accept-Language": request.Device.Language,
"User-Agent": request.Device.UA,
"X-Forwarded-For": request.Device.IP,
"X-Real-Ip": request.Device.IP,
"Content-Type": "application/json;charset=utf-8",
"Accept": "application/json",
})
}

return headers
}
func addNonEmptyHeaders(headers *http.Header, headerValues map[string]string) {
for key, value := range headerValues {
if len(value) > 0 {
headers.Add(key, value)
}
}
}

func getReferer(request *openrtb2.BidRequest) string {
if request.Site == nil {
return ""
}

return request.Site.Domain
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}

func getCurrency(request *openrtb2.BidRequest) string {
if len(request.Cur) == 0 {
return "USD"
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage


return request.Cur[0]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bruno-siira should update in bidder docs that if multiple currencies are present in request then only first is considered

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@onkarvhanumante where should this bidder docs go? Do you have some example?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bruno-siira refer this prebid/prebid.github.io#5486 PR as example

}

func (a *adapter) MakeRequests(requestData *openrtb2.BidRequest, requestInfo *adapters.ExtraRequestInfo) ([]*adapters.RequestData, []error) {
var (
requests []*adapters.RequestData
errors []error
)

referer := getReferer(requestData)
currency := getCurrency(requestData)

if referer == currency {
return nil, nil
}
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved

for i := range requestData.Imp {
imp := requestData.Imp[i]
bidType, err := getBidType(imp)

if err != nil {
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved
errors = append(errors, err)
continue
Comment on lines +126 to +127
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}

splittedRequestData := processDataFromRequest(requestData, imp, bidType)

requestBody, err := json.Marshal(splittedRequestData)
if err != nil {
errors = append(errors, err)
continue
}

requests = append(requests, &adapters.RequestData{
Method: "POST",
Uri: a.endpointUri,
Body: requestBody,
Headers: getHeaders(requestData),
})
}

return requests, errors
}

func processDataFromRequest(requestData *openrtb2.BidRequest, imp openrtb2.Imp, bidType openrtb_ext.BidType) resetDigitalRequest {

var resetDigitalRequestData resetDigitalRequest
resetDigitalRequestData.Site.Domain = requestData.Site.Domain
resetDigitalRequestData.Site.Referrer = requestData.Site.Page
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved

resetDigitalRequestData.Imps = append(resetDigitalRequestData.Imps, resetDigitalRequesImps{})
resetDigitalRequestData.Imps[0].BidID = requestData.ID
resetDigitalRequestData.Imps[0].ImpID = imp.ID

var err error

if bidType == openrtb_ext.BidTypeBanner {
resetDigitalRequestData.Imps[0].MediaTypes.Banner.Sizes = append(resetDigitalRequestData.Imps[0].MediaTypes.Banner.Sizes, []int64{imp.Banner.Format[0].W, imp.Banner.Format[0].H})
}
if bidType == openrtb_ext.BidTypeVideo {
resetDigitalRequestData.Imps[0].MediaTypes.Video.Sizes = append(resetDigitalRequestData.Imps[0].MediaTypes.Banner.Sizes, []int64{*imp.Video.W, *imp.Video.H})
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}

var extData = make(map[string]interface{})
err = json.Unmarshal(imp.Ext, &extData)
if err != nil {

} else {
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved

resetDigitalRequestData.Imps[0].ZoneID.PlacementID = extData["bidder"].(map[string]interface{})["placement_id"].(string)
if resetDigitalRequestData.Imps[0].ZoneID.PlacementID == "test" {
resetDigitalRequestData.Imps[0].ForceBid = true
}

}
return resetDigitalRequestData

}

func (a *adapter) MakeBids(internalRequest *openrtb2.BidRequest, externalRequest *adapters.RequestData, response *adapters.ResponseData) (*adapters.BidderResponse, []error) {
if response.StatusCode == http.StatusNoContent || response.StatusCode == http.StatusBadRequest || response.StatusCode != http.StatusOK {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

return nil, nil
}
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved

var bidResp map[string]interface{}
if err := json.Unmarshal(response.Body, &bidResp); err != nil {
return nil, []error{err}
}

bidResponse := adapters.NewBidderResponseWithBidsCapacity(MaxBids)
jsonData := bidResp["bids"].([]interface{})

for _, bidData := range jsonData {
bidMap := bidData.(map[string]interface{})
bid := getBidFromResponse(bidMap)
if bid == nil {
continue
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}

bidTypes, err := getBidTypes(internalRequest.Imp[0])
if err != nil {
return nil, []error{err}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

Copy link
Collaborator

@bsardo bsardo Sep 16, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does it make more sense to append the error and continue processing the rest of the bids?
If so, this should be:

if err != nil {
    errs = append(errs, err)
    continue
}

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Discussed offline. Reset Digital to append the error and continue.

}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bruno-siira any particular reason to always consider first imp from internalRequest.Imp?

Additionally, MakeRequests splits the incoming single request into multiple requests. So how are we assuming internalRequest.Imp[0] is the request for corresponding bid from response (line 194)


for _, bidType := range bidTypes {
bidResponse.Bids = append(bidResponse.Bids, &adapters.TypedBid{
Bid: bid,
BidType: bidType,
})
}
}

bidResponse.Currency = getCurrency(internalRequest)
return bidResponse, nil
}
func getBidFromResponse(requestData map[string]interface{}) *openrtb2.Bid {
processData := requestData["bid_id"].(string)

bid := &openrtb2.Bid{
ID: processData,
Price: getBidPrice(requestData),
ImpID: requestData["imp_id"].(string),
CrID: requestData["crid"].(string),
}

if value, ok := requestData["html"].(string); ok {
bid.AdM = value
}

if value, ok := requestData["w"].(string); ok {
if i, err := strconv.ParseInt(value, 10, 64); err == nil && i > 0 {
bid.W = i
}
}

if value, ok := requestData["h"].(string); ok {
if i, err := strconv.ParseInt(value, 10, 64); err == nil && i > 0 {
bid.H = i
}
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Potential cases for run time panic if type casting fails. Refer to https://github.com/prebid/prebid-server/pull/3766/files#r1672009993 comment


if bid.Price == 0 {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

return nil
}

return bid
}

func getBidPrice(requestData map[string]interface{}) float64 {
if value, ok := requestData["cpm"].(float64); ok {
return value
}
return 0.0 // Default value if "cpm" doesn't exist or is not a float64
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.


func getBidType(imp openrtb2.Imp) (openrtb_ext.BidType, error) {
if imp.Banner != nil {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeBanner, nil. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Implemented as suggested

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Implemented as suggested

could you point out or link where MType changes are implemented?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, it was addressed on the point that we support only single format bids, so we could assume the anti pattern. Anyway, it would be more advisable to change to the normal pattern?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Anyway, it would be more advisable to change to the normal pattern?

Prebid team recommends using MType field. But if it's not doable then current change suffices single format bid. @bruno-siira should mention in Bidder docs that adapter expects only single format bids in the incoming request

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When we're talking about the Bidder Docs what is this file exacly @onkarvhanumante

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeBanner, nil. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.

return openrtb_ext.BidTypeBanner, nil
} else if imp.Video != nil {
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved
return openrtb_ext.BidTypeVideo, nil
} else if imp.Audio != nil {
bruno-siira marked this conversation as resolved.
Show resolved Hide resolved

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeAudio, nil. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.

return openrtb_ext.BidTypeAudio, nil
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeVideo, nil. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.


return "", fmt.Errorf("failed to find matching imp for bid %s", imp.ID)
Comment on lines +300 to +305
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage

}

func getBidTypes(imp openrtb2.Imp) ([]openrtb_ext.BidType, error) {
var bidTypes []openrtb_ext.BidType

if imp.Banner != nil {
bidTypes = append(bidTypes, openrtb_ext.BidTypeBanner)
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeVideo. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.

if imp.Video != nil {
bidTypes = append(bidTypes, openrtb_ext.BidTypeVideo)
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Consider this as a suggestion. The current implementation follows an anti-pattern, assumes that if there is a multi-format request, the media type defaults to openrtb_ext.BidTypeAudio. Prebid server expects the media type to be explicitly set in the adapter response. Therefore, we strongly recommend implementing a pattern where the adapter server sets the MType field in the response to accurately determine the media type for the impression.

if imp.Audio != nil {
bidTypes = append(bidTypes, openrtb_ext.BidTypeAudio)
}
if len(bidTypes) == 0 {
return nil, fmt.Errorf("failed to find matching imp for bid %s", imp.ID)
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#3766 (comment) this comment mentions like multi format bids are not supported. But getBidTypes collects all multiple format available for bid.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

code path is not covered. should add json tests to improve coverage


return bidTypes, nil
}
92 changes: 92 additions & 0 deletions adapters/resetdigital/resetdigital_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
package resetdigital

import (
"encoding/json"
"net/http"
"testing"

"github.com/prebid/openrtb/v20/openrtb2"
"github.com/prebid/prebid-server/v2/adapters"
"github.com/stretchr/testify/assert"
)

func TestMakeRequests(t *testing.T) {
bidder := new(adapter)

request := &openrtb2.BidRequest{
ID: "12345",

Imp: []openrtb2.Imp{{
ID: "001",
Banner: &openrtb2.Banner{
Format: []openrtb2.Format{
{W: 300, H: 250},
},
},

Ext: json.RawMessage(`{"bidder": {"placement_id": "test"}}`), //Placement_id test is used to get the force bid true
}},
Site: &openrtb2.Site{
Domain: "https://test.com",
Page: "https://test.com/2016/06/12",
},
Cur: []string{"USD"},
Device: &openrtb2.Device{
UA: "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36",
IP: "127.0.0.1",
Language: "EN",
},
}

reqs, errs := bidder.MakeRequests(request, &adapters.ExtraRequestInfo{})

assert.Empty(t, errs, "Got unexpected errors while building HTTP requests: %v", errs)
assert.Equal(t, 1, len(reqs), "Unexpected number of HTTP requests. Got %d. Expected %d", len(reqs), 1)
}

func TestMakeBids(t *testing.T) {
request := &openrtb2.BidRequest{
ID: "12345",

Imp: []openrtb2.Imp{{
ID: "001",
Banner: &openrtb2.Banner{
Format: []openrtb2.Format{
{W: 300, H: 250},
},
},

Ext: json.RawMessage(`{"bidder": {"placement_id": "test"}}`), //Placement_id test is used to get the force bid true
}},
Site: &openrtb2.Site{
Domain: "https://test.com",
Page: "https://test.com/2016/06/12",
},
Cur: []string{"USD"},
Device: &openrtb2.Device{
UA: "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.121 Safari/537.36",
IP: "127.0.0.1",
Language: "EN",
},
}

requestJson, _ := json.Marshal(request)
reqData := &adapters.RequestData{
Method: "POST",
Uri: "test-uri",
Body: requestJson,
}

httpResp := &adapters.ResponseData{
StatusCode: http.StatusOK,
Body: []byte(`{"bids":[{"bid_id":"01","imp_id":"001","cpm":10.00,"cid":"1002088","crid":"1000763-1002088","adid":"1002088","w":"300","h":"250","seat":"resetdigital","html":"<scriptsrc=\"https://data.resetdigital.co/evts?S0B=1&R0E=1&R0M=3_3&testad=US-HEADER-15&R0A=1000048_1001096_1001117_1627360746&R0P=resetio_1234_muscleandfitness.com_Site_1_Banner&R0L=*_*_*_*_*&R0D=*_*_*_*_*_*&R0B=*_*_*\"type=\"text/javascript\"></script><imagesrc='https://adsreq.resetdigital.co?brid=0000000000000001'/><imagesrc='https://sync2.resetdigital.co/hbsync?ck=0000000000000001'/>"}]}`),
}

bidder := new(adapter)
bidResponse, errs := bidder.MakeBids(request, reqData, httpResp)

assert.Empty(t, errs, "Expected 0 errors. Got %d", len(errs))

assert.Equal(t, float64(10), bidResponse.Bids[0].Bid.Price,
"Expected Price 10. Got: %s", bidResponse.Bids[0].Bid.Price)
}
Loading
Loading