prebid-universal-creative 1.15.0 → 1.17.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.circleci/config.yml +44 -30
- package/.github/workflows/codeql.yml +98 -0
- package/.github/workflows/issue_tracker.yml +32 -16
- package/README.md +4 -2
- package/dist/amp.js +3 -3
- package/dist/banner.js +3 -3
- package/dist/caf7688498213fb0c19f.max.js +1046 -0
- package/dist/creative.js +3 -3
- package/dist/load-cookie-with-consent.html +1 -1
- package/dist/load-cookie.html +1 -1
- package/dist/mobile.js +3 -3
- package/dist/native-render.js +3 -3
- package/dist/native-trk.js +3 -3
- package/dist/native.js +3 -3
- package/dist/uid.js +2 -2
- package/dist/video.js +3 -3
- package/gulpfile.js +15 -31
- package/integ-test/fixtures/test.js +79 -0
- package/integ-test/pages/amp.html +80 -0
- package/integ-test/pages/banner.html +96 -0
- package/integ-test/pages/native_legacy.html +107 -0
- package/integ-test/spec/amp_spec.js +111 -0
- package/integ-test/spec/banner_spec.js +85 -0
- package/integ-test/spec/native_legacy_spec.js +213 -0
- package/karma.conf.maker.js +4 -6
- package/package.json +10 -16
- package/playwright.config.js +108 -0
- package/src/adHtmlRender.js +11 -0
- package/src/cookieSync.js +3 -0
- package/src/cookieSyncWithConsent.js +3 -0
- package/src/domHelper.js +25 -15
- package/src/dynamicRenderer.js +56 -0
- package/src/messaging.js +23 -2
- package/src/mobileAndAmpRender.js +17 -20
- package/src/nativeAssetManager.js +134 -80
- package/src/nativeORTBTrackerManager.js +3 -3
- package/src/nativeRenderManager.js +44 -72
- package/src/nativeTrackerManager.js +2 -2
- package/src/renderingManager.js +17 -18
- package/src/utils.js +0 -9
- package/test/helpers/mocks.js +1 -0
- package/test/spec/dynamicRenderer_spec.js +167 -0
- package/test/spec/messaging_spec.js +98 -3
- package/test/spec/mobileAndAmpRender_spec.js +53 -63
- package/test/spec/nativeAssetManager_spec.js +290 -93
- package/test/spec/nativeORTBTrackerManager_spec.js +3 -19
- package/test/spec/nativeRenderManager_spec.js +77 -56
- package/test/spec/renderingManager_spec.js +20 -6
- package/webpack.conf.js +0 -1
- package/.nvmrc +0 -1
- package/dist/creative.max.js +0 -3101
- package/src/postscribeRender.js +0 -8
- package/test/e2e/specs/hello_world_banner_non_sf.spec.js +0 -14
- package/test/e2e/specs/outstream_non_sf.spec.js +0 -14
- package/test/e2e/specs/outstream_sf.spec.js +0 -14
- package/wdio.conf.js +0 -50
@@ -37,40 +37,24 @@ describe('test firing native trackers', function () {
|
|
37
37
|
|
38
38
|
|
39
39
|
it('should fire impression trackers', function () {
|
40
|
-
let imgUrl = 'foo.bar/event?type=img';
|
41
|
-
let jsUrl = 'foo.bar/event?type=js';
|
42
|
-
|
43
|
-
|
44
40
|
fireNativeImpressionTrackers("abc123", sendMessage);
|
45
41
|
|
46
42
|
expect(sendMessage.getCall(0).args[0]).to.deep.equal({
|
47
|
-
message: 'Prebid Native',
|
43
|
+
message: 'Prebid Native',
|
48
44
|
action: 'fireNativeImpressionTrackers',
|
49
45
|
adId: 'abc123'
|
50
46
|
})
|
51
47
|
});
|
52
48
|
|
53
49
|
it('should fire asset clicktrackers', function () {
|
54
|
-
let assetTrackers = ['foo.bar/click?id=1', 'foo.bar/click?id=2'];
|
55
|
-
let mainTrackers = ['foo.bar/click?id=3'];
|
56
50
|
let adId = "abc123";
|
57
|
-
|
58
|
-
assets: [{
|
59
|
-
id: 1,
|
60
|
-
link: { clicktrackers: assetTrackers }
|
61
|
-
}],
|
62
|
-
link: {
|
63
|
-
clicktrackers: mainTrackers
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
addNativeClickTrackers(adId, nativeOrtb, sendMessage);
|
51
|
+
addNativeClickTrackers(adId, sendMessage);
|
68
52
|
expect(sendMessage.getCall(0).args[0]).to.deep.equal({
|
69
53
|
message: "Prebid Native",
|
70
54
|
action: 'click',
|
71
55
|
adId: 'abc123',
|
72
56
|
assetId: 1
|
73
57
|
});
|
74
|
-
|
58
|
+
|
75
59
|
});
|
76
60
|
});
|
@@ -1,8 +1,7 @@
|
|
1
|
-
import {
|
2
|
-
import * as nam
|
3
|
-
import {
|
4
|
-
import {
|
5
|
-
import { merge } from 'lodash';
|
1
|
+
import {newNativeRenderManager} from 'src/nativeRenderManager';
|
2
|
+
import * as nam from 'src/nativeAssetManager';
|
3
|
+
import {mocks} from 'test/helpers/mocks';
|
4
|
+
import {merge} from 'lodash';
|
6
5
|
|
7
6
|
const renderingMocks = {
|
8
7
|
getWindowObject: function() {
|
@@ -15,10 +14,6 @@ const renderingMocks = {
|
|
15
14
|
}
|
16
15
|
};
|
17
16
|
|
18
|
-
function trimPort(url) {
|
19
|
-
return ((/:\d+/).test(url)) ? url.substring(0, url.lastIndexOf(':')) : url;
|
20
|
-
}
|
21
|
-
|
22
17
|
describe('nativeRenderManager', function () {
|
23
18
|
describe('load renderNativeAd', function () {
|
24
19
|
let mockWin;
|
@@ -55,57 +50,83 @@ describe('nativeRenderManager', function () {
|
|
55
50
|
assetManagerStub.restore();
|
56
51
|
});
|
57
52
|
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
value: "ad123",
|
64
|
-
},
|
65
|
-
},
|
66
|
-
addEventListener: (type, listener, capture) => {},
|
67
|
-
},
|
68
|
-
];
|
69
|
-
let nativeTracker = new newNativeRenderManager(mockWin);
|
70
|
-
nativeTracker.renderNativeAd(mockWin.document, tagData);
|
71
|
-
|
72
|
-
expect(mockWin.parent.postMessage.callCount).to.equal(1);
|
73
|
-
let postMessageTargetDomain = mockWin.parent.postMessage.args[0][1];
|
74
|
-
let postMessageContents = mockWin.parent.postMessage.args[0][0];
|
75
|
-
let rawPostMessage = JSON.parse(postMessageContents);
|
76
|
-
|
77
|
-
expect(rawPostMessage.message).to.exist.and.to.equal("Prebid Native");
|
78
|
-
expect(rawPostMessage.adId).to.exist.and.to.equal("ad123");
|
79
|
-
expect(rawPostMessage.action).to.not.exist;
|
80
|
-
expect(trimPort(postMessageTargetDomain)).to.equal(tagData.pubUrl);
|
81
|
-
});
|
53
|
+
describe('should fire event', () => {
|
54
|
+
let recvMessages;
|
55
|
+
function mockMessenger() {
|
56
|
+
return recvMessages.push.bind(recvMessages);
|
57
|
+
}
|
82
58
|
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
59
|
+
beforeEach(() => {
|
60
|
+
recvMessages = [];
|
61
|
+
});
|
62
|
+
it('AD_RENDER_SUCCEEDED', () => {
|
63
|
+
const mockAssetMgr = function () {
|
64
|
+
return {
|
65
|
+
loadAssets(_, fn) {
|
66
|
+
fn();
|
67
|
+
}
|
68
|
+
}
|
69
|
+
}
|
70
|
+
const rdr = newNativeRenderManager(mockWin, mockMessenger, mockAssetMgr);
|
71
|
+
rdr.renderNativeAd(mockWin.document, tagData);
|
72
|
+
sinon.assert.match(recvMessages[0], {
|
73
|
+
message: 'Prebid Event',
|
74
|
+
adId: 'ad123',
|
75
|
+
event: 'adRenderSucceeded',
|
76
|
+
})
|
77
|
+
})
|
78
|
+
describe('AD_RENDER_FAILED', () => {
|
79
|
+
it('on exceptions', () => {
|
80
|
+
const rdr = newNativeRenderManager(mockWin, mockMessenger);
|
81
|
+
rdr.renderNativeAd(mockWin.document, Object.defineProperties({...tagData}, {
|
82
|
+
rendererUrl: {
|
83
|
+
get() {
|
84
|
+
throw new Error('err');
|
85
|
+
}
|
86
|
+
}
|
87
|
+
}));
|
88
|
+
sinon.assert.match(recvMessages[0], {
|
89
|
+
message: 'Prebid Event',
|
90
|
+
adId: 'ad123',
|
91
|
+
event: 'adRenderFailed',
|
92
|
+
info: {
|
93
|
+
reason: 'exception',
|
94
|
+
message: 'err'
|
95
|
+
}
|
96
|
+
})
|
97
|
+
});
|
98
|
+
it('on missing adId',() => {
|
99
|
+
const rdr = newNativeRenderManager(mockWin, mockMessenger);
|
100
|
+
rdr.renderNativeAd(mockWin.document, {...tagData, adId: undefined});
|
101
|
+
sinon.assert.match(recvMessages[0], {
|
102
|
+
message: 'Prebid Event',
|
103
|
+
event: 'adRenderFailed',
|
104
|
+
info: {
|
105
|
+
reason: 'missingDocOrAdid',
|
106
|
+
}
|
107
|
+
})
|
108
|
+
});
|
109
|
+
it('on rendering errors', () => {
|
110
|
+
const mockAssetMgr = function () {
|
111
|
+
return {
|
112
|
+
loadAssets(_1, _2, err) {
|
113
|
+
err(new Error('err'))
|
114
|
+
}
|
115
|
+
}
|
88
116
|
}
|
89
|
-
|
90
|
-
|
91
|
-
|
117
|
+
const rdr = newNativeRenderManager(mockWin, mockMessenger, mockAssetMgr);
|
118
|
+
rdr.renderNativeAd(mockWin.document, tagData);
|
119
|
+
sinon.assert.match(recvMessages[0], {
|
120
|
+
message: 'Prebid Event',
|
121
|
+
event: 'adRenderFailed',
|
122
|
+
info: {
|
123
|
+
reason: 'exception',
|
124
|
+
message: 'err'
|
125
|
+
}
|
92
126
|
})
|
93
127
|
})
|
94
|
-
}
|
95
|
-
|
96
|
-
let nativeTracker = new newNativeRenderManager(mockWin);
|
97
|
-
nativeTracker.renderNativeAd(mockWin.document, tagData);
|
98
|
-
|
99
|
-
expect(mockWin.parent.postMessage.callCount).to.equal(2);
|
100
|
-
|
101
|
-
let postMessageTargetDomain = mockWin.parent.postMessage.args[0][1];
|
102
|
-
let postMessageContents = mockWin.parent.postMessage.args[1][0];
|
103
|
-
let rawPostMessage = JSON.parse(postMessageContents);
|
104
|
-
|
105
|
-
expect(rawPostMessage.message).to.exist.and.to.equal("Prebid Native");
|
106
|
-
expect(rawPostMessage.adId).to.exist.and.to.equal("ad123");
|
107
|
-
expect(rawPostMessage.action).to.exist.and.to.equal('click');
|
108
|
-
expect(trimPort(postMessageTargetDomain)).to.equal(tagData.pubUrl);
|
128
|
+
})
|
109
129
|
});
|
110
130
|
});
|
131
|
+
|
111
132
|
});
|
@@ -1,9 +1,11 @@
|
|
1
1
|
import { renderCrossDomain, renderLegacy } from 'src/renderingManager';
|
2
2
|
import * as utils from 'src/utils';
|
3
3
|
import * as domHelper from 'src/domHelper';
|
4
|
+
import * as dynamic from 'src/dynamicRenderer.js';
|
4
5
|
import { expect } from 'chai';
|
5
6
|
import { mocks } from 'test/helpers/mocks';
|
6
7
|
import { merge } from 'lodash';
|
8
|
+
import {MIN_RENDERER_VERSION} from "src/dynamicRenderer.js";
|
7
9
|
|
8
10
|
function renderingMocks() {
|
9
11
|
return {
|
@@ -72,6 +74,7 @@ describe('renderingManager', function() {
|
|
72
74
|
|
73
75
|
describe('cross domain creative', function() {
|
74
76
|
const ORIGIN = 'http://example.com';
|
77
|
+
let sandbox;
|
75
78
|
let parseStub;
|
76
79
|
let iframeStub;
|
77
80
|
let triggerPixelSpy;
|
@@ -81,10 +84,11 @@ describe('renderingManager', function() {
|
|
81
84
|
let eventSource;
|
82
85
|
|
83
86
|
beforeEach(function(){
|
87
|
+
sandbox = sinon.createSandbox();
|
84
88
|
mockIframe = createMockIframe();
|
85
|
-
parseStub =
|
86
|
-
iframeStub =
|
87
|
-
triggerPixelSpy =
|
89
|
+
parseStub = sandbox.stub(utils, 'parseUrl');
|
90
|
+
iframeStub = sandbox.stub(domHelper, 'getEmptyIframe').returns(mockIframe);
|
91
|
+
triggerPixelSpy = sandbox.stub(utils, 'triggerPixel');
|
88
92
|
parseStub.returns({
|
89
93
|
protocol: 'http',
|
90
94
|
host: 'example.com'
|
@@ -102,9 +106,7 @@ describe('renderingManager', function() {
|
|
102
106
|
});
|
103
107
|
|
104
108
|
afterEach(function () {
|
105
|
-
|
106
|
-
iframeStub.restore();
|
107
|
-
triggerPixelSpy.restore();
|
109
|
+
sandbox.restore();
|
108
110
|
});
|
109
111
|
|
110
112
|
function mockPrebidResponse(msg) {
|
@@ -114,6 +116,18 @@ describe('renderingManager', function() {
|
|
114
116
|
});
|
115
117
|
}
|
116
118
|
|
119
|
+
it('should run renderer if present', () => {
|
120
|
+
sandbox.stub(dynamic, 'runDynamicRenderer');
|
121
|
+
const data = {
|
122
|
+
adId: '123',
|
123
|
+
renderer: 'mock-renderer',
|
124
|
+
rendererVersion: MIN_RENDERER_VERSION,
|
125
|
+
ad: 'markup'
|
126
|
+
};
|
127
|
+
mockPrebidResponse(data);
|
128
|
+
sinon.assert.calledWith(dynamic.runDynamicRenderer, data.adId, sinon.match(data))
|
129
|
+
})
|
130
|
+
|
117
131
|
it("should render cross domain creative", function () {
|
118
132
|
mockPrebidResponse({
|
119
133
|
ad: "ad",
|
package/webpack.conf.js
CHANGED
package/.nvmrc
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
8.7.0
|