From e81384b63df25866310868b939d1140fab1062e3 Mon Sep 17 00:00:00 2001 From: Rich Snapp Date: Wed, 30 May 2018 13:53:31 -0700 Subject: [PATCH] Revert "New debugging functionality with bid overrides (#2492)" This reverts commit 48bd7b8ca643f62f79f103b0766c0154a0044e92. --- src/debugging.js | 89 ----------------------- src/hook.js | 3 - src/prebid.js | 4 - test/spec/debugging_spec.js | 141 ------------------------------------ 4 files changed, 237 deletions(-) delete mode 100644 src/debugging.js delete mode 100644 test/spec/debugging_spec.js diff --git a/src/debugging.js b/src/debugging.js deleted file mode 100644 index 39ddc92beee..00000000000 --- a/src/debugging.js +++ /dev/null @@ -1,89 +0,0 @@ - -import { config } from 'src/config'; -import { logMessage as utilsLogMessage, logWarn as utilsLogWarn } from 'src/utils'; -import { addBidResponse } from 'src/auction'; - -const OVERRIDE_KEY = '$$PREBID_GLOBAL$$:debugging'; - -export let boundHook; - -function logMessage(msg) { - utilsLogMessage('DEBUG: ' + msg); -} - -function logWarn(msg) { - utilsLogWarn('DEBUG: ' + msg); -} - -function enableOverrides(overrides, fromSession = false) { - config.setConfig({'debug': true}); - logMessage(`bidder overrides enabled${fromSession ? ' from session' : ''}`); - - if (boundHook) { - addBidResponse.removeHook(boundHook); - } - - boundHook = addBidResponseHook.bind(null, overrides); - addBidResponse.addHook(boundHook, 5); -} - -export function disableOverrides() { - if (boundHook) { - addBidResponse.removeHook(boundHook); - logMessage('bidder overrides disabled'); - } -} - -export function addBidResponseHook(overrides, adUnitCode, bid, next) { - if (Array.isArray(overrides.bidders) && overrides.bidders.indexOf(bid.bidderCode) === -1) { - logWarn(`bidder '${bid.bidderCode}' excluded from auction by bidder overrides`); - return; - } - - if (Array.isArray(overrides.bids)) { - overrides.bids.forEach(overrideBid => { - if (overrideBid.bidder && overrideBid.bidder !== bid.bidderCode) { - return; - } - if (overrideBid.adUnitCode && overrideBid.adUnitCode !== adUnitCode) { - return; - } - - bid = Object.assign({}, bid); - - Object.keys(overrideBid).filter(key => ['bidder', 'adUnitCode'].indexOf(key) === -1).forEach((key) => { - let value = overrideBid[key]; - logMessage(`bidder overrides changed '${adUnitCode}/${bid.bidderCode}' bid.${key} from '${bid[key]}' to '${value}'`); - bid[key] = value; - }); - }); - } - - next(adUnitCode, bid); -} - -export function getConfig(debugging) { - if (!debugging.enabled) { - disableOverrides(); - try { - window.sessionStorage.removeItem(OVERRIDE_KEY); - } catch (e) {} - } else { - try { - window.sessionStorage.setItem(OVERRIDE_KEY, JSON.stringify(debugging)); - } catch (e) {} - enableOverrides(debugging); - } -} -config.getConfig('debugging', ({debugging}) => getConfig(debugging)); - -export function sessionLoader() { - let overrides; - try { - overrides = JSON.parse(window.sessionStorage.getItem(OVERRIDE_KEY)); - } catch (e) { - } - if (overrides) { - enableOverrides(overrides, true); - } -} diff --git a/src/hook.js b/src/hook.js index fef62a37c3d..6c6cefdc56c 100644 --- a/src/hook.js +++ b/src/hook.js @@ -60,9 +60,6 @@ export function createHook(type, fn, hookName) { }, removeHook: function(removeFn) { _hooks = _hooks.filter(hook => hook.fn === fn || hook.fn !== removeFn); - }, - hasHook: function(fn) { - return _hooks.some(hook => hook.fn === fn); } }; diff --git a/src/prebid.js b/src/prebid.js index d4fbe17a501..d703df43bf5 100644 --- a/src/prebid.js +++ b/src/prebid.js @@ -9,7 +9,6 @@ import { config } from './config'; import { auctionManager } from './auctionManager'; import { targeting, getOldestBid, RENDERED, BID_TARGETING_SET } from './targeting'; import { createHook } from 'src/hook'; -import { sessionLoader } from 'src/debugging'; import includes from 'core-js/library/fn/array/includes'; const $$PREBID_GLOBAL$$ = getGlobal(); @@ -28,9 +27,6 @@ const eventValidators = { bidWon: checkDefinedPlacement }; -// initialize existing debugging sessions if present -sessionLoader(); - /* Public vars */ $$PREBID_GLOBAL$$.bidderSettings = $$PREBID_GLOBAL$$.bidderSettings || {}; diff --git a/test/spec/debugging_spec.js b/test/spec/debugging_spec.js deleted file mode 100644 index 39b08075e06..00000000000 --- a/test/spec/debugging_spec.js +++ /dev/null @@ -1,141 +0,0 @@ - -import { expect } from 'chai'; -import { sessionLoader, addBidResponseHook, getConfig, disableOverrides, boundHook } from 'src/debugging'; -import { addBidResponse } from 'src/auction'; -import { config } from 'src/config'; - -describe('bid overrides', () => { - let sandbox; - - beforeEach(() => { - sandbox = sinon.sandbox.create(); - }); - - afterEach(() => { - sandbox.restore(); - }); - - describe('initialization', () => { - beforeEach(() => { - sandbox.stub(config, 'setConfig'); - sandbox.stub(window.sessionStorage, 'setItem'); - sandbox.stub(window.sessionStorage, 'removeItem'); - }); - - afterEach(() => { - disableOverrides(); - }); - - it('should happen when enabled with setConfig', () => { - getConfig({ - enabled: true - }); - - expect(addBidResponse.hasHook(boundHook)).to.equal(true); - }); - - it('should happen when configuration found in sessionStorage', () => { - sandbox.stub(window.sessionStorage, 'getItem').returns('{"enabled": true}'); - - sessionLoader(); - expect(addBidResponse.hasHook(boundHook)).to.equal(true); - }); - - it('should not throw if sessionStorage is inaccessible', () => { - sandbox.stub(window.sessionStorage, 'getItem').throws(); - - expect(() => { - sessionLoader(); - }).not.to.throw(); - }); - }); - - describe('hook', () => { - let mockBids; - let bids; - - beforeEach(() => { - let baseBid = { - 'bidderCode': 'rubicon', - 'width': 970, - 'height': 250, - 'statusMessage': 'Bid available', - 'mediaType': 'banner', - 'source': 'client', - 'currency': 'USD', - 'cpm': 0.5, - 'ttl': 300, - 'netRevenue': false, - 'adUnitCode': '/19968336/header-bid-tag-0' - }; - mockBids = []; - mockBids.push(baseBid); - mockBids.push(Object.assign({}, baseBid, { - bidderCode: 'appnexus' - })); - - bids = []; - }); - - function run(overrides) { - mockBids.forEach(bid => { - addBidResponseHook(overrides, bid.adUnitCode, bid, (adUnitCode, bid) => { - bids.push(bid); - }) - }); - } - - it('should allow us to exclude bidders', () => { - run({ - enabled: true, - bidders: ['appnexus'] - }); - - expect(bids.length).to.equal(1); - expect(bids[0].bidderCode).to.equal('appnexus'); - }); - - it('should allow us to override all bids', () => { - run({ - enabled: true, - bids: [{ - cpm: 2 - }] - }); - - expect(bids.length).to.equal(2); - expect(bids[0].cpm).to.equal(2); - expect(bids[1].cpm).to.equal(2); - }); - - it('should allow us to override bids by bidder', () => { - run({ - enabled: true, - bids: [{ - bidder: 'rubicon', - cpm: 2 - }] - }); - - expect(bids.length).to.equal(2); - expect(bids[0].cpm).to.equal(2); - expect(bids[1].cpm).to.equal(0.5); - }); - - it('should allow us to override bids by adUnitCode', () => { - mockBids[1].adUnitCode = 'test'; - - run({ - enabled: true, - bids: [{ - adUnitCode: 'test', - cpm: 2 - }] - }); - - expect(bids.length).to.equal(2); - expect(bids[0].cpm).to.equal(0.5); - expect(bids[1].cpm).to.equal(2); - }); - }); -});