| /* |
| * Copyright (C) 2020 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 android.location.cts.common; |
| |
| import android.location.Location; |
| import android.location.LocationListener; |
| import android.location.LocationManager; |
| import android.os.Bundle; |
| |
| import java.util.ArrayList; |
| import java.util.List; |
| import java.util.concurrent.ConcurrentLinkedQueue; |
| import java.util.concurrent.CountDownLatch; |
| |
| /** |
| * Used for receiving notifications from the LocationManager when the location has changed. |
| */ |
| public class TestLocationListener implements LocationListener { |
| private volatile boolean mProviderEnabled; |
| private volatile boolean mLocationReceived; |
| |
| // Timeout in sec for count down latch wait |
| private static final int TIMEOUT_IN_SEC = 120; |
| private CountDownLatch mCountDownLatch; |
| private final ConcurrentLinkedQueue<Location> mLocationList; |
| |
| public TestLocationListener(int locationToCollect) { |
| mCountDownLatch = new CountDownLatch(locationToCollect); |
| mLocationList = new ConcurrentLinkedQueue<>(); |
| } |
| |
| @Override |
| public synchronized void onLocationChanged(Location location) { |
| mLocationReceived = true; |
| mLocationList.add(location); |
| mCountDownLatch.countDown(); |
| } |
| |
| /** Clears the received locations in {@link #mLocationList} */ |
| public synchronized void clearReceivedLocationsAndResetCounter(int locationToCollect) { |
| mLocationList.clear(); |
| mCountDownLatch = new CountDownLatch(locationToCollect); |
| } |
| |
| @Override |
| public void onStatusChanged(String s, int i, Bundle bundle) { |
| } |
| |
| @Override |
| public void onProviderEnabled(String s) { |
| if (LocationManager.GPS_PROVIDER.equals(s)) { |
| mProviderEnabled = true; |
| } |
| } |
| |
| @Override |
| public void onProviderDisabled(String s) { |
| if (LocationManager.GPS_PROVIDER.equals(s)) { |
| mProviderEnabled = false; |
| } |
| } |
| |
| public boolean await() throws InterruptedException { |
| return TestUtils.waitFor(mCountDownLatch, TIMEOUT_IN_SEC); |
| } |
| |
| public boolean await(int timeInSec) throws InterruptedException { |
| return TestUtils.waitFor(mCountDownLatch, timeInSec); |
| } |
| |
| /** |
| * Get the list of locations received. |
| * |
| * Makes a copy of {@code mLocationList}. New locations received after this call is |
| * made are not reflected in the returned list so that the returned list can be safely |
| * iterated without getting a ConcurrentModificationException. Occasionally, |
| * even after calling TestLocationManager.removeLocationUpdates(), the location listener |
| * can receive one or two location updates. |
| */ |
| public List<Location> getReceivedLocationList(){ |
| return new ArrayList(mLocationList); |
| } |
| |
| /** |
| * Check if location provider is enabled. |
| * |
| * @return {@code true} if the location provider is enabled and {@code false} |
| * if location provider is disabled. |
| */ |
| public boolean isProviderEnabled() { |
| return mProviderEnabled; |
| } |
| |
| /** |
| * Check if the location is received. |
| * |
| * @return {@code true} if the location is received and {@code false} |
| * if location is not received. |
| */ |
| public boolean isLocationReceived() { |
| return mLocationReceived; |
| } |
| } |