Migrate PaymentSettings to DashboardFragment
- Move preference related logic to controllers. - Add some test cases for controllers. Test: manual Test: make RunSettingsRoboTests -j ROBOTEST_FILTER=com.android.settings.nfc make RunSettingsRoboTests -j ROBOTEST_FILTER=com.android.settings.core atest SettingsGatewayTest UniquePreferenceTest Change-Id: I061a194c170f63fab51974f26c24be43d67d6f6f
This commit is contained in:
@@ -16,5 +16,20 @@
|
|||||||
|
|
||||||
<PreferenceScreen
|
<PreferenceScreen
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:key="nfc_payment_settings_screen"
|
||||||
android:title="@string/nfc_payment_settings_title">
|
android:title="@string/nfc_payment_settings_title">
|
||||||
|
|
||||||
|
<com.android.settings.nfc.NfcPaymentPreference
|
||||||
|
android:key="nfc_payment"
|
||||||
|
android:title="@string/nfc_payment_default"
|
||||||
|
android:dialogTitle="@string/nfc_payment_pay_with"
|
||||||
|
android:widgetLayout="@layout/preference_widget_gear"
|
||||||
|
settings:controller="com.android.settings.nfc.NfcPaymentPreferenceController"/>
|
||||||
|
|
||||||
|
<DropDownPreference
|
||||||
|
android:key="nfc_foreground"
|
||||||
|
android:title="@string/nfc_payment_use_default"
|
||||||
|
settings:controller="com.android.settings.nfc.NfcForegroundPreferenceController"/>
|
||||||
|
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
@@ -19,11 +19,8 @@ import android.content.Context;
|
|||||||
import android.database.ContentObserver;
|
import android.database.ContentObserver;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.nfc.NfcAdapter;
|
import android.nfc.NfcAdapter;
|
||||||
import android.nfc.NfcManager;
|
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
|
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
@@ -31,7 +28,8 @@ import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
|||||||
import com.android.settingslib.core.lifecycle.events.OnPause;
|
import com.android.settingslib.core.lifecycle.events.OnPause;
|
||||||
import com.android.settingslib.core.lifecycle.events.OnResume;
|
import com.android.settingslib.core.lifecycle.events.OnResume;
|
||||||
|
|
||||||
import java.util.List;
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
public abstract class BaseNfcPreferenceController extends AbstractPreferenceController
|
public abstract class BaseNfcPreferenceController extends AbstractPreferenceController
|
||||||
implements PreferenceControllerMixin, LifecycleObserver, OnResume, OnPause {
|
implements PreferenceControllerMixin, LifecycleObserver, OnResume, OnPause {
|
||||||
@@ -65,13 +63,6 @@ public abstract class BaseNfcPreferenceController extends AbstractPreferenceCont
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateNonIndexableKeys(List<String> keys) {
|
|
||||||
if (!isAvailable()) {
|
|
||||||
keys.add(getPreferenceKey());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public boolean isAvailable() {
|
||||||
return mNfcAdapter != null;
|
return mNfcAdapter != null;
|
||||||
|
@@ -1,65 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2015 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.nfc;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import androidx.preference.DropDownPreference;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
public class NfcForegroundPreference extends DropDownPreference implements
|
|
||||||
PaymentBackend.Callback, Preference.OnPreferenceChangeListener {
|
|
||||||
|
|
||||||
private final PaymentBackend mPaymentBackend;
|
|
||||||
public NfcForegroundPreference(Context context, PaymentBackend backend) {
|
|
||||||
super(context);
|
|
||||||
mPaymentBackend = backend;
|
|
||||||
mPaymentBackend.registerCallback(this);
|
|
||||||
|
|
||||||
setTitle(getContext().getString(R.string.nfc_payment_use_default));
|
|
||||||
setEntries(new CharSequence[] {
|
|
||||||
getContext().getString(R.string.nfc_payment_favor_open),
|
|
||||||
getContext().getString(R.string.nfc_payment_favor_default)
|
|
||||||
});
|
|
||||||
setEntryValues(new CharSequence[] { "1", "0" });
|
|
||||||
refresh();
|
|
||||||
setOnPreferenceChangeListener(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPaymentAppsChanged() {
|
|
||||||
refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
void refresh() {
|
|
||||||
boolean foregroundMode = mPaymentBackend.isForegroundMode();
|
|
||||||
if (foregroundMode) {
|
|
||||||
setValue("1");
|
|
||||||
} else {
|
|
||||||
setValue("0");
|
|
||||||
}
|
|
||||||
setSummary(getEntry());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
|
||||||
String newValueString = (String) newValue;
|
|
||||||
setSummary(getEntries()[findIndexOfValue(newValueString)]);
|
|
||||||
mPaymentBackend.setForegroundMode(Integer.parseInt(newValueString) != 0);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -0,0 +1,129 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2018 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.nfc;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStop;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import androidx.preference.DropDownPreference;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
public class NfcForegroundPreferenceController extends BasePreferenceController implements
|
||||||
|
PaymentBackend.Callback, Preference.OnPreferenceChangeListener,
|
||||||
|
LifecycleObserver, OnStart, OnStop {
|
||||||
|
|
||||||
|
private DropDownPreference mPreference;
|
||||||
|
private PaymentBackend mPaymentBackend;
|
||||||
|
|
||||||
|
public NfcForegroundPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPaymentBackend(PaymentBackend backend) {
|
||||||
|
mPaymentBackend = backend;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStart() {
|
||||||
|
if (mPaymentBackend != null) {
|
||||||
|
mPaymentBackend.registerCallback(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStop() {
|
||||||
|
if (mPaymentBackend != null) {
|
||||||
|
mPaymentBackend.unregisterCallback(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
final PackageManager pm = mContext.getPackageManager();
|
||||||
|
if (!pm.hasSystemFeature(PackageManager.FEATURE_NFC)) {
|
||||||
|
return DISABLED_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
if (mPaymentBackend == null) {
|
||||||
|
return DISABLED_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
final List<PaymentBackend.PaymentAppInfo> appInfos = mPaymentBackend.getPaymentAppInfos();
|
||||||
|
return (appInfos != null && !appInfos.isEmpty())
|
||||||
|
? AVAILABLE
|
||||||
|
: DISABLED_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = (DropDownPreference) screen.findPreference(getPreferenceKey());
|
||||||
|
if (mPreference == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mPreference.setEntries(new CharSequence[] {
|
||||||
|
mContext.getText(R.string.nfc_payment_favor_open),
|
||||||
|
mContext.getText(R.string.nfc_payment_favor_default)
|
||||||
|
});
|
||||||
|
mPreference.setEntryValues(new CharSequence[] {"1", "0"});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPaymentAppsChanged() {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
if (preference instanceof DropDownPreference) {
|
||||||
|
((DropDownPreference) preference).setValue(
|
||||||
|
mPaymentBackend.isForegroundMode() ? "1" : "0");
|
||||||
|
}
|
||||||
|
super.updateState(preference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence getSummary() {
|
||||||
|
return mPreference.getEntry();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
|
if (!(preference instanceof DropDownPreference)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final DropDownPreference pref = (DropDownPreference) preference;
|
||||||
|
final String newValueString = (String) newValue;
|
||||||
|
pref.setSummary(pref.getEntries()[pref.findIndexOfValue(newValueString)]);
|
||||||
|
mPaymentBackend.setForegroundMode(Integer.parseInt(newValueString) != 0);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateNonIndexableKeys(List<String> keys) {
|
||||||
|
final String key = getPreferenceKey();
|
||||||
|
if (!TextUtils.isEmpty(key)) {
|
||||||
|
keys.add(key);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -16,80 +16,49 @@
|
|||||||
package com.android.settings.nfc;
|
package com.android.settings.nfc;
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
import android.content.ActivityNotFoundException;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.app.Dialog;
|
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.util.AttributeSet;
|
||||||
import androidx.preference.PreferenceViewHolder;
|
|
||||||
import android.util.Log;
|
|
||||||
import android.view.LayoutInflater;
|
|
||||||
import android.view.View;
|
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.widget.BaseAdapter;
|
|
||||||
import android.widget.CompoundButton;
|
|
||||||
import android.widget.ImageView;
|
|
||||||
import android.widget.RadioButton;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settings.nfc.PaymentBackend.PaymentAppInfo;
|
|
||||||
import com.android.settingslib.CustomDialogPreference;
|
import com.android.settingslib.CustomDialogPreference;
|
||||||
|
|
||||||
import java.util.List;
|
import androidx.preference.PreferenceViewHolder;
|
||||||
|
|
||||||
public class NfcPaymentPreference extends CustomDialogPreference implements
|
public class NfcPaymentPreference extends CustomDialogPreference {
|
||||||
PaymentBackend.Callback, View.OnClickListener {
|
|
||||||
|
|
||||||
private static final String TAG = "NfcPaymentPreference";
|
private Listener mListener;
|
||||||
|
|
||||||
private final NfcPaymentAdapter mAdapter;
|
interface Listener {
|
||||||
private final Context mContext;
|
void onBindViewHolder(PreferenceViewHolder view);
|
||||||
private final LayoutInflater mLayoutInflater;
|
|
||||||
private final PaymentBackend mPaymentBackend;
|
|
||||||
|
|
||||||
// Fields below only modified on UI thread
|
void onPrepareDialogBuilder(AlertDialog.Builder builder,
|
||||||
private ImageView mSettingsButtonView;
|
DialogInterface.OnClickListener listener);
|
||||||
|
}
|
||||||
|
|
||||||
public NfcPaymentPreference(Context context, PaymentBackend backend) {
|
public NfcPaymentPreference(Context context, AttributeSet attrs, int defStyleAttr,
|
||||||
super(context, null);
|
int defStyleRes) {
|
||||||
mPaymentBackend = backend;
|
super(context, attrs, defStyleAttr, defStyleRes);
|
||||||
mContext = context;
|
}
|
||||||
backend.registerCallback(this);
|
|
||||||
mAdapter = new NfcPaymentAdapter();
|
|
||||||
setDialogTitle(context.getString(R.string.nfc_payment_pay_with));
|
|
||||||
mLayoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
|
||||||
setWidgetLayoutResource(R.layout.preference_widget_gear);
|
|
||||||
|
|
||||||
refresh();
|
public NfcPaymentPreference(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
|
super(context, attrs, defStyleAttr);
|
||||||
|
}
|
||||||
|
|
||||||
|
public NfcPaymentPreference(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
void initialize(Listener listener) {
|
||||||
|
mListener = listener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBindViewHolder(PreferenceViewHolder view) {
|
public void onBindViewHolder(PreferenceViewHolder view) {
|
||||||
super.onBindViewHolder(view);
|
super.onBindViewHolder(view);
|
||||||
|
|
||||||
mSettingsButtonView = (ImageView) view.findViewById(R.id.settings_button);
|
if (mListener != null) {
|
||||||
mSettingsButtonView.setOnClickListener(this);
|
mListener.onBindViewHolder(view);
|
||||||
|
|
||||||
updateSettingsVisibility();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* MUST be called on UI thread.
|
|
||||||
*/
|
|
||||||
public void refresh() {
|
|
||||||
List<PaymentAppInfo> appInfos = mPaymentBackend.getPaymentAppInfos();
|
|
||||||
PaymentAppInfo defaultApp = mPaymentBackend.getDefaultApp();
|
|
||||||
if (appInfos != null) {
|
|
||||||
PaymentAppInfo[] apps = appInfos.toArray(new PaymentAppInfo[appInfos.size()]);
|
|
||||||
mAdapter.updateApps(apps, defaultApp);
|
|
||||||
}
|
}
|
||||||
setTitle(R.string.nfc_payment_default);
|
|
||||||
if (defaultApp != null) {
|
|
||||||
setSummary(defaultApp.label);
|
|
||||||
} else {
|
|
||||||
setSummary(mContext.getString(R.string.nfc_payment_default_not_set));
|
|
||||||
}
|
|
||||||
updateSettingsVisibility();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -97,122 +66,8 @@ public class NfcPaymentPreference extends CustomDialogPreference implements
|
|||||||
DialogInterface.OnClickListener listener) {
|
DialogInterface.OnClickListener listener) {
|
||||||
super.onPrepareDialogBuilder(builder, listener);
|
super.onPrepareDialogBuilder(builder, listener);
|
||||||
|
|
||||||
builder.setSingleChoiceItems(mAdapter, 0, listener);
|
if (mListener != null) {
|
||||||
}
|
mListener.onPrepareDialogBuilder(builder, listener);
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPaymentAppsChanged() {
|
|
||||||
refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(View view) {
|
|
||||||
PaymentAppInfo defaultAppInfo = mPaymentBackend.getDefaultApp();
|
|
||||||
if (defaultAppInfo != null && defaultAppInfo.settingsComponent != null) {
|
|
||||||
Intent settingsIntent = new Intent(Intent.ACTION_MAIN);
|
|
||||||
settingsIntent.setComponent(defaultAppInfo.settingsComponent);
|
|
||||||
settingsIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
|
||||||
try {
|
|
||||||
mContext.startActivity(settingsIntent);
|
|
||||||
} catch (ActivityNotFoundException e) {
|
|
||||||
Log.e(TAG, "Settings activity not found.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void updateSettingsVisibility() {
|
|
||||||
if (mSettingsButtonView != null) {
|
|
||||||
PaymentAppInfo defaultApp = mPaymentBackend.getDefaultApp();
|
|
||||||
if (defaultApp == null || defaultApp.settingsComponent == null) {
|
|
||||||
mSettingsButtonView.setVisibility(View.GONE);
|
|
||||||
} else {
|
|
||||||
mSettingsButtonView.setVisibility(View.VISIBLE);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class NfcPaymentAdapter extends BaseAdapter implements CompoundButton.OnCheckedChangeListener,
|
|
||||||
View.OnClickListener {
|
|
||||||
// Only modified on UI thread
|
|
||||||
private PaymentAppInfo[] appInfos;
|
|
||||||
|
|
||||||
public NfcPaymentAdapter() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateApps(PaymentAppInfo[] appInfos, PaymentAppInfo currentDefault) {
|
|
||||||
// Clone app infos, only add those with a banner
|
|
||||||
this.appInfos = appInfos;
|
|
||||||
notifyDataSetChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getCount() {
|
|
||||||
return appInfos.length;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public PaymentAppInfo getItem(int i) {
|
|
||||||
return appInfos[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long getItemId(int i) {
|
|
||||||
return appInfos[i].componentName.hashCode();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
|
||||||
ViewHolder holder;
|
|
||||||
PaymentAppInfo appInfo = appInfos[position];
|
|
||||||
if (convertView == null) {
|
|
||||||
convertView = mLayoutInflater.inflate(
|
|
||||||
R.layout.nfc_payment_option, parent, false);
|
|
||||||
holder = new ViewHolder();
|
|
||||||
holder.imageView = (ImageView) convertView.findViewById(R.id.banner);
|
|
||||||
holder.radioButton = (RadioButton) convertView.findViewById(R.id.button);
|
|
||||||
convertView.setTag(holder);
|
|
||||||
} else {
|
|
||||||
holder = (ViewHolder) convertView.getTag();
|
|
||||||
}
|
|
||||||
holder.imageView.setImageDrawable(appInfo.banner);
|
|
||||||
holder.imageView.setTag(appInfo);
|
|
||||||
holder.imageView.setContentDescription(appInfo.label);
|
|
||||||
holder.imageView.setOnClickListener(this);
|
|
||||||
|
|
||||||
// Prevent checked callback getting called on recycled views
|
|
||||||
holder.radioButton.setOnCheckedChangeListener(null);
|
|
||||||
holder.radioButton.setChecked(appInfo.isDefault);
|
|
||||||
holder.radioButton.setContentDescription(appInfo.label);
|
|
||||||
holder.radioButton.setOnCheckedChangeListener(this);
|
|
||||||
holder.radioButton.setTag(appInfo);
|
|
||||||
return convertView;
|
|
||||||
}
|
|
||||||
|
|
||||||
public class ViewHolder {
|
|
||||||
public ImageView imageView;
|
|
||||||
public RadioButton radioButton;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
|
||||||
PaymentAppInfo appInfo = (PaymentAppInfo) compoundButton.getTag();
|
|
||||||
makeDefault(appInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(View view) {
|
|
||||||
PaymentAppInfo appInfo = (PaymentAppInfo) view.getTag();
|
|
||||||
makeDefault(appInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
void makeDefault(PaymentAppInfo appInfo) {
|
|
||||||
if (!appInfo.isDefault) {
|
|
||||||
mPaymentBackend.setDefaultPaymentApp(appInfo.componentName);
|
|
||||||
}
|
|
||||||
Dialog dialog = getDialog();
|
|
||||||
if (dialog != null)
|
|
||||||
dialog.dismiss();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
257
src/com/android/settings/nfc/NfcPaymentPreferenceController.java
Normal file
257
src/com/android/settings/nfc/NfcPaymentPreferenceController.java
Normal file
@@ -0,0 +1,257 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2018 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.nfc;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.app.Dialog;
|
||||||
|
import android.content.ActivityNotFoundException;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.BaseAdapter;
|
||||||
|
import android.widget.CompoundButton;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import android.widget.RadioButton;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settings.nfc.PaymentBackend.PaymentAppInfo;
|
||||||
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStart;
|
||||||
|
import com.android.settingslib.core.lifecycle.events.OnStop;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.preference.PreferenceViewHolder;
|
||||||
|
|
||||||
|
public class NfcPaymentPreferenceController extends BasePreferenceController implements
|
||||||
|
PaymentBackend.Callback, View.OnClickListener, NfcPaymentPreference.Listener,
|
||||||
|
LifecycleObserver, OnStart, OnStop {
|
||||||
|
|
||||||
|
private static final String TAG = "NfcPaymentController";
|
||||||
|
|
||||||
|
private final NfcPaymentAdapter mAdapter;
|
||||||
|
private PaymentBackend mPaymentBackend;
|
||||||
|
private NfcPaymentPreference mPreference;
|
||||||
|
private ImageView mSettingsButtonView;
|
||||||
|
|
||||||
|
public NfcPaymentPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mAdapter = new NfcPaymentAdapter(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPaymentBackend(PaymentBackend backend) {
|
||||||
|
mPaymentBackend = backend;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStart() {
|
||||||
|
if (mPaymentBackend != null) {
|
||||||
|
mPaymentBackend.registerCallback(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStop() {
|
||||||
|
if (mPaymentBackend != null) {
|
||||||
|
mPaymentBackend.unregisterCallback(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
final PackageManager pm = mContext.getPackageManager();
|
||||||
|
if (!pm.hasSystemFeature(PackageManager.FEATURE_NFC)) {
|
||||||
|
return DISABLED_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
if (mPaymentBackend == null) {
|
||||||
|
mPaymentBackend = new PaymentBackend(mContext);
|
||||||
|
}
|
||||||
|
final List<PaymentAppInfo> appInfos = mPaymentBackend.getPaymentAppInfos();
|
||||||
|
return (appInfos != null && !appInfos.isEmpty())
|
||||||
|
? AVAILABLE
|
||||||
|
: DISABLED_UNSUPPORTED;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = (NfcPaymentPreference) screen.findPreference(getPreferenceKey());
|
||||||
|
if (mPreference != null) {
|
||||||
|
mPreference.initialize(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBindViewHolder(PreferenceViewHolder view) {
|
||||||
|
mSettingsButtonView = (ImageView) view.findViewById(R.id.settings_button);
|
||||||
|
mSettingsButtonView.setOnClickListener(this);
|
||||||
|
|
||||||
|
updateSettingsVisibility();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
final List<PaymentAppInfo> appInfos = mPaymentBackend.getPaymentAppInfos();
|
||||||
|
if (appInfos != null) {
|
||||||
|
final PaymentAppInfo[] apps = appInfos.toArray(new PaymentAppInfo[appInfos.size()]);
|
||||||
|
mAdapter.updateApps(apps);
|
||||||
|
}
|
||||||
|
super.updateState(preference);
|
||||||
|
updateSettingsVisibility();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CharSequence getSummary() {
|
||||||
|
final PaymentAppInfo defaultApp = mPaymentBackend.getDefaultApp();
|
||||||
|
if (defaultApp != null) {
|
||||||
|
return defaultApp.label;
|
||||||
|
} else {
|
||||||
|
return mContext.getText(R.string.nfc_payment_default_not_set);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPrepareDialogBuilder(AlertDialog.Builder builder,
|
||||||
|
DialogInterface.OnClickListener listener) {
|
||||||
|
builder.setSingleChoiceItems(mAdapter, 0, listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPaymentAppsChanged() {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
final PaymentAppInfo defaultAppInfo = mPaymentBackend.getDefaultApp();
|
||||||
|
if (defaultAppInfo != null && defaultAppInfo.settingsComponent != null) {
|
||||||
|
final Intent settingsIntent = new Intent(Intent.ACTION_MAIN);
|
||||||
|
settingsIntent.setComponent(defaultAppInfo.settingsComponent);
|
||||||
|
settingsIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
|
||||||
|
try {
|
||||||
|
mContext.startActivity(settingsIntent);
|
||||||
|
} catch (ActivityNotFoundException e) {
|
||||||
|
Log.e(TAG, "Settings activity not found.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void updateSettingsVisibility() {
|
||||||
|
if (mSettingsButtonView != null) {
|
||||||
|
final PaymentAppInfo defaultApp = mPaymentBackend.getDefaultApp();
|
||||||
|
if (defaultApp == null || defaultApp.settingsComponent == null) {
|
||||||
|
mSettingsButtonView.setVisibility(View.GONE);
|
||||||
|
} else {
|
||||||
|
mSettingsButtonView.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class NfcPaymentAdapter extends BaseAdapter implements
|
||||||
|
CompoundButton.OnCheckedChangeListener, View.OnClickListener {
|
||||||
|
private final LayoutInflater mLayoutInflater;
|
||||||
|
|
||||||
|
// Only modified on UI thread
|
||||||
|
private PaymentAppInfo[] appInfos;
|
||||||
|
|
||||||
|
public NfcPaymentAdapter(Context context) {
|
||||||
|
mLayoutInflater = (LayoutInflater) context.getSystemService(
|
||||||
|
Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void updateApps(PaymentAppInfo[] appInfos) {
|
||||||
|
// Clone app infos, only add those with a banner
|
||||||
|
this.appInfos = appInfos;
|
||||||
|
notifyDataSetChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getCount() {
|
||||||
|
return (appInfos != null) ? appInfos.length : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public PaymentAppInfo getItem(int i) {
|
||||||
|
return appInfos[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getItemId(int i) {
|
||||||
|
return appInfos[i].componentName.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
ViewHolder holder;
|
||||||
|
final PaymentAppInfo appInfo = appInfos[position];
|
||||||
|
if (convertView == null) {
|
||||||
|
convertView = mLayoutInflater.inflate(
|
||||||
|
R.layout.nfc_payment_option, parent, false);
|
||||||
|
holder = new ViewHolder();
|
||||||
|
holder.imageView = convertView.findViewById(R.id.banner);
|
||||||
|
holder.radioButton = convertView.findViewById(R.id.button);
|
||||||
|
convertView.setTag(holder);
|
||||||
|
} else {
|
||||||
|
holder = (ViewHolder) convertView.getTag();
|
||||||
|
}
|
||||||
|
holder.imageView.setImageDrawable(appInfo.banner);
|
||||||
|
holder.imageView.setTag(appInfo);
|
||||||
|
holder.imageView.setContentDescription(appInfo.label);
|
||||||
|
holder.imageView.setOnClickListener(this);
|
||||||
|
|
||||||
|
// Prevent checked callback getting called on recycled views
|
||||||
|
holder.radioButton.setOnCheckedChangeListener(null);
|
||||||
|
holder.radioButton.setChecked(appInfo.isDefault);
|
||||||
|
holder.radioButton.setContentDescription(appInfo.label);
|
||||||
|
holder.radioButton.setOnCheckedChangeListener(this);
|
||||||
|
holder.radioButton.setTag(appInfo);
|
||||||
|
return convertView;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class ViewHolder {
|
||||||
|
public ImageView imageView;
|
||||||
|
public RadioButton radioButton;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
|
||||||
|
PaymentAppInfo appInfo = (PaymentAppInfo) compoundButton.getTag();
|
||||||
|
makeDefault(appInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(View view) {
|
||||||
|
PaymentAppInfo appInfo = (PaymentAppInfo) view.getTag();
|
||||||
|
makeDefault(appInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void makeDefault(PaymentAppInfo appInfo) {
|
||||||
|
if (!appInfo.isDefault) {
|
||||||
|
mPaymentBackend.setDefaultPaymentApp(appInfo.componentName);
|
||||||
|
}
|
||||||
|
final Dialog dialog = mPreference.getDialog();
|
||||||
|
if (dialog != null) {
|
||||||
|
dialog.dismiss();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -25,7 +25,9 @@ import android.nfc.NfcAdapter;
|
|||||||
import android.nfc.cardemulation.ApduServiceInfo;
|
import android.nfc.cardemulation.ApduServiceInfo;
|
||||||
import android.nfc.cardemulation.CardEmulation;
|
import android.nfc.cardemulation.CardEmulation;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
|
import android.os.Looper;
|
||||||
import android.os.Message;
|
import android.os.Message;
|
||||||
|
import android.os.UserHandle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.provider.Settings.SettingNotFoundException;
|
import android.provider.Settings.SettingNotFoundException;
|
||||||
|
|
||||||
@@ -57,7 +59,7 @@ public class PaymentBackend {
|
|||||||
// Fields below only modified on UI thread
|
// Fields below only modified on UI thread
|
||||||
private ArrayList<PaymentAppInfo> mAppInfos;
|
private ArrayList<PaymentAppInfo> mAppInfos;
|
||||||
private PaymentAppInfo mDefaultAppInfo;
|
private PaymentAppInfo mDefaultAppInfo;
|
||||||
private ArrayList<Callback> mCallbacks = new ArrayList<Callback>();
|
private ArrayList<Callback> mCallbacks = new ArrayList<>();
|
||||||
|
|
||||||
public PaymentBackend(Context context) {
|
public PaymentBackend(Context context) {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
@@ -102,7 +104,8 @@ public class PaymentBackend {
|
|||||||
appInfo.componentName = service.getComponent();
|
appInfo.componentName = service.getComponent();
|
||||||
String settingsActivity = service.getSettingsActivityName();
|
String settingsActivity = service.getSettingsActivityName();
|
||||||
if (settingsActivity != null) {
|
if (settingsActivity != null) {
|
||||||
appInfo.settingsComponent = new ComponentName(appInfo.componentName.getPackageName(),
|
appInfo.settingsComponent = new ComponentName(
|
||||||
|
appInfo.componentName.getPackageName(),
|
||||||
settingsActivity);
|
settingsActivity);
|
||||||
} else {
|
} else {
|
||||||
appInfo.settingsComponent = null;
|
appInfo.settingsComponent = null;
|
||||||
@@ -162,7 +165,7 @@ public class PaymentBackend {
|
|||||||
|
|
||||||
void setForegroundMode(boolean foreground) {
|
void setForegroundMode(boolean foreground) {
|
||||||
Settings.Secure.putInt(mContext.getContentResolver(),
|
Settings.Secure.putInt(mContext.getContentResolver(),
|
||||||
Settings.Secure.NFC_PAYMENT_FOREGROUND, foreground ? 1 : 0) ;
|
Settings.Secure.NFC_PAYMENT_FOREGROUND, foreground ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
ComponentName getDefaultPaymentApp() {
|
ComponentName getDefaultPaymentApp() {
|
||||||
@@ -182,14 +185,23 @@ public class PaymentBackend {
|
|||||||
refresh();
|
refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
private final Handler mHandler = new Handler() {
|
|
||||||
@Override
|
|
||||||
public void dispatchMessage(Message msg) {
|
|
||||||
refresh();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
private class SettingsPackageMonitor extends PackageMonitor {
|
private class SettingsPackageMonitor extends PackageMonitor {
|
||||||
|
private Handler mHandler;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void register(Context context, Looper thread, UserHandle user,
|
||||||
|
boolean externalStorage) {
|
||||||
|
if (mHandler == null) {
|
||||||
|
mHandler = new Handler(thread) {
|
||||||
|
@Override
|
||||||
|
public void dispatchMessage(Message msg) {
|
||||||
|
refresh();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
super.register(context, thread, user, externalStorage);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onPackageAdded(String packageName, int uid) {
|
public void onPackageAdded(String packageName, int uid) {
|
||||||
mHandler.obtainMessage().sendToTarget();
|
mHandler.obtainMessage().sendToTarget();
|
||||||
@@ -210,4 +222,4 @@ public class PaymentBackend {
|
|||||||
mHandler.obtainMessage().sendToTarget();
|
mHandler.obtainMessage().sendToTarget();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -19,10 +19,8 @@ package com.android.settings.nfc;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.res.Resources;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import androidx.preference.PreferenceManager;
|
import android.provider.SearchIndexableResource;
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
import android.view.MenuInflater;
|
import android.view.MenuInflater;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
@@ -31,23 +29,25 @@ import android.view.ViewGroup;
|
|||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.SettingsPreferenceFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settings.search.Indexable;
|
|
||||||
import com.android.settings.search.SearchIndexableRaw;
|
|
||||||
import com.android.settingslib.search.SearchIndexable;
|
import com.android.settingslib.search.SearchIndexable;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
@SearchIndexable
|
@SearchIndexable
|
||||||
public class PaymentSettings extends SettingsPreferenceFragment implements Indexable {
|
public class PaymentSettings extends DashboardFragment {
|
||||||
public static final String TAG = "PaymentSettings";
|
public static final String TAG = "PaymentSettings";
|
||||||
|
|
||||||
static final String PAYMENT_KEY = "payment";
|
|
||||||
|
|
||||||
private PaymentBackend mPaymentBackend;
|
private PaymentBackend mPaymentBackend;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected String getLogTag() {
|
||||||
|
return TAG;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMetricsCategory() {
|
public int getMetricsCategory() {
|
||||||
return MetricsEvent.NFC_PAYMENT;
|
return MetricsEvent.NFC_PAYMENT;
|
||||||
@@ -59,24 +59,13 @@ public class PaymentSettings extends SettingsPreferenceFragment implements Index
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle icicle) {
|
public void onAttach(Context context) {
|
||||||
super.onCreate(icicle);
|
super.onAttach(context);
|
||||||
|
|
||||||
mPaymentBackend = new PaymentBackend(getActivity());
|
mPaymentBackend = new PaymentBackend(getActivity());
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
|
|
||||||
final PreferenceScreen screen = getPreferenceScreen();
|
use(NfcPaymentPreferenceController.class).setPaymentBackend(mPaymentBackend);
|
||||||
|
use(NfcForegroundPreferenceController.class).setPaymentBackend(mPaymentBackend);
|
||||||
List<PaymentBackend.PaymentAppInfo> appInfos = mPaymentBackend.getPaymentAppInfos();
|
|
||||||
if (appInfos != null && appInfos.size() > 0) {
|
|
||||||
NfcPaymentPreference preference =
|
|
||||||
new NfcPaymentPreference(getPrefContext(), mPaymentBackend);
|
|
||||||
preference.setKey(PAYMENT_KEY);
|
|
||||||
screen.addPreference(preference);
|
|
||||||
NfcForegroundPreference foreground = new NfcForegroundPreference(getPrefContext(),
|
|
||||||
mPaymentBackend);
|
|
||||||
screen.addPreference(foreground);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -111,31 +100,19 @@ public class PaymentSettings extends SettingsPreferenceFragment implements Index
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
new BaseSearchIndexProvider() {
|
new BaseSearchIndexProvider() {
|
||||||
@Override
|
@Override
|
||||||
public List<SearchIndexableRaw> getRawDataToIndex(Context context, boolean enabled) {
|
public List<SearchIndexableResource> getXmlResourcesToIndex(Context context,
|
||||||
final List<SearchIndexableRaw> result = new ArrayList<SearchIndexableRaw>();
|
boolean enabled) {
|
||||||
final Resources res = context.getResources();
|
final SearchIndexableResource sir = new SearchIndexableResource(context);
|
||||||
|
sir.xmlResId = R.xml.nfc_payment_settings;
|
||||||
// Add fragment title
|
return Arrays.asList(sir);
|
||||||
SearchIndexableRaw data = new SearchIndexableRaw(context);
|
|
||||||
data.key = PAYMENT_KEY;
|
|
||||||
data.title = res.getString(R.string.nfc_payment_settings_title);
|
|
||||||
data.screenTitle = res.getString(R.string.nfc_payment_settings_title);
|
|
||||||
data.keywords = res.getString(R.string.keywords_payment_settings);
|
|
||||||
result.add(data);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public List<String> getNonIndexableKeys(Context context) {
|
|
||||||
final List<String> nonVisibleKeys = super.getNonIndexableKeys(context);
|
|
||||||
final PackageManager pm = context.getPackageManager();
|
|
||||||
if (pm.hasSystemFeature(PackageManager.FEATURE_NFC)) {
|
|
||||||
return nonVisibleKeys;
|
|
||||||
}
|
}
|
||||||
nonVisibleKeys.add(PAYMENT_KEY);
|
|
||||||
return nonVisibleKeys;
|
@Override
|
||||||
}
|
protected boolean isPageSearchEnabled(Context context) {
|
||||||
};
|
final PackageManager pm = context.getPackageManager();
|
||||||
}
|
return pm.hasSystemFeature(PackageManager.FEATURE_NFC);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
@@ -17,7 +17,6 @@
|
|||||||
package com.android.settings.nfc;
|
package com.android.settings.nfc;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -27,7 +26,6 @@ import android.nfc.NfcManager;
|
|||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
|
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
@@ -44,6 +42,8 @@ import org.robolectric.util.ReflectionHelpers;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
public class AndroidBeamPreferenceControllerTest {
|
public class AndroidBeamPreferenceControllerTest {
|
||||||
|
|
||||||
|
@@ -0,0 +1,158 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2018 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.nfc;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import androidx.preference.DropDownPreference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
|
public class NfcForegroundPreferenceControllerTest {
|
||||||
|
|
||||||
|
private static final String PREF_KEY = PaymentSettingsTest.FOREGROUND_KEY;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PaymentBackend mPaymentBackend;
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
@Mock
|
||||||
|
private PackageManager mManager;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private DropDownPreference mPreference;
|
||||||
|
private NfcForegroundPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
|
when(mContext.getPackageManager()).thenReturn(mManager);
|
||||||
|
mController = new NfcForegroundPreferenceController(mContext, PREF_KEY);
|
||||||
|
mPreference = new DropDownPreference(mContext);
|
||||||
|
when(mScreen.findPreference(PREF_KEY)).thenReturn(mPreference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noNFC_DISABLED() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcForegroundPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noPaymentBackend_DISABLED() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcForegroundPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noPaymentApps_DISABLED() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(null);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcForegroundPreferenceController.AVAILABLE);
|
||||||
|
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(new ArrayList<>());
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcForegroundPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initPaymentApps() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
final ArrayList<PaymentBackend.PaymentAppInfo> appInfos = new ArrayList<>();
|
||||||
|
appInfos.add(new PaymentBackend.PaymentAppInfo());
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(appInfos);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_hasPaymentApps_AVAILABLE() {
|
||||||
|
initPaymentApps();
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(NfcForegroundPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStart_shouldRegisterCallback() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
verify(mPaymentBackend).registerCallback(mController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStop_shouldUnregisterCallback() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
mController.onStop();
|
||||||
|
|
||||||
|
verify(mPaymentBackend).unregisterCallback(mController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void changeOptions_shouldUpdateEntryAndSummary() {
|
||||||
|
initPaymentApps();
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mController.onPaymentAppsChanged();
|
||||||
|
|
||||||
|
final CharSequence favorDefault = mContext.getText(R.string.nfc_payment_favor_default);
|
||||||
|
final CharSequence favorOpen = mContext.getText(R.string.nfc_payment_favor_open);
|
||||||
|
|
||||||
|
assertThat(mPreference.getEntry()).isEqualTo(favorDefault);
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo(favorDefault);
|
||||||
|
|
||||||
|
mPreference.setValueIndex(0);
|
||||||
|
mPreference.callChangeListener(mPreference.getEntryValues()[0]);
|
||||||
|
verify(mPaymentBackend).setForegroundMode(true);
|
||||||
|
assertThat(mPreference.getEntry()).isEqualTo(favorOpen);
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo(favorOpen);
|
||||||
|
|
||||||
|
mPreference.setValueIndex(1);
|
||||||
|
mPreference.callChangeListener(mPreference.getEntryValues()[1]);
|
||||||
|
verify(mPaymentBackend).setForegroundMode(false);
|
||||||
|
assertThat(mPreference.getEntry()).isEqualTo(favorDefault);
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo(favorDefault);
|
||||||
|
}
|
||||||
|
}
|
@@ -1,79 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2018 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.nfc;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.verify;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.mockito.Mock;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.robolectric.RuntimeEnvironment;
|
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
|
||||||
public class NfcForegroundPreferenceTest {
|
|
||||||
@Mock
|
|
||||||
private PaymentBackend mPaymentBackend;
|
|
||||||
|
|
||||||
private Context mContext;
|
|
||||||
private PreferenceScreen mScreen;
|
|
||||||
private NfcForegroundPreference mPreference;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
MockitoAnnotations.initMocks(this);
|
|
||||||
mContext = RuntimeEnvironment.application;
|
|
||||||
mScreen = spy(new PreferenceScreen(mContext, null));
|
|
||||||
when(mScreen.getPreferenceManager()).thenReturn(mock(PreferenceManager.class));
|
|
||||||
when(mPaymentBackend.isForegroundMode()).thenReturn(false);
|
|
||||||
mPreference = new NfcForegroundPreference(mContext, mPaymentBackend);
|
|
||||||
mScreen.addPreference(mPreference);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testTogglingMode() {
|
|
||||||
String nfc_payment_favor_default = mContext.getString(R.string.nfc_payment_favor_default);
|
|
||||||
String nfc_payment_favor_open = mContext.getString(R.string.nfc_payment_favor_open);
|
|
||||||
|
|
||||||
assertThat(mPreference.getEntry()).isEqualTo(nfc_payment_favor_default);
|
|
||||||
assertThat(mPreference.getSummary()).isEqualTo(nfc_payment_favor_default);
|
|
||||||
|
|
||||||
mPreference.setValueIndex(0);
|
|
||||||
mPreference.callChangeListener(mPreference.getEntryValues()[0]);
|
|
||||||
verify(mPaymentBackend).setForegroundMode(true);
|
|
||||||
assertThat(mPreference.getEntry()).isEqualTo(nfc_payment_favor_open);
|
|
||||||
assertThat(mPreference.getSummary()).isEqualTo(nfc_payment_favor_open);
|
|
||||||
|
|
||||||
mPreference.setValueIndex(1);
|
|
||||||
mPreference.callChangeListener(mPreference.getEntryValues()[1]);
|
|
||||||
verify(mPaymentBackend).setForegroundMode(false);
|
|
||||||
assertThat(mPreference.getEntry()).isEqualTo(nfc_payment_favor_default);
|
|
||||||
assertThat(mPreference.getSummary()).isEqualTo(nfc_payment_favor_default);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -0,0 +1,150 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2018 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.nfc;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.nfc.PaymentBackend.PaymentAppInfo;
|
||||||
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
|
public class NfcPaymentPreferenceControllerTest {
|
||||||
|
|
||||||
|
private static final String PREF_KEY = PaymentSettingsTest.PAYMENT_KEY;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
private PaymentBackend mPaymentBackend;
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
@Mock
|
||||||
|
private PackageManager mManager;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
private NfcPaymentPreference mPreference;
|
||||||
|
private NfcPaymentPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
|
when(mContext.getPackageManager()).thenReturn(mManager);
|
||||||
|
mController = new NfcPaymentPreferenceController(mContext, PREF_KEY);
|
||||||
|
mPreference = spy(new NfcPaymentPreference(mContext, null));
|
||||||
|
when(mScreen.findPreference(PREF_KEY)).thenReturn(mPreference);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noNFC_DISABLED() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcPaymentPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_noPaymentApps_DISABLED() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(null);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcPaymentPreferenceController.AVAILABLE);
|
||||||
|
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(new ArrayList<>());
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isNotEqualTo(NfcPaymentPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_hasPaymentApps_AVAILABLE() {
|
||||||
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
final ArrayList<PaymentAppInfo> appInfos = new ArrayList<>();
|
||||||
|
appInfos.add(new PaymentAppInfo());
|
||||||
|
when(mPaymentBackend.getPaymentAppInfos()).thenReturn(appInfos);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(NfcPaymentPreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStart_shouldRegisterCallback() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
verify(mPaymentBackend).registerCallback(mController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onStop_shouldUnregisterCallback() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
mController.onStart();
|
||||||
|
|
||||||
|
mController.onStop();
|
||||||
|
|
||||||
|
verify(mPaymentBackend).unregisterCallback(mController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void displayPreference_shouldInitialize() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
|
||||||
|
verify(mPreference).initialize(mController);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onPaymentAppsChanged_shouldRefreshSummary() {
|
||||||
|
mController.setPaymentBackend(mPaymentBackend);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
when(mPaymentBackend.getDefaultApp()).thenReturn(null);
|
||||||
|
|
||||||
|
mController.onPaymentAppsChanged();
|
||||||
|
|
||||||
|
assertThat(mPreference.getSummary())
|
||||||
|
.isEqualTo(mContext.getText(R.string.nfc_payment_default_not_set));
|
||||||
|
|
||||||
|
final PaymentAppInfo appInfo = new PaymentAppInfo();
|
||||||
|
appInfo.label = "test label";
|
||||||
|
when(mPaymentBackend.getDefaultApp()).thenReturn(appInfo);
|
||||||
|
|
||||||
|
mController.onPaymentAppsChanged();
|
||||||
|
|
||||||
|
assertThat(mPreference.getSummary()).isEqualTo(appInfo.label);
|
||||||
|
}
|
||||||
|
}
|
@@ -17,7 +17,6 @@
|
|||||||
package com.android.settings.nfc;
|
package com.android.settings.nfc;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -26,8 +25,6 @@ import android.nfc.NfcAdapter;
|
|||||||
import android.nfc.NfcManager;
|
import android.nfc.NfcManager;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import androidx.preference.SwitchPreference;
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
|
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
|
|
||||||
@@ -42,10 +39,13 @@ import org.robolectric.util.ReflectionHelpers;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
public class NfcPreferenceControllerTest {
|
public class NfcPreferenceControllerTest {
|
||||||
|
|
||||||
Context mContext;
|
|
||||||
@Mock
|
@Mock
|
||||||
private NfcAdapter mNfcAdapter;
|
private NfcAdapter mNfcAdapter;
|
||||||
@Mock
|
@Mock
|
||||||
@@ -55,6 +55,7 @@ public class NfcPreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private PreferenceScreen mScreen;
|
private PreferenceScreen mScreen;
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
private SwitchPreference mNfcPreference;
|
private SwitchPreference mNfcPreference;
|
||||||
private NfcPreferenceController mNfcController;
|
private NfcPreferenceController mNfcController;
|
||||||
|
|
||||||
|
@@ -18,6 +18,7 @@
|
|||||||
package com.android.settings.nfc;
|
package com.android.settings.nfc;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -30,42 +31,66 @@ import org.junit.Test;
|
|||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.annotation.Implementation;
|
||||||
|
import org.robolectric.annotation.Implements;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(SettingsRobolectricTestRunner.class)
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
|
@Config(shadows = PaymentSettingsTest.ShadowPaymentBackend.class)
|
||||||
public class PaymentSettingsTest {
|
public class PaymentSettingsTest {
|
||||||
|
|
||||||
@Mock
|
static final String PAYMENT_KEY = "nfc_payment";
|
||||||
Context mContext;
|
static final String FOREGROUND_KEY = "nfc_foreground";
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private PackageManager mManager;
|
private PackageManager mManager;
|
||||||
|
|
||||||
private PaymentSettings mFragment;
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mFragment = new PaymentSettings();
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
when(mContext.getPackageManager()).thenReturn(mManager);
|
when(mContext.getPackageManager()).thenReturn(mManager);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNonIndexableKey_NoNFC_KeyAdded() {
|
public void getNonIndexableKey_NoNFC_AllKeysAdded() {
|
||||||
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(false);
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(false);
|
||||||
|
|
||||||
final List<String> niks =
|
final List<String> niks =
|
||||||
PaymentSettings.SEARCH_INDEX_DATA_PROVIDER.getNonIndexableKeys(mContext);
|
PaymentSettings.SEARCH_INDEX_DATA_PROVIDER.getNonIndexableKeys(mContext);
|
||||||
assertThat(niks).contains(PaymentSettings.PAYMENT_KEY);
|
|
||||||
|
assertThat(niks).contains(PAYMENT_KEY);
|
||||||
|
assertThat(niks).contains(FOREGROUND_KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNonIndexableKey_NFC_NoKeyAdded() {
|
public void getNonIndexableKey_NFC_ForegroundKeyAdded() {
|
||||||
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
when(mManager.hasSystemFeature(PackageManager.FEATURE_NFC)).thenReturn(true);
|
||||||
|
|
||||||
final List<String> niks =
|
final List<String> niks =
|
||||||
PaymentSettings.SEARCH_INDEX_DATA_PROVIDER.getNonIndexableKeys(mContext);
|
PaymentSettings.SEARCH_INDEX_DATA_PROVIDER.getNonIndexableKeys(mContext);
|
||||||
assertThat(niks).isEmpty();
|
|
||||||
|
assertThat(niks).contains(FOREGROUND_KEY);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Implements(PaymentBackend.class)
|
||||||
|
public static class ShadowPaymentBackend {
|
||||||
|
private ArrayList<PaymentBackend.PaymentAppInfo> mAppInfos;
|
||||||
|
|
||||||
|
public void __constructor__(Context context) {
|
||||||
|
mAppInfos = new ArrayList<>();
|
||||||
|
mAppInfos.add(new PaymentBackend.PaymentAppInfo());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Implementation
|
||||||
|
public List<PaymentBackend.PaymentAppInfo> getPaymentAppInfos() {
|
||||||
|
return mAppInfos;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Reference in New Issue
Block a user