1 /* 2 * Copyright (C) 2016 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 package com.android.tradefed.invoker; 17 18 import com.android.tradefed.build.IBuildInfo; 19 import com.android.tradefed.config.ConfigurationDescriptor; 20 import com.android.tradefed.device.ITestDevice; 21 import com.android.tradefed.device.ITestDevice.RecoveryMode; 22 import com.android.tradefed.util.MultiMap; 23 import com.android.tradefed.util.UniqueMultiMap; 24 25 import java.io.Serializable; 26 import java.util.HashMap; 27 import java.util.List; 28 import java.util.Map; 29 30 /** 31 * Holds information about the Invocation for the tests to access if needed. Tests should not modify 32 * the context contained here so only getters will be available, except for the context attributes 33 * for reporting purpose. 34 */ 35 public interface IInvocationContext extends Serializable { 36 37 /** Key used for storing associated invocation ID. */ 38 public static final String INVOCATION_ID = "invocation-id"; 39 40 @Deprecated 41 public enum TimingEvent { 42 FETCH_BUILD, 43 SETUP; 44 } 45 46 /** @return associated invocation ID or {@code null} if not linked to an invocation */ getInvocationId()47 public String getInvocationId(); 48 49 /** 50 * Return the number of devices allocated for the invocation. 51 */ getNumDevicesAllocated()52 public int getNumDevicesAllocated(); 53 54 /** 55 * Add a ITestDevice to be tracked by the meta data when the device is allocated. 56 * will set the build info to null in the map. 57 * 58 * @param deviceName the device configuration name to associate with the {@link ITestDevice} 59 * @param testDevice to be added to the allocated devices. 60 */ addAllocatedDevice(String deviceName, ITestDevice testDevice)61 public void addAllocatedDevice(String deviceName, ITestDevice testDevice); 62 63 /** 64 * Track a map of configuration device name associated to a {@link ITestDevice}. Doesn't clear 65 * the previous tracking before adding. 66 * 67 * @param deviceWithName the {@link Map} of additional device to track 68 */ addAllocatedDevice(Map<String, ITestDevice> deviceWithName)69 public void addAllocatedDevice(Map<String, ITestDevice> deviceWithName); 70 71 /** 72 * Return the map of Device/build info association 73 */ getDeviceBuildMap()74 public Map<ITestDevice, IBuildInfo> getDeviceBuildMap(); 75 76 /** 77 * Return all the allocated device tracked for this invocation. 78 */ getDevices()79 public List<ITestDevice> getDevices(); 80 81 /** 82 * Return all the {@link IBuildInfo} tracked for this invocation. 83 */ getBuildInfos()84 public List<IBuildInfo> getBuildInfos(); 85 86 /** 87 * Return the list of serials of the device tracked in this invocation 88 */ getSerials()89 public List<String> getSerials(); 90 91 /** 92 * Return the list of device config names of the device tracked in this invocation 93 */ getDeviceConfigNames()94 public List<String> getDeviceConfigNames(); 95 96 /** 97 * Return the {@link ITestDevice} associated with the device configuration name provided. 98 */ getDevice(String deviceName)99 public ITestDevice getDevice(String deviceName); 100 101 /** 102 * Returns the {@link ITestDevice} associated with the serial provided. 103 * Refrain from using too much as it's not the fastest lookup. 104 */ getDeviceBySerial(String serial)105 public ITestDevice getDeviceBySerial(String serial); 106 107 /** 108 * Returns the name of the device set in the xml configuration from the {@link ITestDevice}. 109 * Returns null, if ITestDevice cannot be matched. 110 */ getDeviceName(ITestDevice device)111 public String getDeviceName(ITestDevice device); 112 113 /** 114 * Returns the name of device set in the xml configuration from the {@link IBuildInfo}. Returns 115 * null if the IBuildInfo cannot be matched 116 */ getBuildInfoName(IBuildInfo info)117 public String getBuildInfoName(IBuildInfo info); 118 119 /** 120 * Return the {@link IBuildInfo} associated with the device configuration name provided. Returns 121 * null, if the deviceName cannot be matched. 122 */ getBuildInfo(String deviceName)123 public IBuildInfo getBuildInfo(String deviceName); 124 125 /** 126 * Return the {@link IBuildInfo} associated with the {@link ITestDevice} 127 */ getBuildInfo(ITestDevice testDevice)128 public IBuildInfo getBuildInfo(ITestDevice testDevice); 129 130 /** 131 * Add a {@link IBuildInfo} to be tracked with the device configuration name. 132 * 133 * @param deviceName the device configuration name 134 * @param buildinfo a {@link IBuildInfo} associated to the device configuration name. 135 */ addDeviceBuildInfo(String deviceName, IBuildInfo buildinfo)136 public void addDeviceBuildInfo(String deviceName, IBuildInfo buildinfo); 137 138 /** 139 * Add an Invocation attribute. 140 */ addInvocationAttribute(String attributeName, String attributeValue)141 public void addInvocationAttribute(String attributeName, String attributeValue); 142 143 /** Add several invocation attributes at once through a {@link UniqueMultiMap}. */ addInvocationAttributes(MultiMap<String, String> attributesMap)144 public void addInvocationAttributes(MultiMap<String, String> attributesMap); 145 146 /** Returns a copy of the map containing all the invocation attributes. */ getAttributes()147 public MultiMap<String, String> getAttributes(); 148 149 /** Add a invocation timing metric. */ 150 @Deprecated addInvocationTimingMetric(TimingEvent timingEvent, Long durationMillis)151 public default void addInvocationTimingMetric(TimingEvent timingEvent, Long durationMillis) { 152 // Do nothing 153 } 154 155 /** Returns the map containing the invocation timing metrics. */ 156 @Deprecated getInvocationTimingMetrics()157 public default Map<TimingEvent, Long> getInvocationTimingMetrics() { 158 return new HashMap<>(); 159 } 160 161 /** Sets the descriptor associated with the test configuration that launched the invocation */ setConfigurationDescriptor(ConfigurationDescriptor configurationDescriptor)162 public void setConfigurationDescriptor(ConfigurationDescriptor configurationDescriptor); 163 164 /** 165 * Returns the descriptor associated with the test configuration that launched the invocation 166 */ getConfigurationDescriptor()167 public ConfigurationDescriptor getConfigurationDescriptor(); 168 169 /** Sets the invocation context of module while being executed as part of a suite. */ setModuleInvocationContext(IInvocationContext invocationContext)170 public void setModuleInvocationContext(IInvocationContext invocationContext); 171 172 /** Returns the invocation context of module while being executed as part of a suite. */ getModuleInvocationContext()173 public IInvocationContext getModuleInvocationContext(); 174 175 /** Returns the invocation test-tag. */ getTestTag()176 public String getTestTag(); 177 178 /** 179 * Sets the invocation test-tag. 180 */ setTestTag(String testTag)181 public void setTestTag(String testTag); 182 183 /** Returns whether or not the devices were released early and won't be used anymore. */ wasReleasedEarly()184 public boolean wasReleasedEarly(); 185 186 /** Mark the devices are getting released early. */ markReleasedEarly()187 public void markReleasedEarly(); 188 189 /** 190 * Sets the {@link RecoveryMode} of all the devices part of the context 191 */ setRecoveryModeForAllDevices(RecoveryMode mode)192 public void setRecoveryModeForAllDevices(RecoveryMode mode); 193 194 /** 195 * Add a serial to be tracked as assigned to one of the shard running some tests. 196 * 197 * @param index the index of the shard using the serials 198 * @param serials The list of serials to be tracked. 199 */ addSerialsFromShard(Integer index, List<String> serials)200 public void addSerialsFromShard(Integer index, List<String> serials); 201 202 /** 203 * Returns the Map of all tracked serials and their shard involved in sharding. Empty if not a 204 * sharded invocation. 205 */ getShardsSerials()206 public Map<Integer, List<String>> getShardsSerials(); 207 208 /** Serialize a the context instance into a protobuf. */ toProto()209 public com.android.tradefed.invoker.proto.InvocationContext.Context toProto(); 210 211 /** 212 * A convenient method for retrieving invocation context attribute as a single key-value pair. 213 * Never return null. 214 * 215 * @return empty string when key doesn't exist, the value otherwise. 216 */ getAttribute(String key)217 public default String getAttribute(String key) { 218 List<String> values = getAttributes().get(key); 219 if (values == null || values.isEmpty()) { 220 return ""; 221 } 222 String value = values.get(0); 223 if (value == null) { 224 return ""; 225 } 226 return value; 227 } 228 } 229