mirror of
https://github.com/ARM-software/workload-automation.git
synced 2025-01-18 12:06:08 +00:00
WA Revent: Updated to support vsync version of revent
WA has been updated to automatically install and run vsync service apk and use the vsync version of revent for recording and playback on android platforms.
This commit is contained in:
parent
a81fe5555a
commit
601202c2ec
@ -60,6 +60,16 @@ class ReventCommand(Command):
|
|||||||
self.device.connect()
|
self.device.connect()
|
||||||
self.device.initialize(context)
|
self.device.initialize(context)
|
||||||
|
|
||||||
|
# Only install vsync service on android
|
||||||
|
if self.device.platform is 'android':
|
||||||
|
self.logger.debug("Installing HelloJni for vsync service")
|
||||||
|
host_HelloJni_apk = context.resolver.get(Executable(NO_ONE, self.device.abi, 'HelloJni.apk'))
|
||||||
|
self.target_HelloJni = self.device.install_if_needed(host_HelloJni_apk)
|
||||||
|
result = self.device.execute('dumpsys activity services | grep "ChoreoService"', check_exit_code=False)
|
||||||
|
if not result or 'com.example.hellojni/.ChoreoService' not in result:
|
||||||
|
self.device.execute('am startservice com.example.hellojni/.ChoreoService')
|
||||||
|
|
||||||
|
# Install revent
|
||||||
host_binary = context.resolver.get(Executable(NO_ONE, self.device.abi, 'revent'))
|
host_binary = context.resolver.get(Executable(NO_ONE, self.device.abi, 'revent'))
|
||||||
self.target_binary = self.device.install_executable(host_binary)
|
self.target_binary = self.device.install_executable(host_binary)
|
||||||
|
|
||||||
@ -149,7 +159,8 @@ class RecordCommand(ReventCommand):
|
|||||||
self.logger.info("Press Enter when you are ready to record...")
|
self.logger.info("Press Enter when you are ready to record...")
|
||||||
raw_input("")
|
raw_input("")
|
||||||
gamepad_flag = '-g ' if args.gamepad else ''
|
gamepad_flag = '-g ' if args.gamepad else ''
|
||||||
command = "{} record {}-s {}".format(self.target_binary, gamepad_flag, revent_file)
|
vsync_flag = '-V ' if self.device.platform is 'android' else ''
|
||||||
|
command = "{} record {}{}-s {}".format(self.target_binary, gamepad_flag, vsync_flag, revent_file)
|
||||||
self.device.kick_off(command)
|
self.device.kick_off(command)
|
||||||
|
|
||||||
self.logger.info("Press Enter when you have finished recording...")
|
self.logger.info("Press Enter when you have finished recording...")
|
||||||
@ -195,7 +206,8 @@ class ReplayCommand(ReventCommand):
|
|||||||
self.device.execute('monkey -p {} -c android.intent.category.LAUNCHER 1'.format(args.package))
|
self.device.execute('monkey -p {} -c android.intent.category.LAUNCHER 1'.format(args.package))
|
||||||
|
|
||||||
self.logger.info("Replaying recording")
|
self.logger.info("Replaying recording")
|
||||||
command = "{} replay {}".format(self.target_binary, revent_file)
|
vsync_flag = '-V ' if self.device.platform is 'android' else ''
|
||||||
|
command = "{} replay {}{}".format(self.target_binary, vsync_flag, revent_file)
|
||||||
recording = ReventRecording(args.revent)
|
recording = ReventRecording(args.revent)
|
||||||
timeout = ceil(recording.duration) + 30
|
timeout = ceil(recording.duration) + 30
|
||||||
recording.close()
|
recording.close()
|
||||||
|
@ -482,6 +482,7 @@ class ReventWorkload(Workload):
|
|||||||
Workload.__init__(self, device, **kwargs)
|
Workload.__init__(self, device, **kwargs)
|
||||||
devpath = self.device.path
|
devpath = self.device.path
|
||||||
self.on_device_revent_binary = devpath.join(self.device.binaries_directory, 'revent')
|
self.on_device_revent_binary = devpath.join(self.device.binaries_directory, 'revent')
|
||||||
|
self.on_device_HelloJni_apk = devpath.join(self.device.binaries_directory, 'HelloJni.apk')
|
||||||
self.setup_timeout = kwargs.get('setup_timeout', None)
|
self.setup_timeout = kwargs.get('setup_timeout', None)
|
||||||
self.run_timeout = kwargs.get('run_timeout', None)
|
self.run_timeout = kwargs.get('run_timeout', None)
|
||||||
self.revent_setup_file = None
|
self.revent_setup_file = None
|
||||||
@ -494,6 +495,7 @@ class ReventWorkload(Workload):
|
|||||||
state_detector.check_match_state_dependencies()
|
state_detector.check_match_state_dependencies()
|
||||||
|
|
||||||
def setup(self, context):
|
def setup(self, context):
|
||||||
|
self.device.killall('revent', signal='SIGKILL')
|
||||||
self.revent_setup_file = context.resolver.get(ReventFile(self, 'setup'))
|
self.revent_setup_file = context.resolver.get(ReventFile(self, 'setup'))
|
||||||
self.revent_run_file = context.resolver.get(ReventFile(self, 'run'))
|
self.revent_run_file = context.resolver.get(ReventFile(self, 'run'))
|
||||||
devpath = self.device.path
|
devpath = self.device.path
|
||||||
@ -508,13 +510,24 @@ class ReventWorkload(Workload):
|
|||||||
self.run_timeout = self.run_timeout or default_run_timeout
|
self.run_timeout = self.run_timeout or default_run_timeout
|
||||||
|
|
||||||
Workload.setup(self, context)
|
Workload.setup(self, context)
|
||||||
self.device.killall('revent')
|
if self.device.platform is 'android':
|
||||||
command = '{} replay {}'.format(self.on_device_revent_binary, self.on_device_setup_revent)
|
result = self.device.execute('dumpsys activity services | grep "ChoreoService"',
|
||||||
|
check_exit_code=False)
|
||||||
|
if not result or 'com.example.hellojni/.ChoreoService' not in result:
|
||||||
|
self.logger.debug('Starting VSync Service')
|
||||||
|
self.device.execute('am startservice com.example.hellojni/.ChoreoService')
|
||||||
|
time.sleep(5) # Allow time for service to start
|
||||||
|
vsync_flag = '-V ' if self.device.platform is 'android' else ''
|
||||||
|
command = '{} replay {}{}'.format(self.on_device_revent_binary, vsync_flag, self.on_device_setup_revent)
|
||||||
self.device.execute(command, timeout=self.setup_timeout)
|
self.device.execute(command, timeout=self.setup_timeout)
|
||||||
|
|
||||||
def run(self, context):
|
def run(self, context):
|
||||||
command = '{} replay {}'.format(self.on_device_revent_binary, self.on_device_run_revent)
|
if self.device.platform is 'android':
|
||||||
|
self.device.execute('am startservice com.example.hellojni/.ChoreoService')
|
||||||
|
time.sleep(5) # Allow time for service to start
|
||||||
self.logger.debug('Replaying {}'.format(os.path.basename(self.on_device_run_revent)))
|
self.logger.debug('Replaying {}'.format(os.path.basename(self.on_device_run_revent)))
|
||||||
|
vsync_flag = '-V ' if self.device.platform is 'android' else ''
|
||||||
|
command = '{} replay {}{}'.format(self.on_device_revent_binary, vsync_flag, self.on_device_run_revent)
|
||||||
self.device.execute(command, timeout=self.run_timeout)
|
self.device.execute(command, timeout=self.run_timeout)
|
||||||
self.logger.debug('Replay completed.')
|
self.logger.debug('Replay completed.')
|
||||||
|
|
||||||
@ -523,6 +536,7 @@ class ReventWorkload(Workload):
|
|||||||
|
|
||||||
def teardown(self, context):
|
def teardown(self, context):
|
||||||
self.device.killall('revent')
|
self.device.killall('revent')
|
||||||
|
self.device.killall("com.example.hellojni")
|
||||||
self.device.delete_file(self.on_device_setup_revent)
|
self.device.delete_file(self.on_device_setup_revent)
|
||||||
self.device.delete_file(self.on_device_run_revent)
|
self.device.delete_file(self.on_device_run_revent)
|
||||||
|
|
||||||
@ -533,6 +547,10 @@ class ReventWorkload(Workload):
|
|||||||
message = '{} does not exist. '.format(revent_binary)
|
message = '{} does not exist. '.format(revent_binary)
|
||||||
message += 'Please build revent for your system and place it in that location'
|
message += 'Please build revent for your system and place it in that location'
|
||||||
raise WorkloadError(message)
|
raise WorkloadError(message)
|
||||||
|
if self.device.platform is 'android':
|
||||||
|
HelloJni_APK = context.resolver.get(Executable(NO_ONE, self.device.abi, 'HelloJni.apk'))
|
||||||
|
if not os.path.isfile(HelloJni_APK):
|
||||||
|
message = '{} does not exist. '.format(HelloJni_APK)
|
||||||
if not self.revent_setup_file:
|
if not self.revent_setup_file:
|
||||||
# pylint: disable=too-few-format-args
|
# pylint: disable=too-few-format-args
|
||||||
message = '{0}.setup.revent file does not exist, Please provide one for your device, {0}'.format(self.device.name)
|
message = '{0}.setup.revent file does not exist, Please provide one for your device, {0}'.format(self.device.name)
|
||||||
@ -543,6 +561,8 @@ class ReventWorkload(Workload):
|
|||||||
raise WorkloadError(message)
|
raise WorkloadError(message)
|
||||||
|
|
||||||
self.on_device_revent_binary = self.device.install_executable(revent_binary)
|
self.on_device_revent_binary = self.device.install_executable(revent_binary)
|
||||||
|
if self.device.platform is 'android':
|
||||||
|
self.on_device_HelloJni_apk = self.device.install_if_needed(HelloJni_APK)
|
||||||
self.device.push_file(self.revent_run_file, self.on_device_run_revent)
|
self.device.push_file(self.revent_run_file, self.on_device_run_revent)
|
||||||
self.device.push_file(self.revent_setup_file, self.on_device_setup_revent)
|
self.device.push_file(self.revent_setup_file, self.on_device_setup_revent)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user