aboutsummaryrefslogtreecommitdiff
path: root/src/com/android/tradefed/targetprep/companion/CompanionDeviceTracker.java
blob: 2edd1f55e652f7e3e52d05b29dc7501439ecd4a2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*
 * Copyright (C) 2014 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.tradefed.targetprep.companion;

import com.android.tradefed.config.GlobalConfiguration;
import com.android.tradefed.device.DeviceSelectionOptions;
import com.android.tradefed.device.FreeDeviceState;
import com.android.tradefed.device.IDeviceManager;
import com.android.tradefed.device.ITestDevice;
import com.android.tradefed.device.TestDeviceState;
import com.android.tradefed.log.LogUtil.CLog;

import java.util.HashMap;
import java.util.Map;

/**
 * A class for allocating and freeing companion devices
 */
public class CompanionDeviceTracker {

    private static CompanionDeviceTracker sInst = null;

    private Map<ITestDevice, ITestDevice> mDeviceMapping = null;

    private CompanionDeviceTracker() {
        mDeviceMapping = new HashMap<ITestDevice, ITestDevice>();
    }

    /**
     * Retrieves singleton instance of the tracker
     */
    public static CompanionDeviceTracker getInstance() {
        if (sInst == null) {
            sInst = new CompanionDeviceTracker();
        }
        return sInst;
    }

    /**
     * Allocate a companion device based on selection criteria.
     *
     * @param device the primary device. used to identify the companion device
     * @param opt selection criteria
     * @return the device allocated or <code>null</code> if none available
     */
    public ITestDevice allocateCompanionDevice(ITestDevice device, DeviceSelectionOptions opt) {
        ITestDevice companion = getDeviceManager().allocateDevice(opt);
        if (companion != null) {
            if (mDeviceMapping.containsKey(device)) {
                CLog.w("device %s already has an allocated companion %s",
                        device.getSerialNumber(), mDeviceMapping.get(companion).getSerialNumber());
            }
            CLog.i("allocated companion device %s for primary device %s",
                    companion.getSerialNumber(), device.getSerialNumber());
            mDeviceMapping.put(device, companion);
        }
        return companion;
    }

    /**
     * Free the companion device as identified by the primary device
     * @param device the primary device whose corresponding companion device should be freed
     * @throws IllegalStateException if no companion devices
     */
    public void freeCompanionDevice(ITestDevice device) {
        if (!mDeviceMapping.containsKey(device)) {
            CLog.w("primary device %s has no tracked companion device", device.getSerialNumber());
            return;
        }
        ITestDevice companion = mDeviceMapping.remove(device);
        FreeDeviceState deviceState = FreeDeviceState.AVAILABLE;
        if (!TestDeviceState.ONLINE.equals(companion.getDeviceState())) {
            //If the device is offline at the end of the test
            deviceState = FreeDeviceState.UNAVAILABLE;
        }
        getDeviceManager().freeDevice(companion, deviceState);
        CLog.i("freed companion device %s for primary device %s",
                companion.getSerialNumber(), device.getSerialNumber());
    }

    /**
     * Retrieve the allocated companion device as identified by the primary device
     * @param device the primary device that the companion device is allocated with
     * @return the companion device or <code>null</code> if not found
     */
    public ITestDevice getCompanionDevice(ITestDevice device) {
        return mDeviceMapping.get(device);
    }

    private IDeviceManager getDeviceManager() {
        return GlobalConfiguration.getDeviceManagerInstance();
    }

}