From fc94f98247c22d61d9f6fb7e1c348af901d077b4 Mon Sep 17 00:00:00 2001 From: Andrey Lushnikov Date: Thu, 15 Feb 2018 13:24:24 -0800 Subject: [PATCH] feat(Targets): expose browser target (#2036) This patch exposes "browser" target to the list of targets. --- docs/api.md | 2 +- lib/Browser.js | 4 ++-- test/test.js | 8 ++++++-- 3 files changed, 9 insertions(+), 5 deletions(-) diff --git a/docs/api.md b/docs/api.md index 2a756cfe8f7..171b8947479 100644 --- a/docs/api.md +++ b/docs/api.md @@ -2483,7 +2483,7 @@ If the target is not of type `"page"`, returns `null`. #### target.type() - returns: <[string]> -Identifies what kind of target this is. Can be `"page"`, `"service_worker"`, or `"other"`. +Identifies what kind of target this is. Can be `"page"`, `"service_worker"`, `"browser"` or `"other"`. #### target.url() - returns: <[string]> diff --git a/lib/Browser.js b/lib/Browser.js index 2772956be69..79d1d3382f1 100644 --- a/lib/Browser.js +++ b/lib/Browser.js @@ -229,11 +229,11 @@ class Target { } /** - * @return {"page"|"service_worker"|"other"} + * @return {"page"|"service_worker"|"other"|"browser"} */ type() { const type = this._targetInfo.type; - if (type === 'page' || type === 'service_worker') + if (type === 'page' || type === 'service_worker' || type === 'browser') return type; return 'other'; } diff --git a/test/test.js b/test/test.js index 3739c65dead..bc0b9fb017b 100644 --- a/test/test.js +++ b/test/test.js @@ -3608,8 +3608,7 @@ describe('Page', function() { const targets = browser.targets(); expect(targets.some(target => target.type() === 'page' && target.url() === 'about:blank')).toBeTruthy('Missing blank page'); - expect(targets.some(target => target.type() === 'other' && - target.url() === '')).toBeTruthy('Missing browser target'); + expect(targets.some(target => target.type() === 'browser')).toBeTruthy('Missing browser target'); }); it('Browser.pages should return all of the pages', async({page, server, browser}) => { // The pages will be the testing page and the original newtab page @@ -3618,6 +3617,11 @@ describe('Page', function() { expect(allPages).toContain(page); expect(allPages[0]).not.toBe(allPages[1]); }); + it('should contain browser target', async({browser}) => { + const targets = browser.targets(); + const browserTarget = targets.find(target => target.type() === 'browser'); + expect(browserTarget).toBeTruthy(); + }); it('should be able to use the default page in the browser', async({page, server, browser}) => { // The pages will be the testing page and the original newtab page const allPages = await browser.pages();