-
Notifications
You must be signed in to change notification settings - Fork 760
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: Intertech #3718
base: master
Are you sure you want to change the base?
New Adapter: Intertech #3718
Conversation
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.
This is an excellent start. I'm excited for the first adapter ported from PBS-Java.
You also need to register the intertech name and adapter in a few other places. Please see this section in the docs or look at this other PR for an example. |
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
@przemkaczmarek, can you resolve conflicts? Thanks! |
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
static/bidder-info/intertech.yaml
Outdated
- native | ||
userSync: | ||
redirect: | ||
url: https://prebid.intertechsrvcs.com/mapuid/intertech/?ssp-id=10500&gdpr={{.GDPR}}&gdpr_consent={{.GDPRConsent}} |
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.
The Java version has &location=
at the end of the URL. We'll need to figure out if that's needed.
We'll also need to verify that this redirect works. It wasn't working for me.
adapters/intertech/intertech.go
Outdated
headers.Add("Content-Type", "application/json;charset=utf-8") | ||
headers.Add("Accept", "application/json") |
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.
Since these don't involve request.Device
, I suggest moving these outside of the conditional so that they are always set.
adapters/intertech/intertech.go
Outdated
if imp.Banner != nil { | ||
return openrtb_ext.BidTypeBanner, nil | ||
} | ||
|
||
return "", &errortypes.BadInput{ | ||
Message: fmt.Sprintf("Processing an invalid impression; cannot resolve impression type for imp #%s", imp.ID), | ||
} |
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.
Given that this adapter only supports banner and native, the bid type is derived from the impression and PBS core will only call the adapter if an impression is one of the supported formats, this error case should not be possible. This function could be simplified as follows:
if imp.Native != nil {
return openrtb_ext.BidTypeNative, nil
}
return openrtb_ext.BidTypeBanner, nil
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
adapters/intertech/intertech.go
Outdated
if banner == nil { | ||
return nil, fmt.Errorf("banner is null") | ||
} |
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.
You can delete this conditional as banner
will always be not nil since this function call is only made if banner is not nil.
adapters/intertech/intertech.go
Outdated
if imp.Native != nil { | ||
return imp, nil | ||
} | ||
return openrtb2.Imp{}, &errortypes.BadInput{ | ||
Message: fmt.Sprintf("Intertech only supports banner and native types. Ignoring imp id=%s", imp.ID), | ||
} |
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.
You can simplify this to just return imp, nil
since you've only declared support for banner and native in the YAML file.
headers.Add("X-Real-Ip", bidRequest.Device.IP) | ||
} | ||
if bidRequest.Device.Language != "" { | ||
headers.Add("Accept-Language", bidRequest.Device.Language) |
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.
Can you add JSON test coverage for this line?
adapters/intertech/intertech.go
Outdated
return &bannerCopy, nil | ||
} | ||
|
||
func (a *adapter) modifyUrl(extImp ExtImpIntertech, referer, cur string) (string, error) { |
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.
You can delete the second return value error
because it is only ever nil.
adapters/intertech/intertech.go
Outdated
return ExtImpIntertech{}, &errortypes.BadInput{ | ||
Message: fmt.Sprintf("imp #%s: unable to parse intertech ext: %s", imp.ID, err), | ||
} |
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.
Please add test coverage for these lines. You can force this error by setting page_id
or imp_id
to an invalid type (e.g. string) which would be something other than an integer.
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.
When deserializing ExtImpIntertech, the JSON data must meet the requirements of the earlier deserialization levels, specifically adapters.ExtImpBidder. If the data fails validation in adapters.ExtImpBidder, tests will never reach the line that deserializes ExtImpIntertech. Therefore, when I think about it, this line is redundant here.
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.
Can you move this test into the supplemental directory?
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.
Can you move this test into the supplemental directory?
"banner": { | ||
"format": [ | ||
{ "w": 300, "h": 250 } | ||
] | ||
}, |
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.
Since you have simple-banner-multi-format.json
which tests when format
is populated, I suggest you make this test cover the case when there is no format but there are top-level dimensions:
"banner": {
"w": 300,
"h": 250
},
"id": "test-missing-dimensions-request-id", | ||
"device": { | ||
"ip": "123.123.123.123", | ||
"ua": "Mozilla/5.0 (X11; Linux x86_64)" | ||
}, | ||
"site": { | ||
"page": "http://bannercheck.com" | ||
}, | ||
"imp": [ | ||
{ | ||
"id": "test-imp-missing-dim", | ||
"tagid": "tag-missing-dim", |
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.
Nitpick: I suggest simplifying the names of the ids here. Just use request-id-1
, imp-id-1
, tag-id-1
. The other names can be confusing. The test file name does a good job of indicating the test purpose.
], | ||
"cur": ["USD"] | ||
}, | ||
"httpCalls": [ |
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.
You can verify the headers, specifically the device related ones, are set correctly given that you have a device object here by including the following:
"httpCalls": [
{
"expectedRequest": {
"headers": {
"Content-Type": [
"application/json;charset=utf-8"
],
"Accept": [
"application/json"
],
etc...
``
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.
You can delete this test. Only banner and native media type requests will result in calling this adapter.
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.
I suggest adding a new JSON test in the supplemental
directory where the incoming request does not have a device
object and then verify that the httpCalls[].expectedRequest.headers
does not contain the device related headers.
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
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.
LGTM. We just need to confirm the user sync works.
adapters/intertech/intertech.go
Outdated
endpoint string | ||
} | ||
|
||
type ExtImpIntertech struct { |
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.
Why are you defining a local ExtImpIntertech
rather than using the one in openrtb_ext
? And why are they different?
The expectation is that openrtb_ext
documents all the bidder specific ext
fields, so there is a collected reference for them all. So it should be an unusual circumstance that requires you to define a separate, local version of it.
openrtb_ext/imp_intertech.go
Outdated
|
||
type ExtImpIntertech struct { | ||
PlacementID string `json:"placement_id"` | ||
// Deprecated: in favor of `PlacementID` |
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.
Are you saying PageID
and ImpID
are deprecated in favor of PlacementID
? The code only ever references the other two and does not consider PlacementID
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.
Ah good catch. placement_id
isn't a valid field. It was supposed to have been removed from this struct.
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
openrtb_ext/imp_intertech.go
Outdated
PageID int64 `json:"page_id"` | ||
ImpID int64 `json:"imp_id"` |
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.
I think you can just make these int
and then remove the type cast in the modifyUrl
itoa
call.
Code coverage summaryNote:
intertechRefer here for heat map coverage report
|
No description provided.