@appium/base-driver 8.2.0 → 8.2.4
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/build/lib/basedriver/capabilities.js +3 -1
- package/build/lib/basedriver/commands/index.js +2 -4
- package/build/lib/basedriver/driver.js +5 -5
- package/build/lib/basedriver/helpers.js +137 -81
- package/build/lib/express/express-logging.js +2 -2
- package/build/lib/index.js +126 -0
- package/build/lib/jsonwp-proxy/protocol-converter.js +2 -5
- package/build/lib/jsonwp-proxy/proxy.js +2 -5
- package/build/lib/protocol/errors.js +4 -2
- package/build/lib/protocol/helpers.js +3 -20
- package/build/lib/protocol/protocol.js +9 -19
- package/build/lib/protocol/routes.js +1 -10
- package/build/test/basedriver/capability-specs.js +10 -10
- package/build/test/basedriver/commands/event-specs.js +10 -10
- package/build/test/basedriver/driver-e2e-specs.js +3 -3
- package/build/test/basedriver/driver-e2e-tests.js +6 -223
- package/build/test/basedriver/driver-specs.js +3 -3
- package/build/test/basedriver/driver-tests.js +4 -4
- package/build/test/basedriver/helpers-specs.js +5 -1
- package/build/test/basedriver/timeout-specs.js +7 -7
- package/build/test/basedriver/websockets-e2e-specs.js +5 -5
- package/build/test/express/server-e2e-specs.js +156 -0
- package/build/test/express/server-specs.js +151 -0
- package/build/test/express/static-specs.js +23 -0
- package/build/test/helpers.js +57 -0
- package/build/test/jsonwp-proxy/mock-request.js +93 -0
- package/build/test/jsonwp-proxy/protocol-converter-specs.js +173 -0
- package/build/test/jsonwp-proxy/proxy-e2e-specs.js +61 -0
- package/build/test/jsonwp-proxy/proxy-specs.js +294 -0
- package/build/test/jsonwp-proxy/url-specs.js +167 -0
- package/build/test/jsonwp-status/status-specs.js +36 -0
- package/build/test/protocol/errors-specs.js +388 -0
- package/build/test/protocol/fake-driver.js +168 -0
- package/build/test/protocol/helpers.js +27 -0
- package/build/test/protocol/protocol-e2e-specs.js +1182 -0
- package/build/test/protocol/routes-specs.js +82 -0
- package/build/test/protocol/validator-specs.js +151 -0
- package/index.d.ts +0 -1
- package/index.js +1 -62
- package/lib/basedriver/capabilities.js +3 -0
- package/lib/basedriver/commands/index.js +0 -2
- package/lib/basedriver/driver.js +5 -5
- package/lib/basedriver/helpers.js +197 -81
- package/lib/express/express-logging.js +1 -1
- package/lib/index.js +64 -0
- package/lib/jsonwp-proxy/protocol-converter.js +1 -5
- package/lib/jsonwp-proxy/proxy.js +1 -3
- package/lib/protocol/errors.js +1 -1
- package/lib/protocol/helpers.js +5 -25
- package/lib/protocol/protocol.js +9 -25
- package/lib/protocol/routes.js +0 -3
- package/package.json +7 -15
- package/test/basedriver/capability-specs.js +1 -1
- package/test/basedriver/commands/event-specs.js +1 -1
- package/test/basedriver/driver-e2e-specs.js +1 -1
- package/test/basedriver/driver-e2e-tests.js +1 -179
- package/test/basedriver/driver-specs.js +1 -1
- package/test/basedriver/driver-tests.js +1 -1
- package/test/basedriver/helpers-specs.js +4 -0
- package/test/basedriver/timeout-specs.js +1 -1
- package/test/basedriver/websockets-e2e-specs.js +1 -1
- package/build/index.js +0 -124
- package/build/lib/basedriver/commands/execute-child.js +0 -137
- package/build/lib/basedriver/commands/execute.js +0 -119
- package/build/test/basedriver/fixtures/custom-element-finder-bad.js +0 -12
- package/build/test/basedriver/fixtures/custom-element-finder.js +0 -36
- package/lib/basedriver/commands/execute-child.js +0 -132
- package/lib/basedriver/commands/execute.js +0 -126
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
require("source-map-support/register");
|
|
6
|
+
|
|
7
|
+
var _lib = require("../../lib");
|
|
8
|
+
|
|
9
|
+
var _axios = _interopRequireDefault(require("axios"));
|
|
10
|
+
|
|
11
|
+
var _sinon = _interopRequireDefault(require("sinon"));
|
|
12
|
+
|
|
13
|
+
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
14
|
+
|
|
15
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
16
|
+
|
|
17
|
+
var _helpers = require("../helpers");
|
|
18
|
+
|
|
19
|
+
describe('server', function () {
|
|
20
|
+
let hwServer;
|
|
21
|
+
let errorStub;
|
|
22
|
+
let port;
|
|
23
|
+
before(async function () {
|
|
24
|
+
port = await (0, _helpers.getTestPort)(true);
|
|
25
|
+
errorStub = _sinon.default.stub(console, 'error');
|
|
26
|
+
|
|
27
|
+
function configureRoutes(app) {
|
|
28
|
+
app.get('/', (req, res) => {
|
|
29
|
+
res.header['content-type'] = 'text/html';
|
|
30
|
+
res.status(200).send('Hello World!');
|
|
31
|
+
});
|
|
32
|
+
app.get('/python', (req, res) => {
|
|
33
|
+
res.status(200).send(req.headers['content-type']);
|
|
34
|
+
});
|
|
35
|
+
app.get('/error', () => {
|
|
36
|
+
throw new Error('hahaha');
|
|
37
|
+
});
|
|
38
|
+
app.get('/pause', async (req, res) => {
|
|
39
|
+
res.header['content-type'] = 'text/html';
|
|
40
|
+
await _bluebird.default.delay(1000);
|
|
41
|
+
res.status(200).send('We have waited!');
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
hwServer = await (0, _lib.server)({
|
|
46
|
+
routeConfiguringFunction: configureRoutes,
|
|
47
|
+
port
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
after(async function () {
|
|
51
|
+
await hwServer.close();
|
|
52
|
+
errorStub.restore();
|
|
53
|
+
});
|
|
54
|
+
it('should start up with our middleware', async function () {
|
|
55
|
+
const {
|
|
56
|
+
data
|
|
57
|
+
} = await _axios.default.get(`http://${_helpers.TEST_HOST}:${port}/`);
|
|
58
|
+
data.should.eql('Hello World!');
|
|
59
|
+
});
|
|
60
|
+
it('should fix broken context type', async function () {
|
|
61
|
+
const {
|
|
62
|
+
data
|
|
63
|
+
} = await (0, _axios.default)({
|
|
64
|
+
url: `http://${_helpers.TEST_HOST}:${port}/python`,
|
|
65
|
+
headers: {
|
|
66
|
+
'user-agent': 'Python',
|
|
67
|
+
'content-type': 'application/x-www-form-urlencoded'
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
data.should.eql('application/json; charset=utf-8');
|
|
71
|
+
});
|
|
72
|
+
it('should catch errors in the catchall', async function () {
|
|
73
|
+
await _axios.default.get(`http://${_helpers.TEST_HOST}:${port}/error`).should.be.rejected;
|
|
74
|
+
});
|
|
75
|
+
it('should error if we try to start again on a port that is used', async function () {
|
|
76
|
+
await (0, _lib.server)({
|
|
77
|
+
routeConfiguringFunction() {},
|
|
78
|
+
|
|
79
|
+
port
|
|
80
|
+
}).should.be.rejectedWith(/EADDRINUSE/);
|
|
81
|
+
});
|
|
82
|
+
it('should not wait for the server close connections before finishing closing', async function () {
|
|
83
|
+
let bodyPromise = _axios.default.get(`http://${_helpers.TEST_HOST}:${port}/pause`).catch(() => {});
|
|
84
|
+
|
|
85
|
+
await _bluebird.default.delay(100);
|
|
86
|
+
let before = Date.now();
|
|
87
|
+
await hwServer.close();
|
|
88
|
+
(Date.now() - before).should.not.be.above(800);
|
|
89
|
+
await bodyPromise;
|
|
90
|
+
});
|
|
91
|
+
it('should error if we try to start on a bad hostname', async function () {
|
|
92
|
+
this.timeout(60000);
|
|
93
|
+
await (0, _lib.server)({
|
|
94
|
+
routeConfiguringFunction: _lodash.default.noop,
|
|
95
|
+
port,
|
|
96
|
+
hostname: 'lolcathost'
|
|
97
|
+
}).should.be.rejectedWith(/ENOTFOUND|EADDRNOTAVAIL|EAI_AGAIN/);
|
|
98
|
+
await (0, _lib.server)({
|
|
99
|
+
routeConfiguringFunction: _lodash.default.noop,
|
|
100
|
+
port,
|
|
101
|
+
hostname: '1.1.1.1'
|
|
102
|
+
}).should.be.rejectedWith(/EADDRNOTAVAIL/);
|
|
103
|
+
});
|
|
104
|
+
});
|
|
105
|
+
describe('server plugins', function () {
|
|
106
|
+
let hwServer;
|
|
107
|
+
let port;
|
|
108
|
+
before(async function () {
|
|
109
|
+
port = await (0, _helpers.getTestPort)(true);
|
|
110
|
+
});
|
|
111
|
+
afterEach(async function () {
|
|
112
|
+
try {
|
|
113
|
+
await hwServer.close();
|
|
114
|
+
} catch (ign) {}
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
function updaterWithGetRoute(route, reply) {
|
|
118
|
+
return async (app, httpServer) => {
|
|
119
|
+
app.get(`/${route}`, (req, res) => {
|
|
120
|
+
res.header['content-type'] = 'text/html';
|
|
121
|
+
res.status(200).send(reply);
|
|
122
|
+
});
|
|
123
|
+
httpServer[`_updated_${route}`] = true;
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
it('should allow one or more plugins to update the server', async function () {
|
|
128
|
+
hwServer = await (0, _lib.server)({
|
|
129
|
+
routeConfiguringFunction: _lodash.default.noop,
|
|
130
|
+
port,
|
|
131
|
+
serverUpdaters: [updaterWithGetRoute('plugin1', 'res from plugin1 route'), updaterWithGetRoute('plugin2', 'res from plugin2 route')]
|
|
132
|
+
});
|
|
133
|
+
let {
|
|
134
|
+
data
|
|
135
|
+
} = await _axios.default.get(`http://${_helpers.TEST_HOST}:${port}/plugin1`);
|
|
136
|
+
data.should.eql('res from plugin1 route');
|
|
137
|
+
({
|
|
138
|
+
data
|
|
139
|
+
} = await _axios.default.get(`http://${_helpers.TEST_HOST}:${port}/plugin2`));
|
|
140
|
+
data.should.eql('res from plugin2 route');
|
|
141
|
+
hwServer._updated_plugin1.should.be.true;
|
|
142
|
+
hwServer._updated_plugin2.should.be.true;
|
|
143
|
+
});
|
|
144
|
+
it('should pass on errors from the plugin updateServer method', async function () {
|
|
145
|
+
await (0, _lib.server)({
|
|
146
|
+
routeConfiguringFunction: _lodash.default.noop,
|
|
147
|
+
port,
|
|
148
|
+
serverUpdaters: [() => {
|
|
149
|
+
throw new Error('ugh');
|
|
150
|
+
}]
|
|
151
|
+
}).should.eventually.be.rejectedWith(/ugh/);
|
|
152
|
+
});
|
|
153
|
+
});require('source-map-support').install();
|
|
154
|
+
|
|
155
|
+
|
|
156
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/express/server-e2e-specs.js"],"names":["describe","hwServer","errorStub","port","before","sinon","stub","console","configureRoutes","app","get","req","res","header","status","send","headers","Error","B","delay","routeConfiguringFunction","after","close","restore","it","data","axios","TEST_HOST","should","eql","url","be","rejected","rejectedWith","bodyPromise","catch","Date","now","not","above","timeout","_","noop","hostname","afterEach","ign","updaterWithGetRoute","route","reply","httpServer","serverUpdaters","_updated_plugin1","true","_updated_plugin2","eventually"],"mappings":"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","sourcesContent":["// transpile:mocha\n\nimport { server } from '../../lib';\nimport axios from 'axios';\nimport sinon from 'sinon';\nimport B from 'bluebird';\nimport _ from 'lodash';\nimport {TEST_HOST, getTestPort} from '../helpers';\n\n\ndescribe('server', function () {\n  let hwServer;\n  let errorStub;\n  let port;\n  before(async function () {\n    port = await getTestPort(true);\n    errorStub = sinon.stub(console, 'error');\n    function configureRoutes (app) {\n      app.get('/', (req, res) => {\n        res.header['content-type'] = 'text/html';\n        res.status(200).send('Hello World!');\n      });\n      app.get('/python', (req, res) => {\n        res.status(200).send(req.headers['content-type']);\n      });\n      app.get('/error', () => {\n        throw new Error('hahaha');\n      });\n      app.get('/pause', async (req, res) => {\n        res.header['content-type'] = 'text/html';\n        await B.delay(1000);\n        res.status(200).send('We have waited!');\n      });\n    }\n    hwServer = await server({\n      routeConfiguringFunction: configureRoutes,\n      port,\n    });\n  });\n  after(async function () {\n    await hwServer.close();\n    errorStub.restore();\n  });\n\n  it('should start up with our middleware', async function () {\n    const {data} = await axios.get(`http://${TEST_HOST}:${port}/`);\n    data.should.eql('Hello World!');\n  });\n  it('should fix broken context type', async function () {\n    const {data} = await axios({\n      url: `http://${TEST_HOST}:${port}/python`,\n      headers: {\n        'user-agent': 'Python',\n        'content-type': 'application/x-www-form-urlencoded'\n      }\n    });\n    data.should.eql('application/json; charset=utf-8');\n  });\n  it('should catch errors in the catchall', async function () {\n    await axios.get(`http://${TEST_HOST}:${port}/error`).should.be.rejected;\n  });\n  it('should error if we try to start again on a port that is used', async function () {\n    await server({\n      routeConfiguringFunction () {},\n      port,\n    }).should.be.rejectedWith(/EADDRINUSE/);\n  });\n  it('should not wait for the server close connections before finishing closing', async function () {\n    let bodyPromise = axios.get(`http://${TEST_HOST}:${port}/pause`).catch(() => {});\n\n    // relinquish control so that we don't close before the request is received\n    await B.delay(100);\n\n    let before = Date.now();\n    await hwServer.close();\n    // expect slightly less than the request waited, since we paused above\n    (Date.now() - before).should.not.be.above(800);\n\n    await bodyPromise;\n  });\n  it('should error if we try to start on a bad hostname', async function () {\n    this.timeout(60000);\n    await server({\n      routeConfiguringFunction: _.noop,\n      port,\n      hostname: 'lolcathost',\n    }).should.be.rejectedWith(/ENOTFOUND|EADDRNOTAVAIL|EAI_AGAIN/);\n    await server({\n      routeConfiguringFunction: _.noop,\n      port,\n      hostname: '1.1.1.1',\n    }).should.be.rejectedWith(/EADDRNOTAVAIL/);\n  });\n});\n\ndescribe('server plugins', function () {\n  let hwServer;\n  let port;\n\n  before(async function () {\n    port = await getTestPort(true);\n  });\n\n  afterEach(async function () {\n    try {\n      await hwServer.close();\n    } catch (ign) {}\n  });\n\n  function updaterWithGetRoute (route, reply) {\n    return async (app, httpServer) => { // eslint-disable-line require-await\n      app.get(`/${route}`, (req, res) => {\n        res.header['content-type'] = 'text/html';\n        res.status(200).send(reply);\n      });\n      httpServer[`_updated_${route}`] = true;\n    };\n  }\n\n  it('should allow one or more plugins to update the server', async function () {\n    hwServer = await server({\n      routeConfiguringFunction: _.noop,\n      port,\n      serverUpdaters: [\n        updaterWithGetRoute('plugin1', 'res from plugin1 route'),\n        updaterWithGetRoute('plugin2', 'res from plugin2 route'),\n      ]\n    });\n    let {data} = await axios.get(`http://${TEST_HOST}:${port}/plugin1`);\n    data.should.eql('res from plugin1 route');\n    ({data} = await axios.get(`http://${TEST_HOST}:${port}/plugin2`));\n    data.should.eql('res from plugin2 route');\n    hwServer._updated_plugin1.should.be.true;\n    hwServer._updated_plugin2.should.be.true;\n  });\n  it('should pass on errors from the plugin updateServer method', async function () {\n    await server({\n      routeConfiguringFunction: _.noop,\n      port,\n      serverUpdaters: [() => { throw new Error('ugh');}]\n    }).should.eventually.be.rejectedWith(/ugh/);\n  });\n});\n"],"file":"test/express/server-e2e-specs.js","sourceRoot":"../../.."}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
require("source-map-support/register");
|
|
6
|
+
|
|
7
|
+
var _lib = require("../../lib");
|
|
8
|
+
|
|
9
|
+
var _server2 = require("../../lib/express/server");
|
|
10
|
+
|
|
11
|
+
var _sinon = _interopRequireDefault(require("sinon"));
|
|
12
|
+
|
|
13
|
+
var _helpers = require("../helpers");
|
|
14
|
+
|
|
15
|
+
function fakeApp() {
|
|
16
|
+
const app = {
|
|
17
|
+
use: _sinon.default.spy(),
|
|
18
|
+
all: _sinon.default.spy(),
|
|
19
|
+
get: _sinon.default.spy(),
|
|
20
|
+
post: _sinon.default.spy(),
|
|
21
|
+
delete: _sinon.default.spy(),
|
|
22
|
+
totalCount: () => app.use.callCount + app.all.callCount + app.get.callCount + app.post.callCount + app.delete.callCount
|
|
23
|
+
};
|
|
24
|
+
return app;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const newMethodMap = {
|
|
28
|
+
'/session/:sessionId/fake': {
|
|
29
|
+
GET: {
|
|
30
|
+
command: 'fakeGet'
|
|
31
|
+
},
|
|
32
|
+
POST: {
|
|
33
|
+
command: 'fakePost',
|
|
34
|
+
payloadParams: {
|
|
35
|
+
required: ['fakeParam']
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
const updateServer = (app, httpServer) => {
|
|
42
|
+
app.updated = true;
|
|
43
|
+
httpServer.updated = true;
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
function fakeDriver() {
|
|
47
|
+
return {
|
|
48
|
+
sessionExists: () => {},
|
|
49
|
+
executeCommand: () => {}
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
describe('server configuration', function () {
|
|
54
|
+
let port;
|
|
55
|
+
before(async function () {
|
|
56
|
+
port = await (0, _helpers.getTestPort)(true);
|
|
57
|
+
});
|
|
58
|
+
it('should actually use the middleware', function () {
|
|
59
|
+
const app = fakeApp();
|
|
60
|
+
|
|
61
|
+
const configureRoutes = () => {};
|
|
62
|
+
|
|
63
|
+
(0, _server2.configureServer)({
|
|
64
|
+
app,
|
|
65
|
+
addRoutes: configureRoutes
|
|
66
|
+
});
|
|
67
|
+
app.use.callCount.should.equal(14);
|
|
68
|
+
app.all.callCount.should.equal(4);
|
|
69
|
+
});
|
|
70
|
+
it('should apply new methods in plugins to the standard method map', function () {
|
|
71
|
+
const app1 = fakeApp();
|
|
72
|
+
const app2 = fakeApp();
|
|
73
|
+
const driver = fakeDriver();
|
|
74
|
+
const addRoutes = (0, _lib.routeConfiguringFunction)(driver);
|
|
75
|
+
(0, _server2.configureServer)({
|
|
76
|
+
app: app1,
|
|
77
|
+
addRoutes
|
|
78
|
+
});
|
|
79
|
+
(0, _server2.configureServer)({
|
|
80
|
+
app: app2,
|
|
81
|
+
addRoutes,
|
|
82
|
+
extraMethodMap: newMethodMap
|
|
83
|
+
});
|
|
84
|
+
app2.totalCount().should.eql(app1.totalCount() + 2);
|
|
85
|
+
});
|
|
86
|
+
it('should silently reject new methods in plugins if not plain objects', function () {
|
|
87
|
+
const app1 = fakeApp();
|
|
88
|
+
const app2 = fakeApp();
|
|
89
|
+
const driver = fakeDriver();
|
|
90
|
+
const addRoutes = (0, _lib.routeConfiguringFunction)(driver);
|
|
91
|
+
(0, _server2.configureServer)({
|
|
92
|
+
app: app1,
|
|
93
|
+
addRoutes
|
|
94
|
+
});
|
|
95
|
+
(0, _server2.configureServer)({
|
|
96
|
+
app: app2,
|
|
97
|
+
addRoutes,
|
|
98
|
+
extraMethodMap: []
|
|
99
|
+
});
|
|
100
|
+
app2.totalCount().should.eql(app1.totalCount());
|
|
101
|
+
});
|
|
102
|
+
it('should allow plugins to update the server', async function () {
|
|
103
|
+
const driver = fakeDriver();
|
|
104
|
+
|
|
105
|
+
const _server = await (0, _lib.server)({
|
|
106
|
+
routeConfiguringFunction: (0, _lib.routeConfiguringFunction)(driver),
|
|
107
|
+
port,
|
|
108
|
+
extraMethodMap: newMethodMap,
|
|
109
|
+
serverUpdaters: [updateServer]
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
try {
|
|
113
|
+
_server.updated.should.be.true;
|
|
114
|
+
} finally {
|
|
115
|
+
await _server.close();
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
it('should reject if error thrown in configureRoutes parameter', async function () {
|
|
119
|
+
const configureRoutes = () => {
|
|
120
|
+
throw new Error('I am Mr. MeeSeeks look at me!');
|
|
121
|
+
};
|
|
122
|
+
|
|
123
|
+
await (0, _lib.server)({
|
|
124
|
+
routeConfiguringFunction: configureRoutes,
|
|
125
|
+
port
|
|
126
|
+
}).should.be.rejectedWith('MeeSeeks');
|
|
127
|
+
});
|
|
128
|
+
describe('#normalizeBasePath', function () {
|
|
129
|
+
it('should throw an error for paths of the wrong type', function () {
|
|
130
|
+
should.throw(() => {
|
|
131
|
+
(0, _server2.normalizeBasePath)(null);
|
|
132
|
+
});
|
|
133
|
+
should.throw(() => {
|
|
134
|
+
(0, _server2.normalizeBasePath)(1);
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
it('should remove trailing slashes', function () {
|
|
138
|
+
(0, _server2.normalizeBasePath)('/wd/hub/').should.eql('/wd/hub');
|
|
139
|
+
(0, _server2.normalizeBasePath)('/foo/').should.eql('/foo');
|
|
140
|
+
(0, _server2.normalizeBasePath)('/').should.eql('');
|
|
141
|
+
});
|
|
142
|
+
it('should ensure a leading slash is present', function () {
|
|
143
|
+
(0, _server2.normalizeBasePath)('foo').should.eql('/foo');
|
|
144
|
+
(0, _server2.normalizeBasePath)('wd/hub').should.eql('/wd/hub');
|
|
145
|
+
(0, _server2.normalizeBasePath)('wd/hub/').should.eql('/wd/hub');
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
});require('source-map-support').install();
|
|
149
|
+
|
|
150
|
+
|
|
151
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/express/server-specs.js"],"names":["fakeApp","app","use","sinon","spy","all","get","post","delete","totalCount","callCount","newMethodMap","GET","command","POST","payloadParams","required","updateServer","httpServer","updated","fakeDriver","sessionExists","executeCommand","describe","port","before","it","configureRoutes","addRoutes","should","equal","app1","app2","driver","extraMethodMap","eql","_server","routeConfiguringFunction","serverUpdaters","be","true","close","Error","rejectedWith","throw"],"mappings":"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","sourcesContent":["// transpile:mocha\n\nimport { server, routeConfiguringFunction } from '../../lib';\nimport { configureServer, normalizeBasePath } from '../../lib/express/server';\nimport sinon from 'sinon';\nimport {getTestPort} from '../helpers';\n\nfunction fakeApp () {\n  const app = {\n    use: sinon.spy(),\n    all: sinon.spy(),\n    get: sinon.spy(),\n    post: sinon.spy(),\n    delete: sinon.spy(),\n    totalCount: () => (\n      app.use.callCount + app.all.callCount + app.get.callCount + app.post.callCount +\n      app.delete.callCount\n    )\n  };\n  return app;\n}\n\nconst newMethodMap = {\n  '/session/:sessionId/fake': {\n    GET: {command: 'fakeGet'},\n    POST: {command: 'fakePost', payloadParams: {required: ['fakeParam']}}\n  },\n};\n\nconst updateServer = (app, httpServer) => {\n  app.updated = true;\n  httpServer.updated = true;\n};\n\nfunction fakeDriver () {\n  return {sessionExists: () => {}, executeCommand: () => {}};\n}\n\ndescribe('server configuration', function () {\n  let port;\n\n  before(async function () {\n    port = await getTestPort(true);\n  });\n\n  it('should actually use the middleware', function () {\n    const app = fakeApp();\n    const configureRoutes = () => {};\n    configureServer({app, addRoutes: configureRoutes});\n    app.use.callCount.should.equal(14);\n    app.all.callCount.should.equal(4);\n  });\n\n  it('should apply new methods in plugins to the standard method map', function () {\n    const app1 = fakeApp();\n    const app2 = fakeApp();\n    const driver = fakeDriver();\n    const addRoutes = routeConfiguringFunction(driver);\n    configureServer({app: app1, addRoutes});\n    configureServer({app: app2, addRoutes, extraMethodMap: newMethodMap});\n    app2.totalCount().should.eql(app1.totalCount() + 2);\n  });\n\n  it('should silently reject new methods in plugins if not plain objects', function () {\n    const app1 = fakeApp();\n    const app2 = fakeApp();\n    const driver = fakeDriver();\n    const addRoutes = routeConfiguringFunction(driver);\n    configureServer({app: app1, addRoutes});\n    configureServer({app: app2, addRoutes, extraMethodMap: []});\n    app2.totalCount().should.eql(app1.totalCount());\n  });\n\n  it('should allow plugins to update the server', async function () {\n    const driver = fakeDriver();\n    const _server = await server({\n      routeConfiguringFunction: routeConfiguringFunction(driver),\n      port,\n      extraMethodMap: newMethodMap,\n      serverUpdaters: [updateServer]\n    });\n    try {\n      _server.updated.should.be.true;\n    } finally {\n      await _server.close();\n    }\n  });\n\n  it('should reject if error thrown in configureRoutes parameter', async function () {\n    const configureRoutes = () => {\n      throw new Error('I am Mr. MeeSeeks look at me!');\n    };\n    await server({\n      routeConfiguringFunction: configureRoutes,\n      port,\n    }).should.be.rejectedWith('MeeSeeks');\n  });\n\n  describe('#normalizeBasePath', function () {\n    it('should throw an error for paths of the wrong type', function () {\n      should.throw(() => {\n        normalizeBasePath(null);\n      });\n      should.throw(() => {\n        normalizeBasePath(1);\n      });\n    });\n    it('should remove trailing slashes', function () {\n      normalizeBasePath('/wd/hub/').should.eql('/wd/hub');\n      normalizeBasePath('/foo/').should.eql('/foo');\n      normalizeBasePath('/').should.eql('');\n    });\n    it('should ensure a leading slash is present', function () {\n      normalizeBasePath('foo').should.eql('/foo');\n      normalizeBasePath('wd/hub').should.eql('/wd/hub');\n      normalizeBasePath('wd/hub/').should.eql('/wd/hub');\n    });\n  });\n});\n"],"file":"test/express/server-specs.js","sourceRoot":"../../.."}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
require("source-map-support/register");
|
|
6
|
+
|
|
7
|
+
var _static = require("../../lib/express/static");
|
|
8
|
+
|
|
9
|
+
var _sinon = _interopRequireDefault(require("sinon"));
|
|
10
|
+
|
|
11
|
+
describe('welcome', function () {
|
|
12
|
+
it('should fill the template', async function () {
|
|
13
|
+
let res = {
|
|
14
|
+
send: _sinon.default.spy()
|
|
15
|
+
};
|
|
16
|
+
await (0, _static.welcome)({}, res);
|
|
17
|
+
res.send.calledOnce.should.be.true;
|
|
18
|
+
res.send.args[0][0].should.include('Let\'s browse!');
|
|
19
|
+
});
|
|
20
|
+
});require('source-map-support').install();
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvZXhwcmVzcy9zdGF0aWMtc3BlY3MuanMiXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJpdCIsInJlcyIsInNlbmQiLCJzaW5vbiIsInNweSIsImNhbGxlZE9uY2UiLCJzaG91bGQiLCJiZSIsInRydWUiLCJhcmdzIiwiaW5jbHVkZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRUE7O0FBQ0E7O0FBSUFBLFFBQVEsQ0FBQyxTQUFELEVBQVksWUFBWTtBQUM5QkMsRUFBQUEsRUFBRSxDQUFDLDBCQUFELEVBQTZCLGtCQUFrQjtBQUMvQyxRQUFJQyxHQUFHLEdBQUc7QUFDUkMsTUFBQUEsSUFBSSxFQUFFQyxlQUFNQyxHQUFOO0FBREUsS0FBVjtBQUdBLFVBQU0scUJBQVEsRUFBUixFQUFZSCxHQUFaLENBQU47QUFFQUEsSUFBQUEsR0FBRyxDQUFDQyxJQUFKLENBQVNHLFVBQVQsQ0FBb0JDLE1BQXBCLENBQTJCQyxFQUEzQixDQUE4QkMsSUFBOUI7QUFDQVAsSUFBQUEsR0FBRyxDQUFDQyxJQUFKLENBQVNPLElBQVQsQ0FBYyxDQUFkLEVBQWlCLENBQWpCLEVBQW9CSCxNQUFwQixDQUEyQkksT0FBM0IsQ0FBbUMsZ0JBQW5DO0FBQ0QsR0FSQyxDQUFGO0FBU0QsQ0FWTyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdHJhbnNwaWxlOm1vY2hhXG5cbmltcG9ydCB7IHdlbGNvbWUgfSBmcm9tICcuLi8uLi9saWIvZXhwcmVzcy9zdGF0aWMnO1xuaW1wb3J0IHNpbm9uIGZyb20gJ3Npbm9uJztcblxuXG5cbmRlc2NyaWJlKCd3ZWxjb21lJywgZnVuY3Rpb24gKCkge1xuICBpdCgnc2hvdWxkIGZpbGwgdGhlIHRlbXBsYXRlJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgIGxldCByZXMgPSB7XG4gICAgICBzZW5kOiBzaW5vbi5zcHkoKVxuICAgIH07XG4gICAgYXdhaXQgd2VsY29tZSh7fSwgcmVzKTtcblxuICAgIHJlcy5zZW5kLmNhbGxlZE9uY2Uuc2hvdWxkLmJlLnRydWU7XG4gICAgcmVzLnNlbmQuYXJnc1swXVswXS5zaG91bGQuaW5jbHVkZSgnTGV0XFwncyBicm93c2UhJyk7XG4gIH0pO1xufSk7XG4iXSwiZmlsZSI6InRlc3QvZXhwcmVzcy9zdGF0aWMtc3BlY3MuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4ifQ==
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.createAppiumURL = exports.TEST_HOST = exports.METHODS = void 0;
|
|
9
|
+
exports.getTestPort = getTestPort;
|
|
10
|
+
|
|
11
|
+
require("source-map-support/register");
|
|
12
|
+
|
|
13
|
+
var _getPort = _interopRequireDefault(require("get-port"));
|
|
14
|
+
|
|
15
|
+
var _lodash = require("lodash");
|
|
16
|
+
|
|
17
|
+
const TEST_HOST = '127.0.0.1';
|
|
18
|
+
exports.TEST_HOST = TEST_HOST;
|
|
19
|
+
const METHODS = {
|
|
20
|
+
POST: 'POST',
|
|
21
|
+
DELETE: 'DELETE'
|
|
22
|
+
};
|
|
23
|
+
exports.METHODS = METHODS;
|
|
24
|
+
let testPort;
|
|
25
|
+
|
|
26
|
+
async function getTestPort(force = false) {
|
|
27
|
+
if (force || !testPort) {
|
|
28
|
+
let port = await (0, _getPort.default)();
|
|
29
|
+
|
|
30
|
+
if (!testPort) {
|
|
31
|
+
testPort = port;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
return port;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return testPort;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
const createAppiumURL = (0, _lodash.curry)((address, port, session, pathname) => {
|
|
41
|
+
if (!/^https?:\/\//.test(address)) {
|
|
42
|
+
address = `http://${address}`;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
let path = session ? `session/${session}` : '';
|
|
46
|
+
|
|
47
|
+
if (pathname) {
|
|
48
|
+
path = `${path}/${pathname}`;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
let url = new URL(path, `${address}:${port}`);
|
|
52
|
+
return url.href;
|
|
53
|
+
}, 4);
|
|
54
|
+
exports.createAppiumURL = createAppiumURL;require('source-map-support').install();
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvaGVscGVycy5qcyJdLCJuYW1lcyI6WyJURVNUX0hPU1QiLCJNRVRIT0RTIiwiUE9TVCIsIkRFTEVURSIsInRlc3RQb3J0IiwiZ2V0VGVzdFBvcnQiLCJmb3JjZSIsInBvcnQiLCJjcmVhdGVBcHBpdW1VUkwiLCJhZGRyZXNzIiwic2Vzc2lvbiIsInBhdGhuYW1lIiwidGVzdCIsInBhdGgiLCJ1cmwiLCJVUkwiLCJocmVmIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFFQSxNQUFNQSxTQUFTLEdBQUcsV0FBbEI7O0FBS0EsTUFBTUMsT0FBTyxHQUFHO0FBQ2RDLEVBQUFBLElBQUksRUFBRSxNQURRO0FBRWRDLEVBQUFBLE1BQU0sRUFBRTtBQUZNLENBQWhCOztBQUtBLElBQUlDLFFBQUo7O0FBTUEsZUFBZUMsV0FBZixDQUE0QkMsS0FBSyxHQUFHLEtBQXBDLEVBQTJDO0FBQ3pDLE1BQUlBLEtBQUssSUFBSSxDQUFDRixRQUFkLEVBQXdCO0FBQ3RCLFFBQUlHLElBQUksR0FBRyxNQUFNLHVCQUFqQjs7QUFDQSxRQUFJLENBQUNILFFBQUwsRUFBZTtBQUNiQSxNQUFBQSxRQUFRLEdBQUdHLElBQVg7QUFDRDs7QUFDRCxXQUFPQSxJQUFQO0FBQ0Q7O0FBQ0QsU0FBT0gsUUFBUDtBQUNEOztBQUVELE1BQU1JLGVBQWUsR0FBRyxtQkEyQnRCLENBQUNDLE9BQUQsRUFBVUYsSUFBVixFQUFnQkcsT0FBaEIsRUFBeUJDLFFBQXpCLEtBQXNDO0FBQ3BDLE1BQUksQ0FBQyxlQUFlQyxJQUFmLENBQW9CSCxPQUFwQixDQUFMLEVBQW1DO0FBQ2pDQSxJQUFBQSxPQUFPLEdBQUksVUFBU0EsT0FBUSxFQUE1QjtBQUNEOztBQUNELE1BQUlJLElBQUksR0FBR0gsT0FBTyxHQUFJLFdBQVVBLE9BQVEsRUFBdEIsR0FBMEIsRUFBNUM7O0FBQ0EsTUFBSUMsUUFBSixFQUFjO0FBQ1pFLElBQUFBLElBQUksR0FBSSxHQUFFQSxJQUFLLElBQUdGLFFBQVMsRUFBM0I7QUFDRDs7QUFDRCxNQUFJRyxHQUFHLEdBQUcsSUFBSUMsR0FBSixDQUFRRixJQUFSLEVBQWUsR0FBRUosT0FBUSxJQUFHRixJQUFLLEVBQWpDLENBQVY7QUFDQSxTQUFPTyxHQUFHLENBQUNFLElBQVg7QUFDRCxDQXJDcUIsRUFzQ3RCLENBdENzQixDQUF4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBnZXRQb3J0IGZyb20gJ2dldC1wb3J0JztcbmltcG9ydCB7Y3Vycnl9IGZyb20gJ2xvZGFzaCc7XG5cbmNvbnN0IFRFU1RfSE9TVCA9ICcxMjcuMC4wLjEnO1xuXG4vKipcbiAqIFNvbWUgSFRUUCBtZXRob2RzLCBmb3IgeW91ciBwbGVhc3VyZVxuICovXG5jb25zdCBNRVRIT0RTID0ge1xuICBQT1NUOiAnUE9TVCcsXG4gIERFTEVURTogJ0RFTEVURSdcbn07XG5cbmxldCB0ZXN0UG9ydDtcbi8qKlxuICogUmV0dXJucyBhIGZyZWUgcG9ydDsgb25lIHBlciBwcm9jZXNzXG4gKiBAcGFyYW0ge2Jvb2xlYW59IFtmb3JjZV0gLSBJZiB0cnVlLCBkbyBub3QgcmV1c2UgdGhlIHBvcnQgKGlmIGl0IGFscmVhZHkgZXhpc3RzKVxuICogQHJldHVybnMge1Byb21pc2U8bnVtYmVyPn0gYSBmcmVlIHBvcnRcbiAqL1xuYXN5bmMgZnVuY3Rpb24gZ2V0VGVzdFBvcnQgKGZvcmNlID0gZmFsc2UpIHtcbiAgaWYgKGZvcmNlIHx8ICF0ZXN0UG9ydCkge1xuICAgIGxldCBwb3J0ID0gYXdhaXQgZ2V0UG9ydCgpO1xuICAgIGlmICghdGVzdFBvcnQpIHtcbiAgICAgIHRlc3RQb3J0ID0gcG9ydDtcbiAgICB9XG4gICAgcmV0dXJuIHBvcnQ7XG4gIH1cbiAgcmV0dXJuIHRlc3RQb3J0O1xufVxuXG5jb25zdCBjcmVhdGVBcHBpdW1VUkwgPSBjdXJyeShcbiAgLyoqXG4gICAqIEJ1aWxkIGFuIEFwcGl1bSBVUkwgZnJvbSBjb21wb25lbnRzLlxuICAgKlxuICAgKiAqKkFsbCoqIHBhcmFtZXRlcnMgYXJlIHJlcXVpcmVkLiAgUHJvdmlkZSBhbiBlbXB0eSBzdHJpbmcgKGAnJ2ApIGlmIHlvdSBkb24ndCBuZWVkIG9uZS5cbiAgICogVG8gcmVhcnJhbmdlIGFyZ3VtZW50cyAoaWYgbmVlZGVkKSwgdXNlIHRoZSBwbGFjZWhvbGRlciAoYF9gKS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IGFkZHJlc3MgLSBCYXNlIGFkZHJlc3MgKHcvIG9wdGlvbmFsIHByb3RvY29sKVxuICAgKiBAcGFyYW0ge3N0cmluZ3xudW1iZXJ9IHBvcnQgLSBQb3J0IG51bWJlclxuICAgKiBAcGFyYW0ge3N0cmluZ30gc2Vzc2lvbiAtIFNlc3Npb24gSURcbiAgICogQHBhcmFtIHtzdHJpbmd9IHBhdGhuYW1lIC0gRXh0cmEgcGF0aFxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSBOZXcgVVJMXG4gICAqIEBleGFtcGxlXG4gICAqXG4gICAqIGltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG4gICAqXG4gICAqIC8vIGh0dHA6Ly8xMjcuMC4wLjE6MzEzMzcvc2Vzc2lvblxuICAgKiBjcmVhdGVBcHBpdW1VUkwoJzEyNy4wLjAuMScsIDMxMzM3LCAnJywgJ3Nlc3Npb24nKVxuICAgKlxuICAgKiAvLyBodHRwOi8vMTI3LjAuMC4xOjMxMzM3L3Nlc3Npb24vYXNkZmdqa2xcbiAgICogY29uc3QgY3JlYXRlU2Vzc2lvblVSTCA9IGNyZWF0ZUFwcGl1bVVSTCgnMTI3LjAuMC4xJywgMzEzMzcsIF8sICdzZXNzaW9uJylcbiAgICogY3JlYXRlU2Vzc2lvblVSTCgnYXNkZmdqa2wnKVxuICAgKlxuICAgKiAvLyBodHRwOi8vMTI3LjAuMC4xOjMxMzM3L3Nlc3Npb24vYXNkZmdqa2wvYXBwaXVtL2V4ZWN1dGVcbiAgICogY29uc3QgY3JlYXRlVVJMV2l0aFBhdGggPSBjcmVhdGVBcHBpdW1VUkwoJzEyNy4wLjAuMScsIDMxMzM3LCAnYXNkZmdqa2wnKTtcbiAgICogY3JlYXRlVVJMV2l0aFBhdGgoJ2FwcGl1bS9leGVjdXRlJylcbiAgICovXG4gIChhZGRyZXNzLCBwb3J0LCBzZXNzaW9uLCBwYXRobmFtZSkgPT4ge1xuICAgIGlmICghL15odHRwcz86XFwvXFwvLy50ZXN0KGFkZHJlc3MpKSB7XG4gICAgICBhZGRyZXNzID0gYGh0dHA6Ly8ke2FkZHJlc3N9YDtcbiAgICB9XG4gICAgbGV0IHBhdGggPSBzZXNzaW9uID8gYHNlc3Npb24vJHtzZXNzaW9ufWAgOiAnJztcbiAgICBpZiAocGF0aG5hbWUpIHtcbiAgICAgIHBhdGggPSBgJHtwYXRofS8ke3BhdGhuYW1lfWA7XG4gICAgfVxuICAgIGxldCB1cmwgPSBuZXcgVVJMKHBhdGgsIGAke2FkZHJlc3N9OiR7cG9ydH1gKTtcbiAgICByZXR1cm4gdXJsLmhyZWY7XG4gIH0sXG4gIDQsXG4pO1xuXG5leHBvcnQge1RFU1RfSE9TVCwgTUVUSE9EUywgZ2V0VGVzdFBvcnQsIGNyZWF0ZUFwcGl1bVVSTH07XG4iXSwiZmlsZSI6InRlc3QvaGVscGVycy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
require("source-map-support/register");
|
|
9
|
+
|
|
10
|
+
function resFixture(url, method) {
|
|
11
|
+
if (/\/status$/.test(url)) {
|
|
12
|
+
return [200, {
|
|
13
|
+
status: 0,
|
|
14
|
+
value: {
|
|
15
|
+
foo: 'bar'
|
|
16
|
+
}
|
|
17
|
+
}];
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
if (/\/element\/bad\/text$/.test(url)) {
|
|
21
|
+
return [500, {
|
|
22
|
+
status: 11,
|
|
23
|
+
value: {
|
|
24
|
+
message: 'Invisible element'
|
|
25
|
+
}
|
|
26
|
+
}];
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (/\/element\/200\/text$/.test(url)) {
|
|
30
|
+
return [200, {
|
|
31
|
+
status: 11,
|
|
32
|
+
value: {
|
|
33
|
+
message: 'Invisible element'
|
|
34
|
+
}
|
|
35
|
+
}];
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (/\/element\/200\/value$/.test(url)) {
|
|
39
|
+
return [200, {
|
|
40
|
+
status: 0,
|
|
41
|
+
sessionId: 'innersessionid',
|
|
42
|
+
value: 'foobar'
|
|
43
|
+
}];
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
if (/\/session$/.test(url) && method === 'POST') {
|
|
47
|
+
return [200, {
|
|
48
|
+
status: 0,
|
|
49
|
+
sessionId: '123',
|
|
50
|
+
value: {
|
|
51
|
+
browserName: 'boo'
|
|
52
|
+
}
|
|
53
|
+
}];
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
if (/\/nochrome$/.test(url)) {
|
|
57
|
+
return [100, {
|
|
58
|
+
status: 0,
|
|
59
|
+
value: {
|
|
60
|
+
message: 'chrome not reachable'
|
|
61
|
+
}
|
|
62
|
+
}];
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
throw new Error("Can't handle url " + url);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
async function request(opts) {
|
|
69
|
+
const {
|
|
70
|
+
url,
|
|
71
|
+
method,
|
|
72
|
+
json
|
|
73
|
+
} = opts;
|
|
74
|
+
|
|
75
|
+
if (/badurl$/.test(url)) {
|
|
76
|
+
throw new Error('noworky');
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const [status, data] = resFixture(url, method, json);
|
|
80
|
+
return {
|
|
81
|
+
status,
|
|
82
|
+
headers: {
|
|
83
|
+
'content-type': 'application/json; charset=utf-8'
|
|
84
|
+
},
|
|
85
|
+
data
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
var _default = request;
|
|
90
|
+
exports.default = _default;require('source-map-support').install();
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvanNvbndwLXByb3h5L21vY2stcmVxdWVzdC5qcyJdLCJuYW1lcyI6WyJyZXNGaXh0dXJlIiwidXJsIiwibWV0aG9kIiwidGVzdCIsInN0YXR1cyIsInZhbHVlIiwiZm9vIiwibWVzc2FnZSIsInNlc3Npb25JZCIsImJyb3dzZXJOYW1lIiwiRXJyb3IiLCJyZXF1ZXN0Iiwib3B0cyIsImpzb24iLCJkYXRhIiwiaGVhZGVycyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsU0FBU0EsVUFBVCxDQUFxQkMsR0FBckIsRUFBMEJDLE1BQTFCLEVBQWtDO0FBQ2hDLE1BQUksWUFBWUMsSUFBWixDQUFpQkYsR0FBakIsQ0FBSixFQUEyQjtBQUN6QixXQUFPLENBQUMsR0FBRCxFQUFNO0FBQUNHLE1BQUFBLE1BQU0sRUFBRSxDQUFUO0FBQVlDLE1BQUFBLEtBQUssRUFBRTtBQUFDQyxRQUFBQSxHQUFHLEVBQUU7QUFBTjtBQUFuQixLQUFOLENBQVA7QUFDRDs7QUFDRCxNQUFJLHdCQUF3QkgsSUFBeEIsQ0FBNkJGLEdBQTdCLENBQUosRUFBdUM7QUFDckMsV0FBTyxDQUFDLEdBQUQsRUFBTTtBQUFDRyxNQUFBQSxNQUFNLEVBQUUsRUFBVDtBQUFhQyxNQUFBQSxLQUFLLEVBQUU7QUFBQ0UsUUFBQUEsT0FBTyxFQUFFO0FBQVY7QUFBcEIsS0FBTixDQUFQO0FBQ0Q7O0FBQ0QsTUFBSSx3QkFBd0JKLElBQXhCLENBQTZCRixHQUE3QixDQUFKLEVBQXVDO0FBQ3JDLFdBQU8sQ0FBQyxHQUFELEVBQU07QUFBQ0csTUFBQUEsTUFBTSxFQUFFLEVBQVQ7QUFBYUMsTUFBQUEsS0FBSyxFQUFFO0FBQUNFLFFBQUFBLE9BQU8sRUFBRTtBQUFWO0FBQXBCLEtBQU4sQ0FBUDtBQUNEOztBQUNELE1BQUkseUJBQXlCSixJQUF6QixDQUE4QkYsR0FBOUIsQ0FBSixFQUF3QztBQUN0QyxXQUFPLENBQUMsR0FBRCxFQUFNO0FBQUNHLE1BQUFBLE1BQU0sRUFBRSxDQUFUO0FBQVlJLE1BQUFBLFNBQVMsRUFBRSxnQkFBdkI7QUFBeUNILE1BQUFBLEtBQUssRUFBRTtBQUFoRCxLQUFOLENBQVA7QUFDRDs7QUFDRCxNQUFJLGFBQWFGLElBQWIsQ0FBa0JGLEdBQWxCLEtBQTBCQyxNQUFNLEtBQUssTUFBekMsRUFBaUQ7QUFDL0MsV0FBTyxDQUFDLEdBQUQsRUFBTTtBQUFDRSxNQUFBQSxNQUFNLEVBQUUsQ0FBVDtBQUFZSSxNQUFBQSxTQUFTLEVBQUUsS0FBdkI7QUFBOEJILE1BQUFBLEtBQUssRUFBRTtBQUFDSSxRQUFBQSxXQUFXLEVBQUU7QUFBZDtBQUFyQyxLQUFOLENBQVA7QUFDRDs7QUFDRCxNQUFJLGNBQWNOLElBQWQsQ0FBbUJGLEdBQW5CLENBQUosRUFBNkI7QUFDM0IsV0FBTyxDQUFDLEdBQUQsRUFBTTtBQUFDRyxNQUFBQSxNQUFNLEVBQUUsQ0FBVDtBQUFZQyxNQUFBQSxLQUFLLEVBQUU7QUFBQ0UsUUFBQUEsT0FBTyxFQUFFO0FBQVY7QUFBbkIsS0FBTixDQUFQO0FBQ0Q7O0FBQ0QsUUFBTSxJQUFJRyxLQUFKLENBQVUsc0JBQXNCVCxHQUFoQyxDQUFOO0FBQ0Q7O0FBRUQsZUFBZVUsT0FBZixDQUF3QkMsSUFBeEIsRUFBOEI7QUFDNUIsUUFBTTtBQUFDWCxJQUFBQSxHQUFEO0FBQU1DLElBQUFBLE1BQU47QUFBY1csSUFBQUE7QUFBZCxNQUFzQkQsSUFBNUI7O0FBQ0EsTUFBSSxVQUFVVCxJQUFWLENBQWVGLEdBQWYsQ0FBSixFQUF5QjtBQUN2QixVQUFNLElBQUlTLEtBQUosQ0FBVSxTQUFWLENBQU47QUFDRDs7QUFFRCxRQUFNLENBQUNOLE1BQUQsRUFBU1UsSUFBVCxJQUFpQmQsVUFBVSxDQUFDQyxHQUFELEVBQU1DLE1BQU4sRUFBY1csSUFBZCxDQUFqQztBQUNBLFNBQU87QUFDTFQsSUFBQUEsTUFESztBQUVMVyxJQUFBQSxPQUFPLEVBQUU7QUFBQyxzQkFBZ0I7QUFBakIsS0FGSjtBQUdMRCxJQUFBQTtBQUhLLEdBQVA7QUFLRDs7ZUFFY0gsTyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIHJlc0ZpeHR1cmUgKHVybCwgbWV0aG9kKSB7XG4gIGlmICgvXFwvc3RhdHVzJC8udGVzdCh1cmwpKSB7XG4gICAgcmV0dXJuIFsyMDAsIHtzdGF0dXM6IDAsIHZhbHVlOiB7Zm9vOiAnYmFyJ319XTtcbiAgfVxuICBpZiAoL1xcL2VsZW1lbnRcXC9iYWRcXC90ZXh0JC8udGVzdCh1cmwpKSB7XG4gICAgcmV0dXJuIFs1MDAsIHtzdGF0dXM6IDExLCB2YWx1ZToge21lc3NhZ2U6ICdJbnZpc2libGUgZWxlbWVudCd9fV07XG4gIH1cbiAgaWYgKC9cXC9lbGVtZW50XFwvMjAwXFwvdGV4dCQvLnRlc3QodXJsKSkge1xuICAgIHJldHVybiBbMjAwLCB7c3RhdHVzOiAxMSwgdmFsdWU6IHttZXNzYWdlOiAnSW52aXNpYmxlIGVsZW1lbnQnfX1dO1xuICB9XG4gIGlmICgvXFwvZWxlbWVudFxcLzIwMFxcL3ZhbHVlJC8udGVzdCh1cmwpKSB7XG4gICAgcmV0dXJuIFsyMDAsIHtzdGF0dXM6IDAsIHNlc3Npb25JZDogJ2lubmVyc2Vzc2lvbmlkJywgdmFsdWU6ICdmb29iYXInfV07XG4gIH1cbiAgaWYgKC9cXC9zZXNzaW9uJC8udGVzdCh1cmwpICYmIG1ldGhvZCA9PT0gJ1BPU1QnKSB7XG4gICAgcmV0dXJuIFsyMDAsIHtzdGF0dXM6IDAsIHNlc3Npb25JZDogJzEyMycsIHZhbHVlOiB7YnJvd3Nlck5hbWU6ICdib28nfX1dO1xuICB9XG4gIGlmICgvXFwvbm9jaHJvbWUkLy50ZXN0KHVybCkpIHtcbiAgICByZXR1cm4gWzEwMCwge3N0YXR1czogMCwgdmFsdWU6IHttZXNzYWdlOiAnY2hyb21lIG5vdCByZWFjaGFibGUnfX1dO1xuICB9XG4gIHRocm93IG5ldyBFcnJvcihcIkNhbid0IGhhbmRsZSB1cmwgXCIgKyB1cmwpO1xufVxuXG5hc3luYyBmdW5jdGlvbiByZXF1ZXN0IChvcHRzKSB7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgcmVxdWlyZS1hd2FpdFxuICBjb25zdCB7dXJsLCBtZXRob2QsIGpzb259ID0gb3B0cztcbiAgaWYgKC9iYWR1cmwkLy50ZXN0KHVybCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ25vd29ya3knKTtcbiAgfVxuXG4gIGNvbnN0IFtzdGF0dXMsIGRhdGFdID0gcmVzRml4dHVyZSh1cmwsIG1ldGhvZCwganNvbik7XG4gIHJldHVybiB7XG4gICAgc3RhdHVzLFxuICAgIGhlYWRlcnM6IHsnY29udGVudC10eXBlJzogJ2FwcGxpY2F0aW9uL2pzb247IGNoYXJzZXQ9dXRmLTgnfSxcbiAgICBkYXRhLFxuICB9O1xufVxuXG5leHBvcnQgZGVmYXVsdCByZXF1ZXN0O1xuIl0sImZpbGUiOiJ0ZXN0L2pzb253cC1wcm94eS9tb2NrLXJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiLi4vLi4vLi4ifQ==
|