@appium/base-driver 8.5.7 → 8.7.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/build/lib/basedriver/capabilities.js +2 -2
- package/build/lib/basedriver/commands/execute.d.ts +11 -0
- package/build/lib/basedriver/commands/execute.d.ts.map +1 -0
- package/build/lib/basedriver/commands/execute.js +62 -0
- package/build/lib/basedriver/commands/index.d.ts +1 -1
- package/build/lib/basedriver/commands/index.d.ts.map +1 -1
- package/build/lib/basedriver/commands/index.js +5 -2
- package/build/lib/basedriver/commands/log.js +2 -4
- package/build/lib/basedriver/core.d.ts +11 -0
- package/build/lib/basedriver/core.d.ts.map +1 -1
- package/build/lib/basedriver/core.js +6 -1
- package/build/lib/basedriver/helpers.js +2 -2
- package/build/lib/express/server.d.ts +70 -7
- package/build/lib/express/server.d.ts.map +1 -1
- package/build/lib/express/server.js +19 -16
- package/build/lib/express/websocket.d.ts +12 -30
- package/build/lib/express/websocket.d.ts.map +1 -1
- package/build/lib/express/websocket.js +6 -4
- package/build/lib/index.d.ts +12 -180
- package/build/lib/index.d.ts.map +1 -1
- package/build/lib/index.js +107 -80
- package/build/lib/jsonwp-proxy/protocol-converter.js +2 -4
- package/build/lib/jsonwp-proxy/proxy.js +3 -7
- package/build/lib/protocol/index.d.ts +3 -1
- package/build/lib/protocol/index.js +13 -1
- package/build/lib/protocol/protocol.d.ts +8 -4
- package/build/lib/protocol/protocol.d.ts.map +1 -1
- package/build/lib/protocol/protocol.js +7 -7
- package/build/lib/protocol/routes.js +2 -6
- package/build/tsconfig.tsbuildinfo +1 -1
- package/lib/basedriver/commands/execute.js +65 -0
- package/lib/basedriver/commands/index.js +3 -1
- package/lib/basedriver/core.js +15 -0
- package/lib/express/server.js +126 -36
- package/lib/express/websocket.js +13 -11
- package/lib/index.js +19 -61
- package/lib/protocol/index.js +4 -0
- package/lib/protocol/protocol.js +10 -3
- package/package.json +17 -15
- package/build/test/basedriver/README.md +0 -5
- package/build/test/basedriver/driver-e2e-tests.js +0 -413
- package/build/test/basedriver/driver-tests.js +0 -572
- package/build/test/basedriver/index.js +0 -26
- package/build/test/e2e/basedriver/driver.e2e.spec.js +0 -15
- package/build/test/e2e/basedriver/helpers.e2e.spec.js +0 -192
- package/build/test/e2e/basedriver/websockets.e2e.spec.js +0 -87
- package/build/test/e2e/express/server.e2e.spec.js +0 -159
- package/build/test/e2e/jsonwp-proxy/proxy.e2e.spec.js +0 -59
- package/build/test/e2e/protocol/fake-driver.js +0 -163
- package/build/test/e2e/protocol/helpers.js +0 -25
- package/build/test/e2e/protocol/protocol.e2e.spec.js +0 -1186
- package/build/test/helpers.js +0 -55
- package/build/test/unit/basedriver/capabilities.spec.js +0 -672
- package/build/test/unit/basedriver/capability.spec.js +0 -353
- package/build/test/unit/basedriver/commands/event.spec.js +0 -110
- package/build/test/unit/basedriver/commands/log.spec.js +0 -92
- package/build/test/unit/basedriver/device-settings.spec.js +0 -97
- package/build/test/unit/basedriver/driver.spec.js +0 -15
- package/build/test/unit/basedriver/helpers.spec.js +0 -151
- package/build/test/unit/basedriver/timeout.spec.js +0 -135
- package/build/test/unit/express/server.spec.js +0 -155
- package/build/test/unit/express/static.spec.js +0 -26
- package/build/test/unit/jsonwp-proxy/mock-request.js +0 -91
- package/build/test/unit/jsonwp-proxy/protocol-converter.spec.js +0 -171
- package/build/test/unit/jsonwp-proxy/proxy.spec.js +0 -292
- package/build/test/unit/jsonwp-proxy/url.spec.js +0 -165
- package/build/test/unit/jsonwp-status/status.spec.js +0 -34
- package/build/test/unit/protocol/errors.spec.js +0 -390
- package/build/test/unit/protocol/routes.spec.js +0 -80
- package/build/test/unit/protocol/validator.spec.js +0 -149
- package/test/basedriver/README.md +0 -5
- package/test/basedriver/driver-e2e-tests.js +0 -386
- package/test/basedriver/driver-tests.js +0 -624
- package/test/basedriver/index.js +0 -6
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _support = require("@appium/support");
|
|
8
|
-
|
|
9
|
-
var _sinon = _interopRequireDefault(require("sinon"));
|
|
10
|
-
|
|
11
|
-
var _deviceSettings = require("../../../lib/basedriver/device-settings");
|
|
12
|
-
|
|
13
|
-
var _errors = require("../../../lib/protocol/errors");
|
|
14
|
-
|
|
15
|
-
const {
|
|
16
|
-
expect
|
|
17
|
-
} = chai;
|
|
18
|
-
describe('DeviceSettings', function () {
|
|
19
|
-
let sandbox;
|
|
20
|
-
beforeEach(function () {
|
|
21
|
-
sandbox = _sinon.default.createSandbox();
|
|
22
|
-
});
|
|
23
|
-
afterEach(function () {
|
|
24
|
-
sandbox.restore();
|
|
25
|
-
});
|
|
26
|
-
describe('constructor', function () {
|
|
27
|
-
describe('when no parameteres are provided to the constructor', function () {
|
|
28
|
-
it('should not throw', function () {
|
|
29
|
-
expect(() => new _deviceSettings.DeviceSettings()).not.to.throw();
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
describe('instance method', function () {
|
|
34
|
-
describe('getSettings()', function () {
|
|
35
|
-
it('should return a clone of the internal settings object', function () {
|
|
36
|
-
const settings = {
|
|
37
|
-
foo: 'bar',
|
|
38
|
-
bar: 'foo'
|
|
39
|
-
};
|
|
40
|
-
const deviceSettings = new _deviceSettings.DeviceSettings(settings);
|
|
41
|
-
expect(deviceSettings.getSettings()).to.eql(settings);
|
|
42
|
-
});
|
|
43
|
-
});
|
|
44
|
-
describe('update()', function () {
|
|
45
|
-
describe('when no parameters are provided', function () {
|
|
46
|
-
it('should reject with an InvalidArgumentError', async function () {
|
|
47
|
-
const deviceSettings = new _deviceSettings.DeviceSettings();
|
|
48
|
-
await expect(deviceSettings.update()).to.be.rejectedWith(_errors.InvalidArgumentError, /with valid JSON/i);
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
describe('when a non-plain-object `newSettings` param is provided', function () {
|
|
52
|
-
it('should reject with an InvalidArgumentError', async function () {
|
|
53
|
-
const deviceSettings = new _deviceSettings.DeviceSettings();
|
|
54
|
-
await expect(deviceSettings.update(null)).to.be.rejectedWith(_errors.InvalidArgumentError, /with valid JSON/i);
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
describe('when the size of the `newSettings` param exceeds `MAX_SETTINGS_SIZE`', function () {
|
|
58
|
-
beforeEach(function () {
|
|
59
|
-
sandbox.stub(_support.node, 'getObjectSize').returns(_deviceSettings.MAX_SETTINGS_SIZE + 1);
|
|
60
|
-
});
|
|
61
|
-
it('should reject with an InvalidArgumentError', async function () {
|
|
62
|
-
const deviceSettings = new _deviceSettings.DeviceSettings();
|
|
63
|
-
await expect(deviceSettings.update({
|
|
64
|
-
stuff: 'things'
|
|
65
|
-
})).to.be.rejectedWith(_errors.InvalidArgumentError, /object size exceeds/i);
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
describe('when the `newSettings` param is valid', function () {
|
|
69
|
-
let onSettingsUpdate;
|
|
70
|
-
beforeEach(function () {
|
|
71
|
-
onSettingsUpdate = sandbox.stub();
|
|
72
|
-
});
|
|
73
|
-
describe('when the new settings do not differ', function () {
|
|
74
|
-
it('should not call the `_onSettingsUpdate` listener', async function () {
|
|
75
|
-
const deviceSettings = new _deviceSettings.DeviceSettings({
|
|
76
|
-
stuff: 'things'
|
|
77
|
-
}, onSettingsUpdate);
|
|
78
|
-
await deviceSettings.update({
|
|
79
|
-
stuff: 'things'
|
|
80
|
-
});
|
|
81
|
-
expect(onSettingsUpdate).not.to.have.been.called;
|
|
82
|
-
});
|
|
83
|
-
});
|
|
84
|
-
describe('when the new settings differ', function () {
|
|
85
|
-
it('should call the `_onSettingsUpdate` listener', async function () {
|
|
86
|
-
const deviceSettings = new _deviceSettings.DeviceSettings({}, onSettingsUpdate);
|
|
87
|
-
await deviceSettings.update({
|
|
88
|
-
stuff: 'things'
|
|
89
|
-
});
|
|
90
|
-
expect(onSettingsUpdate).to.have.been.calledOnceWithExactly('stuff', 'things', undefined);
|
|
91
|
-
});
|
|
92
|
-
});
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["expect","chai","describe","sandbox","beforeEach","sinon","createSandbox","afterEach","restore","it","DeviceSettings","not","to","throw","settings","foo","bar","deviceSettings","getSettings","eql","update","be","rejectedWith","InvalidArgumentError","stub","node","returns","MAX_SETTINGS_SIZE","stuff","onSettingsUpdate","have","been","called","calledOnceWithExactly","undefined"],"sources":["../../../../test/unit/basedriver/device-settings.spec.js"],"sourcesContent":["import {node} from '@appium/support';\nimport sinon from 'sinon';\nimport {DeviceSettings, MAX_SETTINGS_SIZE} from '../../../lib/basedriver/device-settings';\nimport {InvalidArgumentError} from '../../../lib/protocol/errors';\n\nconst {expect} = chai;\n\ndescribe('DeviceSettings', function () {\n  let sandbox;\n\n  beforeEach(function () {\n    sandbox = sinon.createSandbox();\n  });\n\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  describe('constructor', function () {\n    describe('when no parameteres are provided to the constructor', function () {\n      it('should not throw', function () {\n        expect(() => new DeviceSettings()).not.to.throw();\n      });\n    });\n  });\n\n  describe('instance method', function () {\n    describe('getSettings()', function () {\n      it('should return a clone of the internal settings object', function () {\n        const settings = {\n          foo: 'bar',\n          bar: 'foo',\n        };\n        const deviceSettings = new DeviceSettings(settings);\n        expect(deviceSettings.getSettings()).to.eql(settings);\n      });\n    });\n\n    describe('update()', function () {\n      describe('when no parameters are provided', function () {\n        it('should reject with an InvalidArgumentError', async function () {\n          const deviceSettings = new DeviceSettings();\n          await expect(deviceSettings.update()).to.be.rejectedWith(\n            InvalidArgumentError,\n            /with valid JSON/i\n          );\n        });\n      });\n\n      describe('when a non-plain-object `newSettings` param is provided', function () {\n        it('should reject with an InvalidArgumentError', async function () {\n          const deviceSettings = new DeviceSettings();\n          await expect(deviceSettings.update(null)).to.be.rejectedWith(\n            InvalidArgumentError,\n            /with valid JSON/i\n          );\n        });\n      });\n\n      describe('when the size of the `newSettings` param exceeds `MAX_SETTINGS_SIZE`', function () {\n        beforeEach(function () {\n          // this is easier than sending a 21MB object\n          sandbox.stub(node, 'getObjectSize').returns(MAX_SETTINGS_SIZE + 1);\n        });\n\n        it('should reject with an InvalidArgumentError', async function () {\n          const deviceSettings = new DeviceSettings();\n          await expect(deviceSettings.update({stuff: 'things'})).to.be.rejectedWith(\n            InvalidArgumentError,\n            /object size exceeds/i\n          );\n        });\n      });\n\n      describe('when the `newSettings` param is valid', function () {\n        let onSettingsUpdate;\n\n        beforeEach(function () {\n          onSettingsUpdate = sandbox.stub();\n        });\n\n        describe('when the new settings do not differ', function () {\n          it('should not call the `_onSettingsUpdate` listener', async function () {\n            const deviceSettings = new DeviceSettings({stuff: 'things'}, onSettingsUpdate);\n            await deviceSettings.update({stuff: 'things'});\n            expect(onSettingsUpdate).not.to.have.been.called;\n          });\n        });\n\n        describe('when the new settings differ', function () {\n          it('should call the `_onSettingsUpdate` listener', async function () {\n            const deviceSettings = new DeviceSettings({}, onSettingsUpdate);\n            await deviceSettings.update({stuff: 'things'});\n            expect(onSettingsUpdate).to.have.been.calledOnceWithExactly(\n              'stuff',\n              'things',\n              undefined\n            );\n          });\n        });\n      });\n    });\n  });\n});\n"],"mappings":"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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _lib = _interopRequireDefault(require("../../../lib"));
|
|
8
|
-
|
|
9
|
-
var _basedriver = require("../../basedriver");
|
|
10
|
-
|
|
11
|
-
(0, _basedriver.baseDriverUnitTests)(_lib.default, {
|
|
12
|
-
platformName: 'iOS',
|
|
13
|
-
'appium:deviceName': 'Delorean'
|
|
14
|
-
});
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJiYXNlRHJpdmVyVW5pdFRlc3RzIiwiQmFzZURyaXZlciIsInBsYXRmb3JtTmFtZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Rlc3QvdW5pdC9iYXNlZHJpdmVyL2RyaXZlci5zcGVjLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIHRyYW5zcGlsZTptb2NoYVxuXG5pbXBvcnQgQmFzZURyaXZlciBmcm9tICcuLi8uLi8uLi9saWInO1xuaW1wb3J0IHtiYXNlRHJpdmVyVW5pdFRlc3RzfSBmcm9tICcuLi8uLi9iYXNlZHJpdmVyJztcblxuYmFzZURyaXZlclVuaXRUZXN0cyhCYXNlRHJpdmVyLCB7XG4gIHBsYXRmb3JtTmFtZTogJ2lPUycsXG4gICdhcHBpdW06ZGV2aWNlTmFtZSc6ICdEZWxvcmVhbicsXG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBRUE7O0FBQ0E7O0FBRUEsSUFBQUEsK0JBQUEsRUFBb0JDLFlBQXBCLEVBQWdDO0VBQzlCQyxZQUFZLEVBQUUsS0FEZ0I7RUFFOUIscUJBQXFCO0FBRlMsQ0FBaEMifQ==
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _support = require("@appium/support");
|
|
8
|
-
|
|
9
|
-
var _helpers = require("../../../lib/basedriver/helpers");
|
|
10
|
-
|
|
11
|
-
var _sinon = _interopRequireDefault(require("sinon"));
|
|
12
|
-
|
|
13
|
-
describe('helpers', function () {
|
|
14
|
-
describe('#isPackageOrBundle', function () {
|
|
15
|
-
it('should accept packages and bundles', function () {
|
|
16
|
-
(0, _helpers.isPackageOrBundle)('io.appium.testapp').should.be.true;
|
|
17
|
-
});
|
|
18
|
-
it('should not accept non-packages or non-bundles', function () {
|
|
19
|
-
(0, _helpers.isPackageOrBundle)('foo').should.be.false;
|
|
20
|
-
(0, _helpers.isPackageOrBundle)('/path/to/an.app').should.be.false;
|
|
21
|
-
(0, _helpers.isPackageOrBundle)('/path/to/an.apk').should.be.false;
|
|
22
|
-
});
|
|
23
|
-
});
|
|
24
|
-
describe('#duplicateKeys', function () {
|
|
25
|
-
it('should translate key in an object', function () {
|
|
26
|
-
(0, _helpers.duplicateKeys)({
|
|
27
|
-
foo: 'hello world'
|
|
28
|
-
}, 'foo', 'bar').should.eql({
|
|
29
|
-
foo: 'hello world',
|
|
30
|
-
bar: 'hello world'
|
|
31
|
-
});
|
|
32
|
-
});
|
|
33
|
-
it('should translate key in an object within an object', function () {
|
|
34
|
-
(0, _helpers.duplicateKeys)({
|
|
35
|
-
key: {
|
|
36
|
-
foo: 'hello world'
|
|
37
|
-
}
|
|
38
|
-
}, 'foo', 'bar').should.eql({
|
|
39
|
-
key: {
|
|
40
|
-
foo: 'hello world',
|
|
41
|
-
bar: 'hello world'
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
it('should translate key in an object with an array', function () {
|
|
46
|
-
(0, _helpers.duplicateKeys)([{
|
|
47
|
-
key: {
|
|
48
|
-
foo: 'hello world'
|
|
49
|
-
}
|
|
50
|
-
}, {
|
|
51
|
-
foo: 'HELLO WORLD'
|
|
52
|
-
}], 'foo', 'bar').should.eql([{
|
|
53
|
-
key: {
|
|
54
|
-
foo: 'hello world',
|
|
55
|
-
bar: 'hello world'
|
|
56
|
-
}
|
|
57
|
-
}, {
|
|
58
|
-
foo: 'HELLO WORLD',
|
|
59
|
-
bar: 'HELLO WORLD'
|
|
60
|
-
}]);
|
|
61
|
-
});
|
|
62
|
-
it('should duplicate both keys', function () {
|
|
63
|
-
(0, _helpers.duplicateKeys)({
|
|
64
|
-
keyOne: {
|
|
65
|
-
foo: 'hello world'
|
|
66
|
-
},
|
|
67
|
-
keyTwo: {
|
|
68
|
-
bar: 'HELLO WORLD'
|
|
69
|
-
}
|
|
70
|
-
}, 'foo', 'bar').should.eql({
|
|
71
|
-
keyOne: {
|
|
72
|
-
foo: 'hello world',
|
|
73
|
-
bar: 'hello world'
|
|
74
|
-
},
|
|
75
|
-
keyTwo: {
|
|
76
|
-
bar: 'HELLO WORLD',
|
|
77
|
-
foo: 'HELLO WORLD'
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
it('should not do anything to primitives', function () {
|
|
82
|
-
[0, 1, -1, true, false, null, undefined, '', 'Hello World'].forEach(item => {
|
|
83
|
-
should.equal((0, _helpers.duplicateKeys)(item), item);
|
|
84
|
-
});
|
|
85
|
-
});
|
|
86
|
-
it('should rename keys on big complex objects', function () {
|
|
87
|
-
const input = [{
|
|
88
|
-
foo: 'bar'
|
|
89
|
-
}, {
|
|
90
|
-
hello: {
|
|
91
|
-
world: {
|
|
92
|
-
foo: 'BAR'
|
|
93
|
-
}
|
|
94
|
-
},
|
|
95
|
-
foo: 'bahr'
|
|
96
|
-
}, 'foo', null, 0];
|
|
97
|
-
const expectedOutput = [{
|
|
98
|
-
foo: 'bar',
|
|
99
|
-
FOO: 'bar'
|
|
100
|
-
}, {
|
|
101
|
-
hello: {
|
|
102
|
-
world: {
|
|
103
|
-
foo: 'BAR',
|
|
104
|
-
FOO: 'BAR'
|
|
105
|
-
}
|
|
106
|
-
},
|
|
107
|
-
foo: 'bahr',
|
|
108
|
-
FOO: 'bahr'
|
|
109
|
-
}, 'foo', null, 0];
|
|
110
|
-
(0, _helpers.duplicateKeys)(input, 'foo', 'FOO').should.deep.equal(expectedOutput);
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
describe('#configureApp', function () {
|
|
114
|
-
let sandbox;
|
|
115
|
-
beforeEach(function () {
|
|
116
|
-
sandbox = _sinon.default.createSandbox();
|
|
117
|
-
sandbox.stub(_support.zip, 'extractAllTo').resolves();
|
|
118
|
-
sandbox.stub(_support.zip, 'assertValidZip').resolves();
|
|
119
|
-
sandbox.stub(_support.fs, 'mv').resolves();
|
|
120
|
-
sandbox.stub(_support.fs, 'stat').resolves({
|
|
121
|
-
isFile: () => true,
|
|
122
|
-
isDirectory: () => false
|
|
123
|
-
});
|
|
124
|
-
sandbox.stub(_support.fs, 'exists').resolves(true);
|
|
125
|
-
sandbox.stub(_support.fs, 'hash').resolves('0xDEADBEEF');
|
|
126
|
-
sandbox.stub(_support.fs, 'glob').resolves(['/path/to/an.apk']);
|
|
127
|
-
sandbox.stub(_support.fs, 'rimraf').resolves();
|
|
128
|
-
sandbox.stub(_support.tempDir, 'openDir').resolves('/some/dir');
|
|
129
|
-
});
|
|
130
|
-
afterEach(function () {
|
|
131
|
-
sandbox.restore();
|
|
132
|
-
});
|
|
133
|
-
it('should pass "useSystemUnzip" flag through to @appium/support', async function () {
|
|
134
|
-
await (0, _helpers.configureApp)('/path/to/an.apk.zip', '.apk');
|
|
135
|
-
_support.zip.extractAllTo.getCall(0).lastArg.useSystemUnzip.should.be.true;
|
|
136
|
-
});
|
|
137
|
-
});
|
|
138
|
-
});
|
|
139
|
-
describe('parseCapsArray', function () {
|
|
140
|
-
it('should parse string into array', function () {
|
|
141
|
-
(0, _helpers.parseCapsArray)('/tmp/my/app.zip').should.eql(['/tmp/my/app.zip']);
|
|
142
|
-
});
|
|
143
|
-
it('should parse array as string into array', function () {
|
|
144
|
-
(0, _helpers.parseCapsArray)('["/tmp/my/app.zip"]').should.eql(['/tmp/my/app.zip']);
|
|
145
|
-
(0, _helpers.parseCapsArray)('["/tmp/my/app.zip","/tmp/my/app2.zip"]').should.eql(['/tmp/my/app.zip', '/tmp/my/app2.zip']);
|
|
146
|
-
});
|
|
147
|
-
it('should return an array without change', function () {
|
|
148
|
-
(0, _helpers.parseCapsArray)(['a', 'b']).should.eql(['a', 'b']);
|
|
149
|
-
});
|
|
150
|
-
});
|
|
151
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["describe","it","isPackageOrBundle","should","be","true","false","duplicateKeys","foo","eql","bar","key","keyOne","keyTwo","undefined","forEach","item","equal","input","hello","world","expectedOutput","FOO","deep","sandbox","beforeEach","sinon","createSandbox","stub","zip","resolves","fs","isFile","isDirectory","tempDir","afterEach","restore","configureApp","extractAllTo","getCall","lastArg","useSystemUnzip","parseCapsArray"],"sources":["../../../../test/unit/basedriver/helpers.spec.js"],"sourcesContent":["import {zip, fs, tempDir} from '@appium/support';\nimport {\n  configureApp,\n  isPackageOrBundle,\n  duplicateKeys,\n  parseCapsArray,\n} from '../../../lib/basedriver/helpers';\nimport sinon from 'sinon';\n\ndescribe('helpers', function () {\n  describe('#isPackageOrBundle', function () {\n    it('should accept packages and bundles', function () {\n      isPackageOrBundle('io.appium.testapp').should.be.true;\n    });\n    it('should not accept non-packages or non-bundles', function () {\n      isPackageOrBundle('foo').should.be.false;\n      isPackageOrBundle('/path/to/an.app').should.be.false;\n      isPackageOrBundle('/path/to/an.apk').should.be.false;\n    });\n  });\n\n  describe('#duplicateKeys', function () {\n    it('should translate key in an object', function () {\n      duplicateKeys({foo: 'hello world'}, 'foo', 'bar').should.eql({\n        foo: 'hello world',\n        bar: 'hello world',\n      });\n    });\n    it('should translate key in an object within an object', function () {\n      duplicateKeys({key: {foo: 'hello world'}}, 'foo', 'bar').should.eql({\n        key: {foo: 'hello world', bar: 'hello world'},\n      });\n    });\n    it('should translate key in an object with an array', function () {\n      duplicateKeys([{key: {foo: 'hello world'}}, {foo: 'HELLO WORLD'}], 'foo', 'bar').should.eql([\n        {key: {foo: 'hello world', bar: 'hello world'}},\n        {foo: 'HELLO WORLD', bar: 'HELLO WORLD'},\n      ]);\n    });\n    it('should duplicate both keys', function () {\n      duplicateKeys(\n        {\n          keyOne: {\n            foo: 'hello world',\n          },\n          keyTwo: {\n            bar: 'HELLO WORLD',\n          },\n        },\n        'foo',\n        'bar'\n      ).should.eql({\n        keyOne: {\n          foo: 'hello world',\n          bar: 'hello world',\n        },\n        keyTwo: {\n          bar: 'HELLO WORLD',\n          foo: 'HELLO WORLD',\n        },\n      });\n    });\n    it('should not do anything to primitives', function () {\n      [0, 1, -1, true, false, null, undefined, '', 'Hello World'].forEach((item) => {\n        should.equal(duplicateKeys(item), item);\n      });\n    });\n    it('should rename keys on big complex objects', function () {\n      const input = [\n        {foo: 'bar'},\n        {\n          hello: {\n            world: {\n              foo: 'BAR',\n            },\n          },\n          foo: 'bahr',\n        },\n        'foo',\n        null,\n        0,\n      ];\n      const expectedOutput = [\n        {foo: 'bar', FOO: 'bar'},\n        {\n          hello: {\n            world: {\n              foo: 'BAR',\n              FOO: 'BAR',\n            },\n          },\n          foo: 'bahr',\n          FOO: 'bahr',\n        },\n        'foo',\n        null,\n        0,\n      ];\n      duplicateKeys(input, 'foo', 'FOO').should.deep.equal(expectedOutput);\n    });\n  });\n\n  describe('#configureApp', function () {\n    let sandbox;\n\n    beforeEach(function () {\n      sandbox = sinon.createSandbox();\n      sandbox.stub(zip, 'extractAllTo').resolves();\n      sandbox.stub(zip, 'assertValidZip').resolves();\n      sandbox.stub(fs, 'mv').resolves();\n      sandbox.stub(fs, 'stat').resolves({\n        isFile: () => true,\n        isDirectory: () => false,\n      });\n      sandbox.stub(fs, 'exists').resolves(true);\n      sandbox.stub(fs, 'hash').resolves('0xDEADBEEF');\n      sandbox.stub(fs, 'glob').resolves(['/path/to/an.apk']);\n      sandbox.stub(fs, 'rimraf').resolves();\n      sandbox.stub(tempDir, 'openDir').resolves('/some/dir');\n    });\n\n    afterEach(function () {\n      sandbox.restore();\n    });\n\n    it('should pass \"useSystemUnzip\" flag through to @appium/support', async function () {\n      await configureApp('/path/to/an.apk.zip', '.apk');\n      zip.extractAllTo.getCall(0).lastArg.useSystemUnzip.should.be.true;\n    });\n  });\n});\n\ndescribe('parseCapsArray', function () {\n  it('should parse string into array', function () {\n    parseCapsArray('/tmp/my/app.zip').should.eql(['/tmp/my/app.zip']);\n  });\n  it('should parse array as string into array', function () {\n    parseCapsArray('[\"/tmp/my/app.zip\"]').should.eql(['/tmp/my/app.zip']);\n    parseCapsArray('[\"/tmp/my/app.zip\",\"/tmp/my/app2.zip\"]').should.eql([\n      '/tmp/my/app.zip',\n      '/tmp/my/app2.zip',\n    ]);\n  });\n  it('should return an array without change', function () {\n    parseCapsArray(['a', 'b']).should.eql(['a', 'b']);\n  });\n});\n"],"mappings":"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"}
|
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _lib = _interopRequireDefault(require("../../../lib"));
|
|
8
|
-
|
|
9
|
-
var _sinon = require("sinon");
|
|
10
|
-
|
|
11
|
-
describe('timeout', function () {
|
|
12
|
-
let driver = new _lib.default();
|
|
13
|
-
let implicitWaitSpy;
|
|
14
|
-
let sandbox;
|
|
15
|
-
beforeEach(function () {
|
|
16
|
-
sandbox = (0, _sinon.createSandbox)();
|
|
17
|
-
driver.implicitWaitMs = 0;
|
|
18
|
-
implicitWaitSpy = sandbox.spy(driver, 'setImplicitWait');
|
|
19
|
-
});
|
|
20
|
-
afterEach(function () {
|
|
21
|
-
sandbox.restore();
|
|
22
|
-
});
|
|
23
|
-
describe('timeouts', function () {
|
|
24
|
-
describe('errors', function () {
|
|
25
|
-
it('should throw an error if something random is sent', async function () {
|
|
26
|
-
await driver.timeouts('random timeout', 'howdy').should.eventually.be.rejected;
|
|
27
|
-
});
|
|
28
|
-
it('should throw an error if timeout is negative', async function () {
|
|
29
|
-
await driver.timeouts('random timeout', -42).should.eventually.be.rejected;
|
|
30
|
-
});
|
|
31
|
-
it('should throw an errors if timeout type is unknown', async function () {
|
|
32
|
-
await driver.timeouts('random timeout', 42).should.eventually.be.rejected;
|
|
33
|
-
});
|
|
34
|
-
it('should throw an error if something random is sent to scriptDuration', async function () {
|
|
35
|
-
await driver.timeouts(undefined, undefined, 123, undefined, undefined).should.eventually.be.rejected;
|
|
36
|
-
});
|
|
37
|
-
it('should throw an error if something random is sent to pageLoadDuration', async function () {
|
|
38
|
-
await driver.timeouts(undefined, undefined, undefined, 123, undefined).should.eventually.be.rejected;
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
describe('implicit wait', function () {
|
|
42
|
-
it('should call setImplicitWait when given an integer', async function () {
|
|
43
|
-
await driver.timeouts('implicit', 42);
|
|
44
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
45
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
46
|
-
driver.implicitWaitMs.should.eql(42);
|
|
47
|
-
});
|
|
48
|
-
it('should call setImplicitWait when given a string', async function () {
|
|
49
|
-
await driver.timeouts('implicit', '42');
|
|
50
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
51
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
52
|
-
driver.implicitWaitMs.should.eql(42);
|
|
53
|
-
});
|
|
54
|
-
it('should call setImplicitWait when given an integer to implicitDuration', async function () {
|
|
55
|
-
await driver.timeouts(undefined, undefined, undefined, undefined, 42);
|
|
56
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
57
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
58
|
-
driver.implicitWaitMs.should.eql(42);
|
|
59
|
-
});
|
|
60
|
-
it('should call setImplicitWait when given a string to implicitDuration', async function () {
|
|
61
|
-
await driver.timeouts(undefined, undefined, undefined, undefined, '42');
|
|
62
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
63
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
64
|
-
driver.implicitWaitMs.should.eql(42);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
});
|
|
68
|
-
describe('implicitWait', function () {
|
|
69
|
-
it('should call setImplicitWait when given an integer', async function () {
|
|
70
|
-
await driver.implicitWait(42);
|
|
71
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
72
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
73
|
-
driver.implicitWaitMs.should.eql(42);
|
|
74
|
-
});
|
|
75
|
-
it('should call setImplicitWait when given a string', async function () {
|
|
76
|
-
await driver.implicitWait('42');
|
|
77
|
-
implicitWaitSpy.calledOnce.should.be.true;
|
|
78
|
-
implicitWaitSpy.firstCall.args[0].should.equal(42);
|
|
79
|
-
driver.implicitWaitMs.should.eql(42);
|
|
80
|
-
});
|
|
81
|
-
it('should throw an error if something random is sent', async function () {
|
|
82
|
-
await driver.implicitWait('howdy').should.eventually.be.rejected;
|
|
83
|
-
});
|
|
84
|
-
it('should throw an error if timeout is negative', async function () {
|
|
85
|
-
await driver.implicitWait(-42).should.eventually.be.rejected;
|
|
86
|
-
});
|
|
87
|
-
});
|
|
88
|
-
describe('set implicit wait', function () {
|
|
89
|
-
it('should set the implicit wait with an integer', function () {
|
|
90
|
-
driver.setImplicitWait(42);
|
|
91
|
-
driver.implicitWaitMs.should.eql(42);
|
|
92
|
-
});
|
|
93
|
-
describe('with managed driver', function () {
|
|
94
|
-
let managedDriver1 = new _lib.default();
|
|
95
|
-
let managedDriver2 = new _lib.default();
|
|
96
|
-
before(function () {
|
|
97
|
-
driver.addManagedDriver(managedDriver1);
|
|
98
|
-
driver.addManagedDriver(managedDriver2);
|
|
99
|
-
});
|
|
100
|
-
after(function () {
|
|
101
|
-
driver.managedDrivers = [];
|
|
102
|
-
});
|
|
103
|
-
it('should set the implicit wait on managed drivers', function () {
|
|
104
|
-
driver.setImplicitWait(42);
|
|
105
|
-
driver.implicitWaitMs.should.eql(42);
|
|
106
|
-
managedDriver1.implicitWaitMs.should.eql(42);
|
|
107
|
-
managedDriver2.implicitWaitMs.should.eql(42);
|
|
108
|
-
});
|
|
109
|
-
});
|
|
110
|
-
});
|
|
111
|
-
describe('set new command timeout', function () {
|
|
112
|
-
it('should set the new command timeout with an integer', function () {
|
|
113
|
-
driver.setNewCommandTimeout(42);
|
|
114
|
-
driver.newCommandTimeoutMs.should.eql(42);
|
|
115
|
-
});
|
|
116
|
-
describe('with managed driver', function () {
|
|
117
|
-
let managedDriver1 = new _lib.default();
|
|
118
|
-
let managedDriver2 = new _lib.default();
|
|
119
|
-
before(function () {
|
|
120
|
-
driver.addManagedDriver(managedDriver1);
|
|
121
|
-
driver.addManagedDriver(managedDriver2);
|
|
122
|
-
});
|
|
123
|
-
after(function () {
|
|
124
|
-
driver.managedDrivers = [];
|
|
125
|
-
});
|
|
126
|
-
it('should set the new command timeout on managed drivers', function () {
|
|
127
|
-
driver.setNewCommandTimeout(42);
|
|
128
|
-
driver.newCommandTimeoutMs.should.eql(42);
|
|
129
|
-
managedDriver1.newCommandTimeoutMs.should.eql(42);
|
|
130
|
-
managedDriver2.newCommandTimeoutMs.should.eql(42);
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
});
|
|
134
|
-
});
|
|
135
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["describe","driver","BaseDriver","implicitWaitSpy","sandbox","beforeEach","createSandbox","implicitWaitMs","spy","afterEach","restore","it","timeouts","should","eventually","be","rejected","undefined","calledOnce","true","firstCall","args","equal","eql","implicitWait","setImplicitWait","managedDriver1","managedDriver2","before","addManagedDriver","after","managedDrivers","setNewCommandTimeout","newCommandTimeoutMs"],"sources":["../../../../test/unit/basedriver/timeout.spec.js"],"sourcesContent":["// @ts-check\n\nimport BaseDriver from '../../../lib';\nimport {createSandbox} from 'sinon';\n\ndescribe('timeout', function () {\n  let driver = new BaseDriver();\n  let implicitWaitSpy;\n  let sandbox;\n  beforeEach(function () {\n    sandbox = createSandbox();\n    driver.implicitWaitMs = 0;\n    implicitWaitSpy = sandbox.spy(driver, 'setImplicitWait');\n  });\n  afterEach(function () {\n    sandbox.restore();\n  });\n  // expected errors are for checks against runtime type failures. the types we're giving the function are not allowed\n  describe('timeouts', function () {\n    describe('errors', function () {\n      it('should throw an error if something random is sent', async function () {\n        await driver.timeouts('random timeout', 'howdy').should.eventually.be.rejected;\n      });\n      it('should throw an error if timeout is negative', async function () {\n        await driver.timeouts('random timeout', -42).should.eventually.be.rejected;\n      });\n      it('should throw an errors if timeout type is unknown', async function () {\n        await driver.timeouts('random timeout', 42).should.eventually.be.rejected;\n      });\n      it('should throw an error if something random is sent to scriptDuration', async function () {\n        await driver.timeouts(undefined, undefined, 123, undefined, undefined).should.eventually.be\n          .rejected;\n      });\n      it('should throw an error if something random is sent to pageLoadDuration', async function () {\n        await driver.timeouts(undefined, undefined, undefined, 123, undefined).should.eventually.be\n          .rejected;\n      });\n    });\n    describe('implicit wait', function () {\n      it('should call setImplicitWait when given an integer', async function () {\n        await driver.timeouts('implicit', 42);\n        implicitWaitSpy.calledOnce.should.be.true;\n        implicitWaitSpy.firstCall.args[0].should.equal(42);\n        driver.implicitWaitMs.should.eql(42);\n      });\n      it('should call setImplicitWait when given a string', async function () {\n        await driver.timeouts('implicit', '42');\n        implicitWaitSpy.calledOnce.should.be.true;\n        implicitWaitSpy.firstCall.args[0].should.equal(42);\n        driver.implicitWaitMs.should.eql(42);\n      });\n      it('should call setImplicitWait when given an integer to implicitDuration', async function () {\n        await driver.timeouts(undefined, undefined, undefined, undefined, 42);\n        implicitWaitSpy.calledOnce.should.be.true;\n        implicitWaitSpy.firstCall.args[0].should.equal(42);\n        driver.implicitWaitMs.should.eql(42);\n      });\n      it('should call setImplicitWait when given a string to implicitDuration', async function () {\n        await driver.timeouts(undefined, undefined, undefined, undefined, '42');\n        implicitWaitSpy.calledOnce.should.be.true;\n        implicitWaitSpy.firstCall.args[0].should.equal(42);\n        driver.implicitWaitMs.should.eql(42);\n      });\n    });\n  });\n  describe('implicitWait', function () {\n    it('should call setImplicitWait when given an integer', async function () {\n      await driver.implicitWait(42);\n      implicitWaitSpy.calledOnce.should.be.true;\n      implicitWaitSpy.firstCall.args[0].should.equal(42);\n      driver.implicitWaitMs.should.eql(42);\n    });\n    it('should call setImplicitWait when given a string', async function () {\n      await driver.implicitWait('42');\n      implicitWaitSpy.calledOnce.should.be.true;\n      implicitWaitSpy.firstCall.args[0].should.equal(42);\n      driver.implicitWaitMs.should.eql(42);\n    });\n    it('should throw an error if something random is sent', async function () {\n      await driver.implicitWait('howdy').should.eventually.be.rejected;\n    });\n    it('should throw an error if timeout is negative', async function () {\n      await driver.implicitWait(-42).should.eventually.be.rejected;\n    });\n  });\n\n  describe('set implicit wait', function () {\n    it('should set the implicit wait with an integer', function () {\n      driver.setImplicitWait(42);\n      driver.implicitWaitMs.should.eql(42);\n    });\n    describe('with managed driver', function () {\n      let managedDriver1 = new BaseDriver();\n      let managedDriver2 = new BaseDriver();\n      before(function () {\n        driver.addManagedDriver(managedDriver1);\n        driver.addManagedDriver(managedDriver2);\n      });\n      after(function () {\n        driver.managedDrivers = [];\n      });\n      it('should set the implicit wait on managed drivers', function () {\n        driver.setImplicitWait(42);\n        driver.implicitWaitMs.should.eql(42);\n        managedDriver1.implicitWaitMs.should.eql(42);\n        managedDriver2.implicitWaitMs.should.eql(42);\n      });\n    });\n  });\n  describe('set new command timeout', function () {\n    it('should set the new command timeout with an integer', function () {\n      driver.setNewCommandTimeout(42);\n      driver.newCommandTimeoutMs.should.eql(42);\n    });\n    describe('with managed driver', function () {\n      let managedDriver1 = new BaseDriver();\n      let managedDriver2 = new BaseDriver();\n      before(function () {\n        driver.addManagedDriver(managedDriver1);\n        driver.addManagedDriver(managedDriver2);\n      });\n      after(function () {\n        driver.managedDrivers = [];\n      });\n      it('should set the new command timeout on managed drivers', function () {\n        driver.setNewCommandTimeout(42);\n        driver.newCommandTimeoutMs.should.eql(42);\n        managedDriver1.newCommandTimeoutMs.should.eql(42);\n        managedDriver2.newCommandTimeoutMs.should.eql(42);\n      });\n    });\n  });\n});\n"],"mappings":";;;;;;AAEA;;AACA;;AAEAA,QAAQ,CAAC,SAAD,EAAY,YAAY;EAC9B,IAAIC,MAAM,GAAG,IAAIC,YAAJ,EAAb;EACA,IAAIC,eAAJ;EACA,IAAIC,OAAJ;EACAC,UAAU,CAAC,YAAY;IACrBD,OAAO,GAAG,IAAAE,oBAAA,GAAV;IACAL,MAAM,CAACM,cAAP,GAAwB,CAAxB;IACAJ,eAAe,GAAGC,OAAO,CAACI,GAAR,CAAYP,MAAZ,EAAoB,iBAApB,CAAlB;EACD,CAJS,CAAV;EAKAQ,SAAS,CAAC,YAAY;IACpBL,OAAO,CAACM,OAAR;EACD,CAFQ,CAAT;EAIAV,QAAQ,CAAC,UAAD,EAAa,YAAY;IAC/BA,QAAQ,CAAC,QAAD,EAAW,YAAY;MAC7BW,EAAE,CAAC,mDAAD,EAAsD,kBAAkB;QACxE,MAAMV,MAAM,CAACW,QAAP,CAAgB,gBAAhB,EAAkC,OAAlC,EAA2CC,MAA3C,CAAkDC,UAAlD,CAA6DC,EAA7D,CAAgEC,QAAtE;MACD,CAFC,CAAF;MAGAL,EAAE,CAAC,8CAAD,EAAiD,kBAAkB;QACnE,MAAMV,MAAM,CAACW,QAAP,CAAgB,gBAAhB,EAAkC,CAAC,EAAnC,EAAuCC,MAAvC,CAA8CC,UAA9C,CAAyDC,EAAzD,CAA4DC,QAAlE;MACD,CAFC,CAAF;MAGAL,EAAE,CAAC,mDAAD,EAAsD,kBAAkB;QACxE,MAAMV,MAAM,CAACW,QAAP,CAAgB,gBAAhB,EAAkC,EAAlC,EAAsCC,MAAtC,CAA6CC,UAA7C,CAAwDC,EAAxD,CAA2DC,QAAjE;MACD,CAFC,CAAF;MAGAL,EAAE,CAAC,qEAAD,EAAwE,kBAAkB;QAC1F,MAAMV,MAAM,CAACW,QAAP,CAAgBK,SAAhB,EAA2BA,SAA3B,EAAsC,GAAtC,EAA2CA,SAA3C,EAAsDA,SAAtD,EAAiEJ,MAAjE,CAAwEC,UAAxE,CAAmFC,EAAnF,CACHC,QADH;MAED,CAHC,CAAF;MAIAL,EAAE,CAAC,uEAAD,EAA0E,kBAAkB;QAC5F,MAAMV,MAAM,CAACW,QAAP,CAAgBK,SAAhB,EAA2BA,SAA3B,EAAsCA,SAAtC,EAAiD,GAAjD,EAAsDA,SAAtD,EAAiEJ,MAAjE,CAAwEC,UAAxE,CAAmFC,EAAnF,CACHC,QADH;MAED,CAHC,CAAF;IAID,CAlBO,CAAR;IAmBAhB,QAAQ,CAAC,eAAD,EAAkB,YAAY;MACpCW,EAAE,CAAC,mDAAD,EAAsD,kBAAkB;QACxE,MAAMV,MAAM,CAACW,QAAP,CAAgB,UAAhB,EAA4B,EAA5B,CAAN;QACAT,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;QACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;QACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;MACD,CALC,CAAF;MAMAZ,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;QACtE,MAAMV,MAAM,CAACW,QAAP,CAAgB,UAAhB,EAA4B,IAA5B,CAAN;QACAT,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;QACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;QACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;MACD,CALC,CAAF;MAMAZ,EAAE,CAAC,uEAAD,EAA0E,kBAAkB;QAC5F,MAAMV,MAAM,CAACW,QAAP,CAAgBK,SAAhB,EAA2BA,SAA3B,EAAsCA,SAAtC,EAAiDA,SAAjD,EAA4D,EAA5D,CAAN;QACAd,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;QACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;QACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;MACD,CALC,CAAF;MAMAZ,EAAE,CAAC,qEAAD,EAAwE,kBAAkB;QAC1F,MAAMV,MAAM,CAACW,QAAP,CAAgBK,SAAhB,EAA2BA,SAA3B,EAAsCA,SAAtC,EAAiDA,SAAjD,EAA4D,IAA5D,CAAN;QACAd,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;QACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;QACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;MACD,CALC,CAAF;IAMD,CAzBO,CAAR;EA0BD,CA9CO,CAAR;EA+CAvB,QAAQ,CAAC,cAAD,EAAiB,YAAY;IACnCW,EAAE,CAAC,mDAAD,EAAsD,kBAAkB;MACxE,MAAMV,MAAM,CAACuB,YAAP,CAAoB,EAApB,CAAN;MACArB,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;MACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;MACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;IACD,CALC,CAAF;IAMAZ,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;MACtE,MAAMV,MAAM,CAACuB,YAAP,CAAoB,IAApB,CAAN;MACArB,eAAe,CAACe,UAAhB,CAA2BL,MAA3B,CAAkCE,EAAlC,CAAqCI,IAArC;MACAhB,eAAe,CAACiB,SAAhB,CAA0BC,IAA1B,CAA+B,CAA/B,EAAkCR,MAAlC,CAAyCS,KAAzC,CAA+C,EAA/C;MACArB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;IACD,CALC,CAAF;IAMAZ,EAAE,CAAC,mDAAD,EAAsD,kBAAkB;MACxE,MAAMV,MAAM,CAACuB,YAAP,CAAoB,OAApB,EAA6BX,MAA7B,CAAoCC,UAApC,CAA+CC,EAA/C,CAAkDC,QAAxD;IACD,CAFC,CAAF;IAGAL,EAAE,CAAC,8CAAD,EAAiD,kBAAkB;MACnE,MAAMV,MAAM,CAACuB,YAAP,CAAoB,CAAC,EAArB,EAAyBX,MAAzB,CAAgCC,UAAhC,CAA2CC,EAA3C,CAA8CC,QAApD;IACD,CAFC,CAAF;EAGD,CAnBO,CAAR;EAqBAhB,QAAQ,CAAC,mBAAD,EAAsB,YAAY;IACxCW,EAAE,CAAC,8CAAD,EAAiD,YAAY;MAC7DV,MAAM,CAACwB,eAAP,CAAuB,EAAvB;MACAxB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;IACD,CAHC,CAAF;IAIAvB,QAAQ,CAAC,qBAAD,EAAwB,YAAY;MAC1C,IAAI0B,cAAc,GAAG,IAAIxB,YAAJ,EAArB;MACA,IAAIyB,cAAc,GAAG,IAAIzB,YAAJ,EAArB;MACA0B,MAAM,CAAC,YAAY;QACjB3B,MAAM,CAAC4B,gBAAP,CAAwBH,cAAxB;QACAzB,MAAM,CAAC4B,gBAAP,CAAwBF,cAAxB;MACD,CAHK,CAAN;MAIAG,KAAK,CAAC,YAAY;QAChB7B,MAAM,CAAC8B,cAAP,GAAwB,EAAxB;MACD,CAFI,CAAL;MAGApB,EAAE,CAAC,iDAAD,EAAoD,YAAY;QAChEV,MAAM,CAACwB,eAAP,CAAuB,EAAvB;QACAxB,MAAM,CAACM,cAAP,CAAsBM,MAAtB,CAA6BU,GAA7B,CAAiC,EAAjC;QACAG,cAAc,CAACnB,cAAf,CAA8BM,MAA9B,CAAqCU,GAArC,CAAyC,EAAzC;QACAI,cAAc,CAACpB,cAAf,CAA8BM,MAA9B,CAAqCU,GAArC,CAAyC,EAAzC;MACD,CALC,CAAF;IAMD,CAhBO,CAAR;EAiBD,CAtBO,CAAR;EAuBAvB,QAAQ,CAAC,yBAAD,EAA4B,YAAY;IAC9CW,EAAE,CAAC,oDAAD,EAAuD,YAAY;MACnEV,MAAM,CAAC+B,oBAAP,CAA4B,EAA5B;MACA/B,MAAM,CAACgC,mBAAP,CAA2BpB,MAA3B,CAAkCU,GAAlC,CAAsC,EAAtC;IACD,CAHC,CAAF;IAIAvB,QAAQ,CAAC,qBAAD,EAAwB,YAAY;MAC1C,IAAI0B,cAAc,GAAG,IAAIxB,YAAJ,EAArB;MACA,IAAIyB,cAAc,GAAG,IAAIzB,YAAJ,EAArB;MACA0B,MAAM,CAAC,YAAY;QACjB3B,MAAM,CAAC4B,gBAAP,CAAwBH,cAAxB;QACAzB,MAAM,CAAC4B,gBAAP,CAAwBF,cAAxB;MACD,CAHK,CAAN;MAIAG,KAAK,CAAC,YAAY;QAChB7B,MAAM,CAAC8B,cAAP,GAAwB,EAAxB;MACD,CAFI,CAAL;MAGApB,EAAE,CAAC,uDAAD,EAA0D,YAAY;QACtEV,MAAM,CAAC+B,oBAAP,CAA4B,EAA5B;QACA/B,MAAM,CAACgC,mBAAP,CAA2BpB,MAA3B,CAAkCU,GAAlC,CAAsC,EAAtC;QACAG,cAAc,CAACO,mBAAf,CAAmCpB,MAAnC,CAA0CU,GAA1C,CAA8C,EAA9C;QACAI,cAAc,CAACM,mBAAf,CAAmCpB,MAAnC,CAA0CU,GAA1C,CAA8C,EAA9C;MACD,CALC,CAAF;IAMD,CAhBO,CAAR;EAiBD,CAtBO,CAAR;AAuBD,CA/HO,CAAR"}
|
|
@@ -1,155 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
require("source-map-support/register");
|
|
4
|
-
|
|
5
|
-
var _lib = require("../../../lib");
|
|
6
|
-
|
|
7
|
-
var _server2 = require("../../../lib/express/server");
|
|
8
|
-
|
|
9
|
-
var _sinon = require("sinon");
|
|
10
|
-
|
|
11
|
-
var _helpers = require("../../helpers");
|
|
12
|
-
|
|
13
|
-
const newMethodMap = {
|
|
14
|
-
'/session/:sessionId/fake': {
|
|
15
|
-
GET: {
|
|
16
|
-
command: 'fakeGet'
|
|
17
|
-
},
|
|
18
|
-
POST: {
|
|
19
|
-
command: 'fakePost',
|
|
20
|
-
payloadParams: {
|
|
21
|
-
required: ['fakeParam']
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
|
|
27
|
-
const updateServer = (app, httpServer) => {
|
|
28
|
-
app.updated = true;
|
|
29
|
-
httpServer.updated = true;
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
function fakeDriver() {
|
|
33
|
-
return {
|
|
34
|
-
sessionExists: () => {},
|
|
35
|
-
executeCommand: () => {}
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
describe('server configuration', function () {
|
|
40
|
-
let port;
|
|
41
|
-
let sandbox;
|
|
42
|
-
|
|
43
|
-
function fakeApp() {
|
|
44
|
-
const app = {
|
|
45
|
-
use: sandbox.spy(),
|
|
46
|
-
all: sandbox.spy(),
|
|
47
|
-
get: sandbox.spy(),
|
|
48
|
-
post: sandbox.spy(),
|
|
49
|
-
delete: sandbox.spy(),
|
|
50
|
-
totalCount: () => app.use.callCount + app.all.callCount + app.get.callCount + app.post.callCount + app.delete.callCount
|
|
51
|
-
};
|
|
52
|
-
return app;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
before(async function () {
|
|
56
|
-
port = await (0, _helpers.getTestPort)(true);
|
|
57
|
-
});
|
|
58
|
-
beforeEach(function () {
|
|
59
|
-
sandbox = (0, _sinon.createSandbox)();
|
|
60
|
-
});
|
|
61
|
-
afterEach(function () {
|
|
62
|
-
sandbox.restore();
|
|
63
|
-
});
|
|
64
|
-
it('should actually use the middleware', function () {
|
|
65
|
-
const app = fakeApp();
|
|
66
|
-
|
|
67
|
-
const configureRoutes = () => {};
|
|
68
|
-
|
|
69
|
-
(0, _server2.configureServer)({
|
|
70
|
-
app,
|
|
71
|
-
addRoutes: configureRoutes
|
|
72
|
-
});
|
|
73
|
-
app.use.callCount.should.equal(14);
|
|
74
|
-
app.all.callCount.should.equal(4);
|
|
75
|
-
});
|
|
76
|
-
it('should apply new methods in plugins to the standard method map', function () {
|
|
77
|
-
const app1 = fakeApp();
|
|
78
|
-
const app2 = fakeApp();
|
|
79
|
-
const driver = fakeDriver();
|
|
80
|
-
const addRoutes = (0, _lib.routeConfiguringFunction)(driver);
|
|
81
|
-
(0, _server2.configureServer)({
|
|
82
|
-
app: app1,
|
|
83
|
-
addRoutes
|
|
84
|
-
});
|
|
85
|
-
(0, _server2.configureServer)({
|
|
86
|
-
app: app2,
|
|
87
|
-
addRoutes,
|
|
88
|
-
extraMethodMap: newMethodMap
|
|
89
|
-
});
|
|
90
|
-
app2.totalCount().should.eql(app1.totalCount() + 2);
|
|
91
|
-
});
|
|
92
|
-
it('should silently reject new methods in plugins if not plain objects', function () {
|
|
93
|
-
const app1 = fakeApp();
|
|
94
|
-
const app2 = fakeApp();
|
|
95
|
-
const driver = fakeDriver();
|
|
96
|
-
const addRoutes = (0, _lib.routeConfiguringFunction)(driver);
|
|
97
|
-
(0, _server2.configureServer)({
|
|
98
|
-
app: app1,
|
|
99
|
-
addRoutes
|
|
100
|
-
});
|
|
101
|
-
(0, _server2.configureServer)({
|
|
102
|
-
app: app2,
|
|
103
|
-
addRoutes,
|
|
104
|
-
extraMethodMap: []
|
|
105
|
-
});
|
|
106
|
-
app2.totalCount().should.eql(app1.totalCount());
|
|
107
|
-
});
|
|
108
|
-
it('should allow plugins to update the server', async function () {
|
|
109
|
-
const driver = fakeDriver();
|
|
110
|
-
|
|
111
|
-
const _server = await (0, _lib.server)({
|
|
112
|
-
routeConfiguringFunction: (0, _lib.routeConfiguringFunction)(driver),
|
|
113
|
-
port,
|
|
114
|
-
extraMethodMap: newMethodMap,
|
|
115
|
-
serverUpdaters: [updateServer]
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
try {
|
|
119
|
-
_server.updated.should.be.true;
|
|
120
|
-
} finally {
|
|
121
|
-
await _server.close();
|
|
122
|
-
}
|
|
123
|
-
});
|
|
124
|
-
it('should reject if error thrown in configureRoutes parameter', async function () {
|
|
125
|
-
const configureRoutes = () => {
|
|
126
|
-
throw new Error('I am Mr. MeeSeeks look at me!');
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
await (0, _lib.server)({
|
|
130
|
-
routeConfiguringFunction: configureRoutes,
|
|
131
|
-
port
|
|
132
|
-
}).should.be.rejectedWith('MeeSeeks');
|
|
133
|
-
});
|
|
134
|
-
describe('#normalizeBasePath', function () {
|
|
135
|
-
it('should throw an error for paths of the wrong type', function () {
|
|
136
|
-
should.throw(() => {
|
|
137
|
-
(0, _server2.normalizeBasePath)(null);
|
|
138
|
-
});
|
|
139
|
-
should.throw(() => {
|
|
140
|
-
(0, _server2.normalizeBasePath)(1);
|
|
141
|
-
});
|
|
142
|
-
});
|
|
143
|
-
it('should remove trailing slashes', function () {
|
|
144
|
-
(0, _server2.normalizeBasePath)('/wd/hub/').should.eql('/wd/hub');
|
|
145
|
-
(0, _server2.normalizeBasePath)('/foo/').should.eql('/foo');
|
|
146
|
-
(0, _server2.normalizeBasePath)('/').should.eql('');
|
|
147
|
-
});
|
|
148
|
-
it('should ensure a leading slash is present', function () {
|
|
149
|
-
(0, _server2.normalizeBasePath)('foo').should.eql('/foo');
|
|
150
|
-
(0, _server2.normalizeBasePath)('wd/hub').should.eql('/wd/hub');
|
|
151
|
-
(0, _server2.normalizeBasePath)('wd/hub/').should.eql('/wd/hub');
|
|
152
|
-
});
|
|
153
|
-
});
|
|
154
|
-
});
|
|
155
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["newMethodMap","GET","command","POST","payloadParams","required","updateServer","app","httpServer","updated","fakeDriver","sessionExists","executeCommand","describe","port","sandbox","fakeApp","use","spy","all","get","post","delete","totalCount","callCount","before","getTestPort","beforeEach","createSandbox","afterEach","restore","it","configureRoutes","configureServer","addRoutes","should","equal","app1","app2","driver","routeConfiguringFunction","extraMethodMap","eql","_server","server","serverUpdaters","be","true","close","Error","rejectedWith","throw","normalizeBasePath"],"sources":["../../../../test/unit/express/server.spec.js"],"sourcesContent":["// transpile:mocha\n\nimport {server, routeConfiguringFunction} from '../../../lib';\nimport {configureServer, normalizeBasePath} from '../../../lib/express/server';\nimport {createSandbox} from 'sinon';\nimport {getTestPort} from '../../helpers';\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  let sandbox;\n\n  function fakeApp() {\n    const app = {\n      use: sandbox.spy(),\n      all: sandbox.spy(),\n      get: sandbox.spy(),\n      post: sandbox.spy(),\n      delete: sandbox.spy(),\n      totalCount: () =>\n        app.use.callCount +\n        app.all.callCount +\n        app.get.callCount +\n        app.post.callCount +\n        app.delete.callCount,\n    };\n    return app;\n  }\n\n  before(async function () {\n    port = await getTestPort(true);\n  });\n\n  beforeEach(function () {\n    sandbox = createSandbox();\n  });\n\n  afterEach(function () {\n    sandbox.restore();\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"],"mappings":";;;;AAEA;;AACA;;AACA;;AACA;;AAEA,MAAMA,YAAY,GAAG;EACnB,4BAA4B;IAC1BC,GAAG,EAAE;MAACC,OAAO,EAAE;IAAV,CADqB;IAE1BC,IAAI,EAAE;MAACD,OAAO,EAAE,UAAV;MAAsBE,aAAa,EAAE;QAACC,QAAQ,EAAE,CAAC,WAAD;MAAX;IAArC;EAFoB;AADT,CAArB;;AAOA,MAAMC,YAAY,GAAG,CAACC,GAAD,EAAMC,UAAN,KAAqB;EACxCD,GAAG,CAACE,OAAJ,GAAc,IAAd;EACAD,UAAU,CAACC,OAAX,GAAqB,IAArB;AACD,CAHD;;AAKA,SAASC,UAAT,GAAsB;EACpB,OAAO;IAACC,aAAa,EAAE,MAAM,CAAE,CAAxB;IAA0BC,cAAc,EAAE,MAAM,CAAE;EAAlD,CAAP;AACD;;AAEDC,QAAQ,CAAC,sBAAD,EAAyB,YAAY;EAC3C,IAAIC,IAAJ;EAEA,IAAIC,OAAJ;;EAEA,SAASC,OAAT,GAAmB;IACjB,MAAMT,GAAG,GAAG;MACVU,GAAG,EAAEF,OAAO,CAACG,GAAR,EADK;MAEVC,GAAG,EAAEJ,OAAO,CAACG,GAAR,EAFK;MAGVE,GAAG,EAAEL,OAAO,CAACG,GAAR,EAHK;MAIVG,IAAI,EAAEN,OAAO,CAACG,GAAR,EAJI;MAKVI,MAAM,EAAEP,OAAO,CAACG,GAAR,EALE;MAMVK,UAAU,EAAE,MACVhB,GAAG,CAACU,GAAJ,CAAQO,SAAR,GACAjB,GAAG,CAACY,GAAJ,CAAQK,SADR,GAEAjB,GAAG,CAACa,GAAJ,CAAQI,SAFR,GAGAjB,GAAG,CAACc,IAAJ,CAASG,SAHT,GAIAjB,GAAG,CAACe,MAAJ,CAAWE;IAXH,CAAZ;IAaA,OAAOjB,GAAP;EACD;;EAEDkB,MAAM,CAAC,kBAAkB;IACvBX,IAAI,GAAG,MAAM,IAAAY,oBAAA,EAAY,IAAZ,CAAb;EACD,CAFK,CAAN;EAIAC,UAAU,CAAC,YAAY;IACrBZ,OAAO,GAAG,IAAAa,oBAAA,GAAV;EACD,CAFS,CAAV;EAIAC,SAAS,CAAC,YAAY;IACpBd,OAAO,CAACe,OAAR;EACD,CAFQ,CAAT;EAIAC,EAAE,CAAC,oCAAD,EAAuC,YAAY;IACnD,MAAMxB,GAAG,GAAGS,OAAO,EAAnB;;IACA,MAAMgB,eAAe,GAAG,MAAM,CAAE,CAAhC;;IACA,IAAAC,wBAAA,EAAgB;MAAC1B,GAAD;MAAM2B,SAAS,EAAEF;IAAjB,CAAhB;IACAzB,GAAG,CAACU,GAAJ,CAAQO,SAAR,CAAkBW,MAAlB,CAAyBC,KAAzB,CAA+B,EAA/B;IACA7B,GAAG,CAACY,GAAJ,CAAQK,SAAR,CAAkBW,MAAlB,CAAyBC,KAAzB,CAA+B,CAA/B;EACD,CANC,CAAF;EAQAL,EAAE,CAAC,gEAAD,EAAmE,YAAY;IAC/E,MAAMM,IAAI,GAAGrB,OAAO,EAApB;IACA,MAAMsB,IAAI,GAAGtB,OAAO,EAApB;IACA,MAAMuB,MAAM,GAAG7B,UAAU,EAAzB;IACA,MAAMwB,SAAS,GAAG,IAAAM,6BAAA,EAAyBD,MAAzB,CAAlB;IACA,IAAAN,wBAAA,EAAgB;MAAC1B,GAAG,EAAE8B,IAAN;MAAYH;IAAZ,CAAhB;IACA,IAAAD,wBAAA,EAAgB;MAAC1B,GAAG,EAAE+B,IAAN;MAAYJ,SAAZ;MAAuBO,cAAc,EAAEzC;IAAvC,CAAhB;IACAsC,IAAI,CAACf,UAAL,GAAkBY,MAAlB,CAAyBO,GAAzB,CAA6BL,IAAI,CAACd,UAAL,KAAoB,CAAjD;EACD,CARC,CAAF;EAUAQ,EAAE,CAAC,oEAAD,EAAuE,YAAY;IACnF,MAAMM,IAAI,GAAGrB,OAAO,EAApB;IACA,MAAMsB,IAAI,GAAGtB,OAAO,EAApB;IACA,MAAMuB,MAAM,GAAG7B,UAAU,EAAzB;IACA,MAAMwB,SAAS,GAAG,IAAAM,6BAAA,EAAyBD,MAAzB,CAAlB;IACA,IAAAN,wBAAA,EAAgB;MAAC1B,GAAG,EAAE8B,IAAN;MAAYH;IAAZ,CAAhB;IACA,IAAAD,wBAAA,EAAgB;MAAC1B,GAAG,EAAE+B,IAAN;MAAYJ,SAAZ;MAAuBO,cAAc,EAAE;IAAvC,CAAhB;IACAH,IAAI,CAACf,UAAL,GAAkBY,MAAlB,CAAyBO,GAAzB,CAA6BL,IAAI,CAACd,UAAL,EAA7B;EACD,CARC,CAAF;EAUAQ,EAAE,CAAC,2CAAD,EAA8C,kBAAkB;IAChE,MAAMQ,MAAM,GAAG7B,UAAU,EAAzB;;IACA,MAAMiC,OAAO,GAAG,MAAM,IAAAC,WAAA,EAAO;MAC3BJ,wBAAwB,EAAE,IAAAA,6BAAA,EAAyBD,MAAzB,CADC;MAE3BzB,IAF2B;MAG3B2B,cAAc,EAAEzC,YAHW;MAI3B6C,cAAc,EAAE,CAACvC,YAAD;IAJW,CAAP,CAAtB;;IAMA,IAAI;MACFqC,OAAO,CAAClC,OAAR,CAAgB0B,MAAhB,CAAuBW,EAAvB,CAA0BC,IAA1B;IACD,CAFD,SAEU;MACR,MAAMJ,OAAO,CAACK,KAAR,EAAN;IACD;EACF,CAbC,CAAF;EAeAjB,EAAE,CAAC,4DAAD,EAA+D,kBAAkB;IACjF,MAAMC,eAAe,GAAG,MAAM;MAC5B,MAAM,IAAIiB,KAAJ,CAAU,+BAAV,CAAN;IACD,CAFD;;IAGA,MAAM,IAAAL,WAAA,EAAO;MACXJ,wBAAwB,EAAER,eADf;MAEXlB;IAFW,CAAP,EAGHqB,MAHG,CAGIW,EAHJ,CAGOI,YAHP,CAGoB,UAHpB,CAAN;EAID,CARC,CAAF;EAUArC,QAAQ,CAAC,oBAAD,EAAuB,YAAY;IACzCkB,EAAE,CAAC,mDAAD,EAAsD,YAAY;MAClEI,MAAM,CAACgB,KAAP,CAAa,MAAM;QACjB,IAAAC,0BAAA,EAAkB,IAAlB;MACD,CAFD;MAGAjB,MAAM,CAACgB,KAAP,CAAa,MAAM;QACjB,IAAAC,0BAAA,EAAkB,CAAlB;MACD,CAFD;IAGD,CAPC,CAAF;IAQArB,EAAE,CAAC,gCAAD,EAAmC,YAAY;MAC/C,IAAAqB,0BAAA,EAAkB,UAAlB,EAA8BjB,MAA9B,CAAqCO,GAArC,CAAyC,SAAzC;MACA,IAAAU,0BAAA,EAAkB,OAAlB,EAA2BjB,MAA3B,CAAkCO,GAAlC,CAAsC,MAAtC;MACA,IAAAU,0BAAA,EAAkB,GAAlB,EAAuBjB,MAAvB,CAA8BO,GAA9B,CAAkC,EAAlC;IACD,CAJC,CAAF;IAKAX,EAAE,CAAC,0CAAD,EAA6C,YAAY;MACzD,IAAAqB,0BAAA,EAAkB,KAAlB,EAAyBjB,MAAzB,CAAgCO,GAAhC,CAAoC,MAApC;MACA,IAAAU,0BAAA,EAAkB,QAAlB,EAA4BjB,MAA5B,CAAmCO,GAAnC,CAAuC,SAAvC;MACA,IAAAU,0BAAA,EAAkB,SAAlB,EAA6BjB,MAA7B,CAAoCO,GAApC,CAAwC,SAAxC;IACD,CAJC,CAAF;EAKD,CAnBO,CAAR;AAoBD,CA3GO,CAAR"}
|