refactor screen recording

Summary:
moving logic for screen recordings to the respective devices, instead of having it in the button component.
This is part of my wider effort to unify our use of adb/adbkit and upgrade to the latest version of adbkit.

Reviewed By: passy

Differential Revision: D17318702

fbshipit-source-id: cff4459047d7a197ed6cb8ee8c290b4eaab41479
This commit is contained in:
Daniel Büchele
2019-09-13 05:25:36 -07:00
committed by Facebook Github Bot
parent b7ad035742
commit 01be3dc5d1
4 changed files with 127 additions and 146 deletions

View File

@@ -6,7 +6,7 @@
*/
import {DeviceType, LogLevel, DeviceLogEntry} from './BaseDevice';
import child_process from 'child_process';
import child_process, {ChildProcess} from 'child_process';
import BaseDevice from './BaseDevice';
import JSONStream from 'JSONStream';
import {Transform} from 'stream';
@@ -39,6 +39,8 @@ type RawLogEntry = {
export default class IOSDevice extends BaseDevice {
log: any;
buffer: string;
private recordingProcess?: ChildProcess;
private recordingLocation?: string;
constructor(serial: string, deviceType: DeviceType, title: string) {
super(serial, deviceType, title, 'iOS');
@@ -138,11 +140,11 @@ export default class IOSDevice extends BaseDevice {
static parseLogEntry(entry: RawLogEntry): DeviceLogEntry {
const LOG_MAPPING: Map<IOSLogLevel, LogLevel> = new Map([
['Default', 'debug'],
['Info', 'info'],
['Debug', 'debug'],
['Error', 'error'],
['Fault', 'fatal'],
['Default' as IOSLogLevel, 'debug' as LogLevel],
['Info' as IOSLogLevel, 'info' as LogLevel],
['Debug' as IOSLogLevel, 'debug' as LogLevel],
['Error' as IOSLogLevel, 'error' as LogLevel],
['Fault' as IOSLogLevel, 'fatal' as LogLevel],
]);
let type: LogLevel = LOG_MAPPING.get(entry.messageType) || 'unknown';
@@ -174,6 +176,27 @@ export default class IOSDevice extends BaseDevice {
type,
};
}
async screenCaptureAvailable() {
return this.deviceType === 'emulator';
}
async startScreenCapture(destination: string) {
this.recordingProcess = exec(
`xcrun simctl io booted recordVideo "${destination}"`,
);
this.recordingLocation = destination;
}
async stopScreenCaputre(): Promise<string | null> {
if (this.recordingProcess && this.recordingLocation) {
this.recordingProcess.kill('SIGINT');
const {recordingLocation} = this;
this.recordingLocation = undefined;
return recordingLocation;
}
return null;
}
}
// Used to strip the initial output of the logging utility where it prints out settings.