[Settings] Replace ImsDirectQuery

This is a code refactor to replace
1. Legacy ImsQuery into ImsExecutorQuery
2. ImsDirectQuery into ImsQuery
3. SystemTty into Tty

Bug: 140542283
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=Enhanced4gBasePreferenceControllerTest
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=Enhanced4gLteSliceHelperTest
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=VideoCallingPreferenceControllerTest
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=WifiCallingPreferenceControllerTest
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=WifiCallingSettingsForSubTest
Test: m RunSettingsRoboTests -j ROBOTEST_FILTER=WifiCallingSliceHelperTest
Change-Id: I239021c60fff47de307ac7e21641bee56e205861
This commit is contained in:
Bonian Chen
2020-01-28 10:54:44 +08:00
parent 613371047b
commit c820dc191c
11 changed files with 53 additions and 178 deletions

View File

@@ -1,32 +0,0 @@
/*
* 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 com.android.settings.network.ims;
/**
* An interface for direct querying IMS, and return {@code boolean}
*/
public interface ImsDirectQuery {
/**
* Interface for performing IMS status/configuration query through public APIs
*
* @return result of query in boolean
*/
boolean directQuery();
}

View File

@@ -1,56 +0,0 @@
/*
* 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 com.android.settings.network.ims;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Future;
import java.util.concurrent.RejectedExecutionException;
/**
* An implementation of {@code ImsQuery} and {@code ImsDirectQuery}.
*/
abstract class ImsDirectQueryImpl implements ImsQuery, ImsDirectQuery, Callable<Boolean> {
/**
* Implementation of interface {@code ImsQuery}
*
* @param executors {@code ExecutorService} which allows to submit {@code ImsQuery} when
* required
* @return result of query in format of {@code Future<Boolean>}
*/
public Future<Boolean> query(ExecutorService executors) throws RejectedExecutionException {
return executors.submit(this);
}
/**
* Implementation of interface {@code ImsDirectQuery}
*
* @return result of query
*/
public boolean directQuery() {
return call();
}
/**
* Query running within a {@code Callable}
*
* @return result of query
*/
public abstract Boolean call();
}

View File

@@ -16,23 +16,17 @@
package com.android.settings.network.ims;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Future;
import java.util.concurrent.RejectedExecutionException;
/**
* An interface for querying IMS, and return {@code Future<Boolean>}
* An interface for direct querying IMS, and return {@link boolean}
*/
public interface ImsQuery {
/**
* Interface for performing IMS status/configuration query through ExecutorService
* Interface for performing IMS status/configuration query through public APIs
*
* @param executors {@code ExecutorService} which allows to submit {@code ImsQuery} when
* required
* @return result of query in format of {@code Future<Boolean>}
* @return result of query in boolean
*/
Future<Boolean> query(ExecutorService executors) throws RejectedExecutionException;
boolean query();
}

View File

@@ -16,8 +16,6 @@
package com.android.settings.network.ims;
import android.content.Context;
import androidx.annotation.VisibleForTesting;
/**
@@ -26,12 +24,7 @@ import androidx.annotation.VisibleForTesting;
abstract class ImsQueryController {
@VisibleForTesting
ImsDirectQuery isSystemTtyEnabled(Context context) {
return new ImsQuerySystemTtyStat(context);
}
@VisibleForTesting
ImsDirectQuery isTtyOnVolteEnabled(int subId) {
ImsQuery isTtyOnVolteEnabled(int subId) {
return new ImsQueryTtyOnVolteStat(subId);
}
}

View File

@@ -1,47 +0,0 @@
/*
* 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 com.android.settings.network.ims;
import android.content.Context;
import android.telecom.TelecomManager;
/**
* An {@code ImsQuery} for accessing system TTY stat
*/
public class ImsQuerySystemTtyStat extends ImsDirectQueryImpl {
/**
* Constructor
* @param context context of activity
*/
public ImsQuerySystemTtyStat(Context context) {
mContext = context;
}
private volatile Context mContext;
/**
* Query running within a {@code Callable}
*
* @return result of query
*/
public Boolean call() {
final TelecomManager telecomManager = mContext.getSystemService(TelecomManager.class);
return (telecomManager.getCurrentTtyMode() != TelecomManager.TTY_MODE_OFF);
}
}

View File

@@ -20,9 +20,9 @@ import android.telephony.ims.ImsMmTelManager;
/**
* An {@code ImsQuery} for accessing IMS tty on VoLte stat
* An {@link ImsQuery} for accessing IMS tty on VoLte stat
*/
public class ImsQueryTtyOnVolteStat extends ImsDirectQueryImpl {
public class ImsQueryTtyOnVolteStat implements ImsQuery {
/**
* Constructor
@@ -35,11 +35,11 @@ public class ImsQueryTtyOnVolteStat extends ImsDirectQueryImpl {
private volatile int mSubId;
/**
* Query running within a {@code Callable}
* Implementation of interface {@link ImsQuery#query()}
*
* @return result of query
*/
public Boolean call() {
public boolean query() {
final ImsMmTelManager imsMmTelManager = ImsMmTelManager.createForSubscriptionId(mSubId);
return imsMmTelManager.isTtyOverVolteEnabled();
}

View File

@@ -20,9 +20,9 @@ import android.telephony.ims.ImsMmTelManager;
/**
* An {@code ImsQuery} for accessing IMS VT enabled settings from user
* An {@link ImsQuery} for accessing IMS VT enabled settings from user
*/
public class ImsQueryVtUserSetting extends ImsDirectQueryImpl {
public class ImsQueryVtUserSetting implements ImsQuery {
/**
* Constructor
@@ -35,11 +35,11 @@ public class ImsQueryVtUserSetting extends ImsDirectQueryImpl {
private volatile int mSubId;
/**
* Query running within a {@code Callable}
* Implementation of interface {@link ImsQuery#query()}
*
* @return result of query
*/
public Boolean call() {
public boolean query() {
final ImsMmTelManager imsMmTelManager = ImsMmTelManager.createForSubscriptionId(mSubId);
return imsMmTelManager.isVtSettingEnabled();
}

View File

@@ -20,9 +20,9 @@ import android.telephony.ims.ImsMmTelManager;
/**
* An {@code ImsQuery} for accessing IMS WFC enabled settings from user
* An {@link ImsQuery} for accessing IMS WFC enabled settings from user
*/
public class ImsQueryWfcUserSetting extends ImsDirectQueryImpl {
public class ImsQueryWfcUserSetting implements ImsQuery {
/**
* Constructor
@@ -35,11 +35,11 @@ public class ImsQueryWfcUserSetting extends ImsDirectQueryImpl {
private volatile int mSubId;
/**
* Query running within a {@code Callable}
* Implementation of interface {@link ImsQuery#query()}
*
* @return result of query
*/
public Boolean call() {
public boolean query() {
final ImsMmTelManager imsMmTelManager = ImsMmTelManager.createForSubscriptionId(mSubId);
return imsMmTelManager.isVoWiFiSettingEnabled();
}

View File

@@ -17,8 +17,11 @@
package com.android.settings.network.ims;
import android.content.Context;
import android.telecom.TelecomManager;
import android.telephony.SubscriptionManager;
import androidx.annotation.VisibleForTesting;
import com.android.ims.ImsManager;
import com.android.settings.network.SubscriptionUtil;
@@ -34,7 +37,7 @@ public class VolteQueryImsState extends ImsQueryController {
/**
* Constructor
*
* @param context {@code Context}
* @param context {@link Context}
* @param subId subscription's id
*/
public VolteQueryImsState(Context context, int subId) {
@@ -52,8 +55,14 @@ public class VolteQueryImsState extends ImsQueryController {
return false;
}
return ((!isSystemTtyEnabled(mContext).directQuery())
|| (isTtyOnVolteEnabled(mSubId).directQuery()));
return ((!isTtyEnabled(mContext))
|| (isTtyOnVolteEnabled(mSubId).query()));
}
@VisibleForTesting
boolean isTtyEnabled(Context context) {
final TelecomManager telecomManager = context.getSystemService(TelecomManager.class);
return (telecomManager.getCurrentTtyMode() != TelecomManager.TTY_MODE_OFF);
}
/**

View File

@@ -17,6 +17,7 @@
package com.android.settings.network.ims;
import android.content.Context;
import android.telecom.TelecomManager;
import android.telephony.SubscriptionManager;
import androidx.annotation.VisibleForTesting;
@@ -32,7 +33,7 @@ public class VtQueryImsState extends ImsQueryController {
/**
* Constructor
*
* @param context {@code Context}
* @param context {@link Context}
* @param subId subscription's id
*/
public VtQueryImsState(Context context, int subId) {
@@ -44,7 +45,7 @@ public class VtQueryImsState extends ImsQueryController {
* Implementation of ImsQueryController#isEnabledByUser(int subId)
*/
@VisibleForTesting
ImsDirectQuery isEnabledByUser(int subId) {
ImsQuery isEnabledByUser(int subId) {
return new ImsQueryVtUserSetting(subId);
}
@@ -57,8 +58,14 @@ public class VtQueryImsState extends ImsQueryController {
if (!SubscriptionManager.isValidSubscriptionId(mSubId)) {
return false;
}
return ((!isSystemTtyEnabled(mContext).directQuery())
|| (isTtyOnVolteEnabled(mSubId).directQuery()));
return ((!isTtyEnabled(mContext))
|| (isTtyOnVolteEnabled(mSubId).query()));
}
@VisibleForTesting
boolean isTtyEnabled(Context context) {
final TelecomManager telecomManager = context.getSystemService(TelecomManager.class);
return (telecomManager.getCurrentTtyMode() != TelecomManager.TTY_MODE_OFF);
}
/**
@@ -70,6 +77,6 @@ public class VtQueryImsState extends ImsQueryController {
if (!SubscriptionManager.isValidSubscriptionId(mSubId)) {
return false;
}
return isEnabledByUser(mSubId).directQuery();
return isEnabledByUser(mSubId).query();
}
}

View File

@@ -17,6 +17,7 @@
package com.android.settings.network.ims;
import android.content.Context;
import android.telecom.TelecomManager;
import android.telephony.SubscriptionManager;
import androidx.annotation.VisibleForTesting;
@@ -32,7 +33,7 @@ public class WifiCallingQueryImsState extends ImsQueryController {
/**
* Constructor
*
* @param context {@code Context}
* @param context {@link Context}
* @param subId subscription's id
*/
public WifiCallingQueryImsState(Context context, int subId) {
@@ -44,7 +45,7 @@ public class WifiCallingQueryImsState extends ImsQueryController {
* Implementation of ImsQueryController#isEnabledByUser(int subId)
*/
@VisibleForTesting
ImsDirectQuery isEnabledByUser(int subId) {
ImsQuery isEnabledByUser(int subId) {
return new ImsQueryWfcUserSetting(subId);
}
@@ -58,8 +59,14 @@ public class WifiCallingQueryImsState extends ImsQueryController {
return false;
}
return ((!isSystemTtyEnabled(mContext).directQuery())
|| (isTtyOnVolteEnabled(mSubId).directQuery()));
return ((!isTtyEnabled(mContext))
|| (isTtyOnVolteEnabled(mSubId).query()));
}
@VisibleForTesting
boolean isTtyEnabled(Context context) {
final TelecomManager telecomManager = context.getSystemService(TelecomManager.class);
return (telecomManager.getCurrentTtyMode() != TelecomManager.TTY_MODE_OFF);
}
/**
@@ -71,6 +78,6 @@ public class WifiCallingQueryImsState extends ImsQueryController {
if (!SubscriptionManager.isValidSubscriptionId(mSubId)) {
return false;
}
return isEnabledByUser(mSubId).directQuery();
return isEnabledByUser(mSubId).query();
}
}