@limrun/cli 0.1.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/README.md +670 -0
- package/bin/dev.js +16 -0
- package/bin/run.js +8 -0
- package/dist/base-command.d.ts +17 -0
- package/dist/base-command.d.ts.map +1 -0
- package/dist/base-command.js +111 -0
- package/dist/base-command.js.map +1 -0
- package/dist/commands/build.d.ts +20 -0
- package/dist/commands/build.d.ts.map +1 -0
- package/dist/commands/build.js +83 -0
- package/dist/commands/build.js.map +1 -0
- package/dist/commands/connect/android.d.ts +15 -0
- package/dist/commands/connect/android.d.ts.map +1 -0
- package/dist/commands/connect/android.js +80 -0
- package/dist/commands/connect/android.js.map +1 -0
- package/dist/commands/delete/android.d.ts +14 -0
- package/dist/commands/delete/android.d.ts.map +1 -0
- package/dist/commands/delete/android.js +22 -0
- package/dist/commands/delete/android.js.map +1 -0
- package/dist/commands/delete/asset.d.ts +14 -0
- package/dist/commands/delete/asset.d.ts.map +1 -0
- package/dist/commands/delete/asset.js +22 -0
- package/dist/commands/delete/asset.js.map +1 -0
- package/dist/commands/delete/index.d.ts +14 -0
- package/dist/commands/delete/index.d.ts.map +1 -0
- package/dist/commands/delete/index.js +47 -0
- package/dist/commands/delete/index.js.map +1 -0
- package/dist/commands/delete/ios.d.ts +14 -0
- package/dist/commands/delete/ios.d.ts.map +1 -0
- package/dist/commands/delete/ios.js +24 -0
- package/dist/commands/delete/ios.js.map +1 -0
- package/dist/commands/delete/xcode.d.ts +14 -0
- package/dist/commands/delete/xcode.d.ts.map +1 -0
- package/dist/commands/delete/xcode.js +22 -0
- package/dist/commands/delete/xcode.js.map +1 -0
- package/dist/commands/exec/element-tree.d.ts +14 -0
- package/dist/commands/exec/element-tree.d.ts.map +1 -0
- package/dist/commands/exec/element-tree.js +51 -0
- package/dist/commands/exec/element-tree.js.map +1 -0
- package/dist/commands/exec/install-app.d.ts +16 -0
- package/dist/commands/exec/install-app.d.ts.map +1 -0
- package/dist/commands/exec/install-app.js +75 -0
- package/dist/commands/exec/install-app.js.map +1 -0
- package/dist/commands/exec/launch-app.d.ts +16 -0
- package/dist/commands/exec/launch-app.d.ts.map +1 -0
- package/dist/commands/exec/launch-app.js +49 -0
- package/dist/commands/exec/launch-app.js.map +1 -0
- package/dist/commands/exec/list-apps.d.ts +14 -0
- package/dist/commands/exec/list-apps.d.ts.map +1 -0
- package/dist/commands/exec/list-apps.js +45 -0
- package/dist/commands/exec/list-apps.js.map +1 -0
- package/dist/commands/exec/log.d.ts +17 -0
- package/dist/commands/exec/log.d.ts.map +1 -0
- package/dist/commands/exec/log.js +80 -0
- package/dist/commands/exec/log.js.map +1 -0
- package/dist/commands/exec/open-url.d.ts +15 -0
- package/dist/commands/exec/open-url.d.ts.map +1 -0
- package/dist/commands/exec/open-url.js +35 -0
- package/dist/commands/exec/open-url.js.map +1 -0
- package/dist/commands/exec/press-key.d.ts +16 -0
- package/dist/commands/exec/press-key.d.ts.map +1 -0
- package/dist/commands/exec/press-key.js +41 -0
- package/dist/commands/exec/press-key.js.map +1 -0
- package/dist/commands/exec/record.d.ts +17 -0
- package/dist/commands/exec/record.d.ts.map +1 -0
- package/dist/commands/exec/record.js +78 -0
- package/dist/commands/exec/record.js.map +1 -0
- package/dist/commands/exec/screenshot.d.ts +15 -0
- package/dist/commands/exec/screenshot.d.ts.map +1 -0
- package/dist/commands/exec/screenshot.js +65 -0
- package/dist/commands/exec/screenshot.js.map +1 -0
- package/dist/commands/exec/scroll.d.ts +16 -0
- package/dist/commands/exec/scroll.d.ts.map +1 -0
- package/dist/commands/exec/scroll.js +50 -0
- package/dist/commands/exec/scroll.js.map +1 -0
- package/dist/commands/exec/tap-element.d.ts +18 -0
- package/dist/commands/exec/tap-element.d.ts.map +1 -0
- package/dist/commands/exec/tap-element.js +91 -0
- package/dist/commands/exec/tap-element.js.map +1 -0
- package/dist/commands/exec/tap.d.ts +22 -0
- package/dist/commands/exec/tap.d.ts.map +1 -0
- package/dist/commands/exec/tap.js +41 -0
- package/dist/commands/exec/tap.js.map +1 -0
- package/dist/commands/exec/terminate-app.d.ts +15 -0
- package/dist/commands/exec/terminate-app.d.ts.map +1 -0
- package/dist/commands/exec/terminate-app.js +39 -0
- package/dist/commands/exec/terminate-app.js.map +1 -0
- package/dist/commands/exec/type.d.ts +16 -0
- package/dist/commands/exec/type.d.ts.map +1 -0
- package/dist/commands/exec/type.js +43 -0
- package/dist/commands/exec/type.js.map +1 -0
- package/dist/commands/get/android.d.ts +19 -0
- package/dist/commands/get/android.d.ts.map +1 -0
- package/dist/commands/get/android.js +69 -0
- package/dist/commands/get/android.js.map +1 -0
- package/dist/commands/get/asset.d.ts +18 -0
- package/dist/commands/get/asset.d.ts.map +1 -0
- package/dist/commands/get/asset.js +74 -0
- package/dist/commands/get/asset.js.map +1 -0
- package/dist/commands/get/ios.d.ts +19 -0
- package/dist/commands/get/ios.d.ts.map +1 -0
- package/dist/commands/get/ios.js +69 -0
- package/dist/commands/get/ios.js.map +1 -0
- package/dist/commands/get/xcode.d.ts +17 -0
- package/dist/commands/get/xcode.d.ts.map +1 -0
- package/dist/commands/get/xcode.js +65 -0
- package/dist/commands/get/xcode.js.map +1 -0
- package/dist/commands/login.d.ts +7 -0
- package/dist/commands/login.d.ts.map +1 -0
- package/dist/commands/login.js +18 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +7 -0
- package/dist/commands/logout.d.ts.map +1 -0
- package/dist/commands/logout.js +14 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/pull.d.ts +16 -0
- package/dist/commands/pull.d.ts.map +1 -0
- package/dist/commands/pull.js +71 -0
- package/dist/commands/pull.js.map +1 -0
- package/dist/commands/push.d.ts +15 -0
- package/dist/commands/push.d.ts.map +1 -0
- package/dist/commands/push.js +40 -0
- package/dist/commands/push.js.map +1 -0
- package/dist/commands/run/android.d.ts +24 -0
- package/dist/commands/run/android.d.ts.map +1 -0
- package/dist/commands/run/android.js +183 -0
- package/dist/commands/run/android.js.map +1 -0
- package/dist/commands/run/ios.d.ts +23 -0
- package/dist/commands/run/ios.d.ts.map +1 -0
- package/dist/commands/run/ios.js +129 -0
- package/dist/commands/run/ios.js.map +1 -0
- package/dist/commands/run/xcode.d.ts +19 -0
- package/dist/commands/run/xcode.d.ts.map +1 -0
- package/dist/commands/run/xcode.js +81 -0
- package/dist/commands/run/xcode.js.map +1 -0
- package/dist/commands/session/start.d.ts +15 -0
- package/dist/commands/session/start.d.ts.map +1 -0
- package/dist/commands/session/start.js +97 -0
- package/dist/commands/session/start.js.map +1 -0
- package/dist/commands/session/status.d.ts +11 -0
- package/dist/commands/session/status.d.ts.map +1 -0
- package/dist/commands/session/status.js +64 -0
- package/dist/commands/session/status.js.map +1 -0
- package/dist/commands/session/stop.d.ts +15 -0
- package/dist/commands/session/stop.d.ts.map +1 -0
- package/dist/commands/session/stop.js +67 -0
- package/dist/commands/session/stop.js.map +1 -0
- package/dist/commands/sync.d.ts +19 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +80 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/auth.d.ts +2 -0
- package/dist/lib/auth.d.ts.map +1 -0
- package/dist/lib/auth.js +60 -0
- package/dist/lib/auth.js.map +1 -0
- package/dist/lib/config.d.ts +21 -0
- package/dist/lib/config.d.ts.map +1 -0
- package/dist/lib/config.js +101 -0
- package/dist/lib/config.js.map +1 -0
- package/dist/lib/daemon-client.d.ts +9 -0
- package/dist/lib/daemon-client.d.ts.map +1 -0
- package/dist/lib/daemon-client.js +81 -0
- package/dist/lib/daemon-client.js.map +1 -0
- package/dist/lib/daemon.d.ts +40 -0
- package/dist/lib/daemon.d.ts.map +1 -0
- package/dist/lib/daemon.js +427 -0
- package/dist/lib/daemon.js.map +1 -0
- package/dist/lib/formatting.d.ts +3 -0
- package/dist/lib/formatting.d.ts.map +1 -0
- package/dist/lib/formatting.js +31 -0
- package/dist/lib/formatting.js.map +1 -0
- package/dist/lib/instance-client-factory.d.ts +23 -0
- package/dist/lib/instance-client-factory.d.ts.map +1 -0
- package/dist/lib/instance-client-factory.js +62 -0
- package/dist/lib/instance-client-factory.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const path_1 = __importDefault(require("path"));
|
|
7
|
+
const core_1 = require("@oclif/core");
|
|
8
|
+
const base_command_1 = require("../../base-command");
|
|
9
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
10
|
+
class ExecRecord extends base_command_1.BaseCommand {
|
|
11
|
+
async run() {
|
|
12
|
+
const { args, flags } = await this.parse(ExecRecord);
|
|
13
|
+
this.setParsedFlags(flags);
|
|
14
|
+
await this.withAuth(async () => {
|
|
15
|
+
if (args.action === 'start') {
|
|
16
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
17
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'start-recording', [flags.quality]);
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
const { client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
21
|
+
try {
|
|
22
|
+
await client.startRecording({ quality: flags.quality });
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
disconnect();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
this.log('Recording started');
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
const saveTo = {};
|
|
32
|
+
if (flags.output)
|
|
33
|
+
saveTo.localPath = path_1.default.resolve(flags.output);
|
|
34
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
35
|
+
const url = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'stop-recording', [saveTo]);
|
|
36
|
+
if (flags.output) {
|
|
37
|
+
this.log(`Recording saved to ${flags.output}`);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.log(`Recording download URL: ${url}`);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
const { client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
45
|
+
try {
|
|
46
|
+
const url = await client.stopRecording(saveTo);
|
|
47
|
+
if (flags.output) {
|
|
48
|
+
this.log(`Recording saved to ${flags.output}`);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.log(`Recording download URL: ${url}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
finally {
|
|
55
|
+
disconnect();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
ExecRecord.summary = 'Start or stop video recording on a running instance';
|
|
63
|
+
ExecRecord.examples = [
|
|
64
|
+
'<%= config.bin %> exec record <instance-ID> start',
|
|
65
|
+
'<%= config.bin %> exec record <instance-ID> stop -o recording.mp4',
|
|
66
|
+
'<%= config.bin %> exec record <instance-ID> start --quality 8',
|
|
67
|
+
];
|
|
68
|
+
ExecRecord.args = {
|
|
69
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
70
|
+
action: core_1.Args.string({ description: 'start or stop', required: true, options: ['start', 'stop'] }),
|
|
71
|
+
};
|
|
72
|
+
ExecRecord.flags = {
|
|
73
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
74
|
+
quality: core_1.Flags.integer({ description: 'Recording quality (5-10)', default: 5 }),
|
|
75
|
+
output: core_1.Flags.string({ char: 'o', description: 'Save recording to file (for stop action)' }),
|
|
76
|
+
};
|
|
77
|
+
exports.default = ExecRecord;
|
|
78
|
+
//# sourceMappingURL=record.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"record.js","sourceRoot":"","sources":["../../../src/commands/exec/record.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecScreenshot extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
output: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=screenshot.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screenshot.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/screenshot.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,WAAW;IACrD,MAAM,CAAC,OAAO,SAAkD;IAChE,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;MAET;IAEF,MAAM,CAAC,KAAK;;;;MAGV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAqC3B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const fs_1 = __importDefault(require("fs"));
|
|
7
|
+
const path_1 = __importDefault(require("path"));
|
|
8
|
+
const core_1 = require("@oclif/core");
|
|
9
|
+
const base_command_1 = require("../../base-command");
|
|
10
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
11
|
+
class ExecScreenshot extends base_command_1.BaseCommand {
|
|
12
|
+
async run() {
|
|
13
|
+
const { args, flags } = await this.parse(ExecScreenshot);
|
|
14
|
+
this.setParsedFlags(flags);
|
|
15
|
+
await this.withAuth(async () => {
|
|
16
|
+
let screenshot;
|
|
17
|
+
let type;
|
|
18
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
19
|
+
screenshot = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'screenshot');
|
|
20
|
+
type = args.id.split('_')[0];
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
const resolved = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
24
|
+
type = resolved.type;
|
|
25
|
+
try {
|
|
26
|
+
screenshot = await resolved.client.screenshot();
|
|
27
|
+
}
|
|
28
|
+
finally {
|
|
29
|
+
resolved.disconnect();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (flags.output) {
|
|
33
|
+
const outPath = path_1.default.resolve(flags.output);
|
|
34
|
+
if (type === 'ios') {
|
|
35
|
+
fs_1.default.writeFileSync(outPath, Buffer.from(screenshot.base64, 'base64'));
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
const base64 = screenshot.dataUri.replace(/^data:image\/\w+;base64,/, '');
|
|
39
|
+
fs_1.default.writeFileSync(outPath, Buffer.from(base64, 'base64'));
|
|
40
|
+
}
|
|
41
|
+
this.log(`Screenshot saved to ${outPath}`);
|
|
42
|
+
}
|
|
43
|
+
else if (flags.json) {
|
|
44
|
+
this.outputJson(screenshot);
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.log(type === 'ios' ? screenshot.base64 : screenshot.dataUri);
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ExecScreenshot.summary = 'Capture a screenshot from a running instance';
|
|
53
|
+
ExecScreenshot.examples = [
|
|
54
|
+
'<%= config.bin %> exec screenshot <instance-ID> -o screenshot.png',
|
|
55
|
+
'<%= config.bin %> exec screenshot <instance-ID>',
|
|
56
|
+
];
|
|
57
|
+
ExecScreenshot.args = {
|
|
58
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
59
|
+
};
|
|
60
|
+
ExecScreenshot.flags = {
|
|
61
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
62
|
+
output: core_1.Flags.string({ char: 'o', description: 'Save screenshot to file path' }),
|
|
63
|
+
};
|
|
64
|
+
exports.default = ExecScreenshot;
|
|
65
|
+
//# sourceMappingURL=screenshot.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screenshot.js","sourceRoot":"","sources":["../../../src/commands/exec/screenshot.ts"],"names":[],"mappings":";;;;;AAAA,4CAAoB;AACpB,gDAAwB;AACxB,sCAA0C;AAC1C,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,cAAe,SAAQ,0BAAW;IAgBrD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;QACzD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,UAAe,CAAC;YACpB,IAAI,IAAY,CAAC;YAEjB,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,UAAU,GAAG,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;gBAC7D,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,MAAM,QAAQ,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC/D,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;gBACrB,IAAI,CAAC;oBACH,UAAU,GAAG,MAAM,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;gBAClD,CAAC;wBAAS,CAAC;oBACT,QAAQ,CAAC,UAAU,EAAE,CAAC;gBACxB,CAAC;YACH,CAAC;YAED,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,MAAM,OAAO,GAAG,cAAI,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBAC3C,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;oBACnB,YAAE,CAAC,aAAa,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;gBACtE,CAAC;qBAAM,CAAC;oBACN,MAAM,MAAM,GAAI,UAAU,CAAC,OAAkB,CAAC,OAAO,CAAC,0BAA0B,EAAE,EAAE,CAAC,CAAC;oBACtF,YAAE,CAAC,aAAa,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;gBAC3D,CAAC;gBACD,IAAI,CAAC,GAAG,CAAC,uBAAuB,OAAO,EAAE,CAAC,CAAC;YAC7C,CAAC;iBAAM,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;gBACtB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;YAC9B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YACpE,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;;AAnDM,sBAAO,GAAG,8CAA8C,CAAC;AACzD,uBAAQ,GAAG;IAChB,mEAAmE;IACnE,iDAAiD;CAClD,CAAC;AAEK,mBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChE,CAAC;AAEK,oBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,MAAM,EAAE,YAAK,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,WAAW,EAAE,8BAA8B,EAAE,CAAC;CACjF,CAAC;kBAdiB,cAAc"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecScroll extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
direction: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
amount: import("@oclif/core/lib/interfaces").OptionFlag<number, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=scroll.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scroll.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/scroll.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,WAAW;IACjD,MAAM,CAAC,OAAO,SAAkC;IAChD,MAAM,CAAC,QAAQ,WAAqE;IAEpF,MAAM,CAAC,IAAI;;;MAOT;IAEF,MAAM,CAAC,KAAK;;;;MAMV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB3B"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecScroll extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecScroll);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'scroll', [args.direction, flags.amount]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
try {
|
|
17
|
+
if (type === 'ios') {
|
|
18
|
+
await client.scroll(args.direction, flags.amount);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
await client.scrollScreen(args.direction, flags.amount);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
disconnect();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
this.log(`Scrolled ${args.direction}`);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
ExecScroll.summary = 'Scroll on a running instance';
|
|
33
|
+
ExecScroll.examples = ['<%= config.bin %> exec scroll <instance-ID> down --amount 500'];
|
|
34
|
+
ExecScroll.args = {
|
|
35
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
36
|
+
direction: core_1.Args.string({
|
|
37
|
+
description: 'Scroll direction',
|
|
38
|
+
required: true,
|
|
39
|
+
options: ['up', 'down', 'left', 'right'],
|
|
40
|
+
}),
|
|
41
|
+
};
|
|
42
|
+
ExecScroll.flags = {
|
|
43
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
44
|
+
amount: core_1.Flags.integer({
|
|
45
|
+
description: 'Scroll amount (pixels for iOS, abstract units for Android)',
|
|
46
|
+
default: 300,
|
|
47
|
+
}),
|
|
48
|
+
};
|
|
49
|
+
exports.default = ExecScroll;
|
|
50
|
+
//# sourceMappingURL=scroll.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scroll.js","sourceRoot":"","sources":["../../../src/commands/exec/scroll.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,UAAW,SAAQ,0BAAW;IAqBjD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACrD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;YAC9E,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,MAAO,MAAc,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;oBAC7D,CAAC;yBAAM,CAAC;wBACN,MAAO,MAAc,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;oBACnE,CAAC;gBACH,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACzC,CAAC,CAAC,CAAC;IACL,CAAC;;AAzCM,kBAAO,GAAG,8BAA8B,CAAC;AACzC,mBAAQ,GAAG,CAAC,+DAA+D,CAAC,CAAC;AAE7E,eAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,SAAS,EAAE,WAAI,CAAC,MAAM,CAAC;QACrB,WAAW,EAAE,kBAAkB;QAC/B,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC;KACzC,CAAC;CACH,CAAC;AAEK,gBAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,MAAM,EAAE,YAAK,CAAC,OAAO,CAAC;QACpB,WAAW,EAAE,4DAA4D;QACzE,OAAO,EAAE,GAAG;KACb,CAAC;CACH,CAAC;kBAnBiB,UAAU"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecTapElement extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
};
|
|
8
|
+
static flags: {
|
|
9
|
+
label: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
10
|
+
'accessibility-id': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
'resource-id': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
text: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
14
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
15
|
+
};
|
|
16
|
+
run(): Promise<void>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=tap-element.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tap-element.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/tap-element.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,cAAe,SAAQ,WAAW;IACrD,MAAM,CAAC,OAAO,SAA8C;IAC5D,MAAM,CAAC,QAAQ,WAGb;IAEF,MAAM,CAAC,IAAI;;MAET;IAEF,MAAM,CAAC,KAAK;;;;;;;MAMV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CA+C3B"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecTapElement extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecTapElement);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
const type = args.id.split('_')[0];
|
|
12
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
13
|
+
const selector = {};
|
|
14
|
+
if (type === 'ios') {
|
|
15
|
+
if (flags.label)
|
|
16
|
+
selector.label = flags.label;
|
|
17
|
+
if (flags['accessibility-id'])
|
|
18
|
+
selector.accessibilityId = flags['accessibility-id'];
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
if (flags.label)
|
|
22
|
+
selector.contentDesc = flags.label;
|
|
23
|
+
if (flags['resource-id'])
|
|
24
|
+
selector.resourceId = flags['resource-id'];
|
|
25
|
+
if (flags.text)
|
|
26
|
+
selector.text = flags.text;
|
|
27
|
+
if (flags['accessibility-id'])
|
|
28
|
+
selector.resourceId = flags['accessibility-id'];
|
|
29
|
+
}
|
|
30
|
+
const result = await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'tap-element', [selector]);
|
|
31
|
+
if (flags.json)
|
|
32
|
+
this.outputJson(result);
|
|
33
|
+
else
|
|
34
|
+
this.log('Element tapped');
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
38
|
+
try {
|
|
39
|
+
if (type === 'ios') {
|
|
40
|
+
const selector = {};
|
|
41
|
+
if (flags.label)
|
|
42
|
+
selector.label = flags.label;
|
|
43
|
+
if (flags['accessibility-id'])
|
|
44
|
+
selector.accessibilityId = flags['accessibility-id'];
|
|
45
|
+
const result = await client.tapElement(selector);
|
|
46
|
+
if (flags.json)
|
|
47
|
+
this.outputJson(result);
|
|
48
|
+
else
|
|
49
|
+
this.log('Element tapped');
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
const selector = {};
|
|
53
|
+
if (flags.label)
|
|
54
|
+
selector.contentDesc = flags.label;
|
|
55
|
+
if (flags['resource-id'])
|
|
56
|
+
selector.resourceId = flags['resource-id'];
|
|
57
|
+
if (flags.text)
|
|
58
|
+
selector.text = flags.text;
|
|
59
|
+
if (flags['accessibility-id'])
|
|
60
|
+
selector.resourceId = flags['accessibility-id'];
|
|
61
|
+
const result = await client.tap({ selector });
|
|
62
|
+
if (flags.json)
|
|
63
|
+
this.outputJson(result);
|
|
64
|
+
else
|
|
65
|
+
this.log('Element tapped');
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
finally {
|
|
69
|
+
disconnect();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
ExecTapElement.summary = 'Tap an element by accessibility selector';
|
|
76
|
+
ExecTapElement.examples = [
|
|
77
|
+
'<%= config.bin %> exec tap-element <instance-ID> --label "Submit"',
|
|
78
|
+
'<%= config.bin %> exec tap-element <instance-ID> --accessibility-id btn_ok',
|
|
79
|
+
];
|
|
80
|
+
ExecTapElement.args = {
|
|
81
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
82
|
+
};
|
|
83
|
+
ExecTapElement.flags = {
|
|
84
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
85
|
+
label: core_1.Flags.string({ description: 'Element label text' }),
|
|
86
|
+
'accessibility-id': core_1.Flags.string({ description: 'Accessibility identifier' }),
|
|
87
|
+
'resource-id': core_1.Flags.string({ description: 'Android resource ID' }),
|
|
88
|
+
text: core_1.Flags.string({ description: 'Android text content' }),
|
|
89
|
+
};
|
|
90
|
+
exports.default = ExecTapElement;
|
|
91
|
+
//# sourceMappingURL=tap-element.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tap-element.js","sourceRoot":"","sources":["../../../src/commands/exec/tap-element.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecTap extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
x: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
8
|
+
max?: number;
|
|
9
|
+
min?: number;
|
|
10
|
+
}>;
|
|
11
|
+
y: import("@oclif/core/lib/interfaces").Arg<number, {
|
|
12
|
+
max?: number;
|
|
13
|
+
min?: number;
|
|
14
|
+
}>;
|
|
15
|
+
};
|
|
16
|
+
static flags: {
|
|
17
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
18
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
19
|
+
};
|
|
20
|
+
run(): Promise<void>;
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=tap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tap.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/tap.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,OAAQ,SAAQ,WAAW;IAC9C,MAAM,CAAC,OAAO,SAA8C;IAC5D,MAAM,CAAC,QAAQ,WAAwD;IAEvE,MAAM,CAAC,IAAI;;;;;;;;;;MAIT;IAEF,MAAM,CAAC,KAAK;;;MAAgC;IAEtC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB3B"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecTap extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecTap);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'tap', [args.x, args.y]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
try {
|
|
17
|
+
if (type === 'ios') {
|
|
18
|
+
await client.tap(args.x, args.y);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
await client.tap({ x: args.x, y: args.y });
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
disconnect();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
this.log(`Tapped at (${args.x}, ${args.y})`);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
ExecTap.summary = 'Tap at coordinates on a running instance';
|
|
33
|
+
ExecTap.examples = ['<%= config.bin %> exec tap <instance-ID> 100 200'];
|
|
34
|
+
ExecTap.args = {
|
|
35
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
36
|
+
x: core_1.Args.integer({ description: 'X coordinate', required: true }),
|
|
37
|
+
y: core_1.Args.integer({ description: 'Y coordinate', required: true }),
|
|
38
|
+
};
|
|
39
|
+
ExecTap.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
40
|
+
exports.default = ExecTap;
|
|
41
|
+
//# sourceMappingURL=tap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tap.js","sourceRoot":"","sources":["../../../src/commands/exec/tap.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,OAAQ,SAAQ,0BAAW;IAY9C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,MAAO,MAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC5C,CAAC;yBAAM,CAAC;wBACN,MAAO,MAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;oBACtD,CAAC;gBACH,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;IACL,CAAC;;AAhCM,eAAO,GAAG,0CAA0C,CAAC;AACrD,gBAAQ,GAAG,CAAC,kDAAkD,CAAC,CAAC;AAEhE,YAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,CAAC,EAAE,WAAI,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAChE,CAAC,EAAE,WAAI,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACjE,CAAC;AAEK,aAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAC;kBAVzB,OAAO"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecTerminateApp extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
bundleId: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
12
|
+
};
|
|
13
|
+
run(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=terminate-app.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"terminate-app.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/terminate-app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,gBAAiB,SAAQ,WAAW;IACvD,MAAM,CAAC,OAAO,SAAgD;IAC9D,MAAM,CAAC,QAAQ,WAA0E;IAEzF,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;MAAgC;IAEtC,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB3B"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecTerminateApp extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecTerminateApp);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'terminate-app', [args.bundleId]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
if (type !== 'ios') {
|
|
17
|
+
disconnect();
|
|
18
|
+
this.error('terminate-app is only supported on iOS instances');
|
|
19
|
+
}
|
|
20
|
+
try {
|
|
21
|
+
await client.terminateApp(args.bundleId);
|
|
22
|
+
}
|
|
23
|
+
finally {
|
|
24
|
+
disconnect();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
this.log(`Terminated ${args.bundleId}`);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
ExecTerminateApp.summary = 'Terminate an app on a running iOS instance';
|
|
32
|
+
ExecTerminateApp.examples = ['<%= config.bin %> exec terminate-app <instance-ID> com.example.app'];
|
|
33
|
+
ExecTerminateApp.args = {
|
|
34
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
35
|
+
bundleId: core_1.Args.string({ description: 'App bundle identifier', required: true }),
|
|
36
|
+
};
|
|
37
|
+
ExecTerminateApp.flags = { ...base_command_1.BaseCommand.baseFlags };
|
|
38
|
+
exports.default = ExecTerminateApp;
|
|
39
|
+
//# sourceMappingURL=terminate-app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"terminate-app.js","sourceRoot":"","sources":["../../../src/commands/exec/terminate-app.ts"],"names":[],"mappings":";;AAAA,sCAAmC;AACnC,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,gBAAiB,SAAQ,0BAAW;IAWvD,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAC3D,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,eAAe,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YACtE,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;oBACnB,UAAU,EAAE,CAAC;oBACb,IAAI,CAAC,KAAK,CAAC,kDAAkD,CAAC,CAAC;gBACjE,CAAC;gBACD,IAAI,CAAC;oBACH,MAAO,MAAc,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACpD,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC;;AA/BM,wBAAO,GAAG,4CAA4C,CAAC;AACvD,yBAAQ,GAAG,CAAC,oEAAoE,CAAC,CAAC;AAElF,qBAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,QAAQ,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,uBAAuB,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CAChF,CAAC;AAEK,sBAAK,GAAG,EAAE,GAAG,0BAAW,CAAC,SAAS,EAAE,CAAC;kBATzB,gBAAgB"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class ExecType extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static examples: string[];
|
|
5
|
+
static args: {
|
|
6
|
+
id: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
7
|
+
text: import("@oclif/core/lib/interfaces").Arg<string, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
'press-enter': import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
11
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
13
|
+
};
|
|
14
|
+
run(): Promise<void>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=type.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"type.d.ts","sourceRoot":"","sources":["../../../src/commands/exec/type.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGjD,MAAM,CAAC,OAAO,OAAO,QAAS,SAAQ,WAAW;IAC/C,MAAM,CAAC,OAAO,SAA4C;IAC1D,MAAM,CAAC,QAAQ,WAA+D;IAE9E,MAAM,CAAC,IAAI;;;MAGT;IAEF,MAAM,CAAC,KAAK;;;;MAGV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAsB3B"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const core_1 = require("@oclif/core");
|
|
4
|
+
const base_command_1 = require("../../base-command");
|
|
5
|
+
const instance_client_factory_1 = require("../../lib/instance-client-factory");
|
|
6
|
+
class ExecType extends base_command_1.BaseCommand {
|
|
7
|
+
async run() {
|
|
8
|
+
const { args, flags } = await this.parse(ExecType);
|
|
9
|
+
this.setParsedFlags(flags);
|
|
10
|
+
await this.withAuth(async () => {
|
|
11
|
+
if ((0, instance_client_factory_1.hasActiveSession)(args.id)) {
|
|
12
|
+
await (0, instance_client_factory_1.sendSessionCommand)(args.id, 'type', [args.text, flags['press-enter']]);
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
const { type, client, disconnect } = await (0, instance_client_factory_1.getInstanceClient)(this.client, args.id);
|
|
16
|
+
try {
|
|
17
|
+
if (type === 'ios') {
|
|
18
|
+
await client.typeText(args.text, flags['press-enter']);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
await client.setText(undefined, args.text);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
finally {
|
|
25
|
+
disconnect();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
this.log('Text typed');
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
ExecType.summary = 'Type text into the focused input field';
|
|
33
|
+
ExecType.examples = ['<%= config.bin %> exec type <instance-ID> "Hello World"'];
|
|
34
|
+
ExecType.args = {
|
|
35
|
+
id: core_1.Args.string({ description: 'Instance ID', required: true }),
|
|
36
|
+
text: core_1.Args.string({ description: 'Text to type', required: true }),
|
|
37
|
+
};
|
|
38
|
+
ExecType.flags = {
|
|
39
|
+
...base_command_1.BaseCommand.baseFlags,
|
|
40
|
+
'press-enter': core_1.Flags.boolean({ description: 'Press Enter after typing (iOS only)', default: false }),
|
|
41
|
+
};
|
|
42
|
+
exports.default = ExecType;
|
|
43
|
+
//# sourceMappingURL=type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"type.js","sourceRoot":"","sources":["../../../src/commands/exec/type.ts"],"names":[],"mappings":";;AAAA,sCAA0C;AAC1C,qDAAiD;AACjD,+EAA4G;AAE5G,MAAqB,QAAS,SAAQ,0BAAW;IAc/C,KAAK,CAAC,GAAG;QACP,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAE3B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE;YAC7B,IAAI,IAAA,0CAAgB,EAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;gBAC9B,MAAM,IAAA,4CAAkB,EAAC,IAAI,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YAC/E,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,2CAAiB,EAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;gBACnF,IAAI,CAAC;oBACH,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;wBACnB,MAAO,MAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC;oBAClE,CAAC;yBAAM,CAAC;wBACN,MAAO,MAAc,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBACtD,CAAC;gBACH,CAAC;wBAAS,CAAC;oBACT,UAAU,EAAE,CAAC;gBACf,CAAC;YACH,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;;AAlCM,gBAAO,GAAG,wCAAwC,CAAC;AACnD,iBAAQ,GAAG,CAAC,yDAAyD,CAAC,CAAC;AAEvE,aAAI,GAAG;IACZ,EAAE,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAC/D,IAAI,EAAE,WAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;CACnE,CAAC;AAEK,cAAK,GAAG;IACb,GAAG,0BAAW,CAAC,SAAS;IACxB,aAAa,EAAE,YAAK,CAAC,OAAO,CAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;CACrG,CAAC;kBAZiB,QAAQ"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { BaseCommand } from '../../base-command';
|
|
2
|
+
export default class GetAndroid extends BaseCommand {
|
|
3
|
+
static summary: string;
|
|
4
|
+
static aliases: string[];
|
|
5
|
+
static examples: string[];
|
|
6
|
+
static args: {
|
|
7
|
+
id: import("@oclif/core/lib/interfaces").Arg<string | undefined, Record<string, unknown>>;
|
|
8
|
+
};
|
|
9
|
+
static flags: {
|
|
10
|
+
state: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
11
|
+
region: import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
12
|
+
'label-selector': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
13
|
+
all: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
14
|
+
'api-key': import("@oclif/core/lib/interfaces").OptionFlag<string | undefined, import("@oclif/core/lib/interfaces").CustomOptions>;
|
|
15
|
+
json: import("@oclif/core/lib/interfaces").BooleanFlag<boolean>;
|
|
16
|
+
};
|
|
17
|
+
run(): Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=android.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"android.d.ts","sourceRoot":"","sources":["../../../src/commands/get/android.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,CAAC,OAAO,OAAO,UAAW,SAAQ,WAAW;IACjD,MAAM,CAAC,OAAO,SAAkD;IAChE,MAAM,CAAC,OAAO,WAAa;IAC3B,MAAM,CAAC,QAAQ,WAA2E;IAE1F,MAAM,CAAC,IAAI;;MAET;IAEF,MAAM,CAAC,KAAK;;;;;;;MAMV;IAEI,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAkD3B"}
|