@browserless/test 10.9.11 → 10.9.15

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/package.json CHANGED
@@ -2,8 +2,12 @@
2
2
  "name": "@browserless/test",
3
3
  "description": "A test suite for browserless API",
4
4
  "homepage": "https://browserless.js.org",
5
- "version": "10.9.11",
6
- "main": "index.js",
5
+ "version": "10.9.15",
6
+ "exports": {
7
+ ".": "./src/index.js",
8
+ "./create": "./src/create.js",
9
+ "./suite": "./src/suite.js"
10
+ },
7
11
  "author": {
8
12
  "email": "hello@microlink.io",
9
13
  "name": "microlink.io",
@@ -43,13 +47,12 @@
43
47
  "node": ">= 12"
44
48
  },
45
49
  "files": [
46
- "fixtures",
47
- "index.js"
50
+ "src"
48
51
  ],
49
52
  "scripts": {
50
53
  "coverage": "exit 0",
51
54
  "test": "exit 0"
52
55
  },
53
56
  "license": "MIT",
54
- "gitHead": "01e4b9a320e1f0f7a7005710e1eec841fed917b6"
57
+ "gitHead": "b7e795fe720ee15519ecb14210fc4b11379e25ad"
55
58
  }
package/src/create.js ADDED
@@ -0,0 +1,64 @@
1
+ 'use strict'
2
+
3
+ const { default: listen } = require('async-listen')
4
+ const { onExit } = require('signal-exit')
5
+ const { createServer } = require('http')
6
+
7
+ const closeServer = server => require('util').promisify(server.close.bind(server))()
8
+
9
+ const runServer = async (t, handler) => {
10
+ const server = createServer(async (req, res) => {
11
+ try {
12
+ await handler({ req, res })
13
+ } catch (error) {
14
+ console.error(error)
15
+ res.statusCode = 500
16
+ res.end()
17
+ }
18
+ })
19
+
20
+ const url = await listen(server)
21
+ url.hostname = '127.0.0.1'
22
+
23
+ t.teardown(() => closeServer(server))
24
+ return url.toString()
25
+ }
26
+
27
+ module.exports = opts => {
28
+ let _browser
29
+
30
+ const createBrowser = () => {
31
+ const browser = require('browserless')(opts)
32
+ onExit(browser.close)
33
+ return browser
34
+ }
35
+
36
+ const getBrowser = () => _browser || (_browser = createBrowser())
37
+
38
+ const getInternalBrowser = () => getBrowser().browser()
39
+
40
+ const getBrowserWSEndpoint = () => getInternalBrowser().then(browser => browser.wsEndpoint())
41
+
42
+ const getBrowserContext = async (t, opts) => {
43
+ const browserless = await getBrowser().createContext(opts)
44
+ t.teardown(browserless.destroyContext)
45
+ return browserless
46
+ }
47
+
48
+ const getPage = async (t, opts) => {
49
+ const browserless = await getBrowserContext(t, opts)
50
+ const page = await browserless.page()
51
+ t.teardown(() => page.close())
52
+ return page
53
+ }
54
+
55
+ return {
56
+ createBrowser,
57
+ getBrowser,
58
+ getBrowserContext,
59
+ getBrowserWSEndpoint,
60
+ getInternalBrowser,
61
+ getPage,
62
+ runServer
63
+ }
64
+ }
package/src/index.js ADDED
@@ -0,0 +1 @@
1
+ module.exports = require('./create')({ timeout: 120000 })
@@ -3,13 +3,14 @@
3
3
  const { imgDiff } = require('img-diff-js')
4
4
  const { PDFParse } = require('pdf-parse')
5
5
  const { onExit } = require('signal-exit')
6
- const { runServer } = require('./util')
7
6
  const { copy } = require('fs-extra')
8
7
  const temp = require('temperment')
9
8
  const path = require('path')
10
9
  const test = require('ava')
11
10
  const fs = require('fs')
12
11
 
12
+ const { runServer } = require('.')
13
+
13
14
  const isCI = !!process.env.CI
14
15
 
15
16
  const PIXELS_DIFFERENCE = isCI ? 50000 : 0