#    Copyright 2015 ARM Limited
#
# Licensed under the Apache License, Version 2.0 (the 'License');
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an 'AS IS' BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# pylint: disable=attribute-defined-outside-init
import os

from time import sleep

from wlauto import Workload, Parameter
from wlauto import File
from wlauto.exceptions import ConfigError
from wlauto.utils.android import ApkInfo


class ApkLaunchWorkload(Workload):
    name = 'apklaunch'
    description = '''
    Installs and runs a .apk file, waits wait_time_seconds, and tests if the app
    has started successfully.
    '''
    supported_platforms = ['android']

    parameters = [
        Parameter('apk_file', description='Name to the .apk to run', mandatory=True),
        Parameter('uninstall_required', kind=bool, default=False,
                  description='Set to true if the package should be uninstalled'),
        Parameter('wait_time_seconds', kind=int, default=0,
                  description='Seconds to wait before testing if the app is still alive')
    ]

    def setup(self, context):
        apk_file = context.resolver.get(File(self, self.apk_file))
        self.package = ApkInfo(apk_file).package  # pylint: disable=attribute-defined-outside-init

        self.logger.info('Installing {}'.format(apk_file))
        return self.device.install(apk_file)

    def run(self, context):
        self.logger.info('Starting {}'.format(self.package))
        self.device.execute('am start -W {}'.format(self.package))

        self.logger.info('Waiting {} seconds'.format(self.wait_time_seconds))
        sleep(self.wait_time_seconds)

    def update_result(self, context):
        app_is_running = bool([p for p in self.device.ps() if p.name == self.package])
        context.result.add_metric('ran_successfully', app_is_running)

    def teardown(self, context):
        if self.uninstall_required:
            self.logger.info('Uninstalling {}'.format(self.package))
            self.device.execute('pm uninstall {}'.format(self.package))