/* * Copyright (C) 2017 The Android Open Source Project * * 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. */ package com.android.example; import com.android.tradefed.config.Option; import com.android.tradefed.device.DeviceNotAvailableException; import com.android.tradefed.invoker.TestInformation; import com.android.tradefed.metrics.proto.MetricMeasurement.Metric; import com.android.tradefed.result.ITestInvocationListener; import com.android.tradefed.result.TestDescription; import com.android.tradefed.testtype.IRemoteTest; import java.util.HashMap; /** * Reboots the device and verifies it comes back online. This simple reboot tests acts as an example * integration test. */ public class RebootTest implements IRemoteTest { @Option(name = "num-of-reboots", description = "Number of times to reboot the device.") private int mNumDeviceReboots = 1; /** {@inheritDoc} */ @Override public void run(TestInformation testInfo, ITestInvocationListener listener) throws DeviceNotAvailableException { long start; HashMap emptyMap = new HashMap<>(); TestDescription testId; start = System.currentTimeMillis(); listener.testRunStarted(String.format("#%d device reboots", mNumDeviceReboots), mNumDeviceReboots); try { for (int testCount = 0; testCount < mNumDeviceReboots; testCount++) { testId = new TestDescription("RebootTest", String.format("RebootLoop #%d", testCount)); listener.testStarted(testId); try { testInfo.getDevice().reboot(); } catch (DeviceNotAvailableException e) { listener.testFailed(testId, "Failed to reboot."); } finally { listener.testEnded(testId, emptyMap); } } } finally { listener.testRunEnded(System.currentTimeMillis() - start, emptyMap); } } }