Enable audio sharing hysteresis mode fix when preview is on.
Test: atest Bug: 368401233 Flag: com.android.settingslib.flags.audio_sharing_developer_option Change-Id: I3dad42011aadcfd1a2670d297c8e000d1b92324a
This commit is contained in:
@@ -46,7 +46,6 @@ import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
|||||||
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothProfileManager;
|
import com.android.settingslib.bluetooth.LocalBluetoothProfileManager;
|
||||||
import com.android.settingslib.bluetooth.VolumeControlProfile;
|
import com.android.settingslib.bluetooth.VolumeControlProfile;
|
||||||
import com.android.settingslib.flags.Flags;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
@@ -222,8 +221,8 @@ public class AudioSharingUtils {
|
|||||||
Log.d(TAG, "hasActiveConnectedLeadDevice return false due to null device manager.");
|
Log.d(TAG, "hasActiveConnectedLeadDevice return false due to null device manager.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return deviceManager.getCachedDevicesCopy().stream().anyMatch(
|
return deviceManager.getCachedDevicesCopy().stream()
|
||||||
BluetoothUtils::isActiveMediaDevice);
|
.anyMatch(BluetoothUtils::isActiveMediaDevice);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Build {@link AudioSharingDeviceItem} from {@link CachedBluetoothDevice}. */
|
/** Build {@link AudioSharingDeviceItem} from {@link CachedBluetoothDevice}. */
|
||||||
@@ -348,17 +347,18 @@ public class AudioSharingUtils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** Set {@link CachedBluetoothDevice} as primary device for call audio */
|
/** Set {@link CachedBluetoothDevice} as primary device for call audio */
|
||||||
public static void setPrimary(@NonNull Context context,
|
public static void setPrimary(
|
||||||
@Nullable CachedBluetoothDevice cachedDevice) {
|
@NonNull Context context, @Nullable CachedBluetoothDevice cachedDevice) {
|
||||||
if (cachedDevice == null) return;
|
if (cachedDevice == null) return;
|
||||||
cachedDevice.setActive();
|
cachedDevice.setActive();
|
||||||
if (Flags.audioSharingHysteresisModeFix()) {
|
if (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(context)) {
|
||||||
int groupId = BluetoothUtils.getGroupId(cachedDevice);
|
int groupId = BluetoothUtils.getGroupId(cachedDevice);
|
||||||
// TODO: use real key name in SettingsProvider
|
// TODO: use real key name in SettingsProvider
|
||||||
int userPreferredId = Settings.Secure.getInt(
|
int userPreferredId =
|
||||||
context.getContentResolver(),
|
Settings.Secure.getInt(
|
||||||
BLUETOOTH_LE_BROADCAST_PRIMARY_DEVICE_GROUP_ID,
|
context.getContentResolver(),
|
||||||
BluetoothCsipSetCoordinator.GROUP_ID_INVALID);
|
BLUETOOTH_LE_BROADCAST_PRIMARY_DEVICE_GROUP_ID,
|
||||||
|
BluetoothCsipSetCoordinator.GROUP_ID_INVALID);
|
||||||
if (groupId != userPreferredId) {
|
if (groupId != userPreferredId) {
|
||||||
Settings.Secure.putInt(
|
Settings.Secure.putInt(
|
||||||
context.getContentResolver(),
|
context.getContentResolver(),
|
||||||
|
@@ -16,8 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.audioSharingHysteresisModeFix;
|
|
||||||
|
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
||||||
@@ -38,6 +36,7 @@ import com.android.settings.R;
|
|||||||
import com.android.settings.bluetooth.Utils;
|
import com.android.settings.bluetooth.Utils;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
|
import com.android.settingslib.bluetooth.BluetoothUtils;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settingslib.utils.ThreadUtils;
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
@@ -77,7 +76,7 @@ public class AudioStreamButtonController extends BasePreferenceController
|
|||||||
BluetoothLeBroadcastReceiveState state) {
|
BluetoothLeBroadcastReceiveState state) {
|
||||||
super.onReceiveStateChanged(sink, sourceId, state);
|
super.onReceiveStateChanged(sink, sourceId, state);
|
||||||
boolean shouldUpdateButton =
|
boolean shouldUpdateButton =
|
||||||
audioSharingHysteresisModeFix()
|
BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
? AudioStreamsHelper.hasSourcePresent(state)
|
? AudioStreamsHelper.hasSourcePresent(state)
|
||||||
: AudioStreamsHelper.isConnected(state);
|
: AudioStreamsHelper.isConnected(state);
|
||||||
if (shouldUpdateButton) {
|
if (shouldUpdateButton) {
|
||||||
@@ -157,7 +156,7 @@ public class AudioStreamButtonController extends BasePreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
List<BluetoothLeBroadcastReceiveState> sources =
|
List<BluetoothLeBroadcastReceiveState> sources =
|
||||||
audioSharingHysteresisModeFix()
|
BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
? mAudioStreamsHelper.getAllPresentSources()
|
? mAudioStreamsHelper.getAllPresentSources()
|
||||||
: mAudioStreamsHelper.getAllConnectedSources();
|
: mAudioStreamsHelper.getAllConnectedSources();
|
||||||
boolean isConnected =
|
boolean isConnected =
|
||||||
|
@@ -37,6 +37,7 @@ import com.android.settings.bluetooth.Utils;
|
|||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.widget.EntityHeaderController;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
|
import com.android.settingslib.bluetooth.BluetoothUtils;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
||||||
import com.android.settingslib.utils.ThreadUtils;
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
import com.android.settingslib.widget.LayoutPreference;
|
import com.android.settingslib.widget.LayoutPreference;
|
||||||
@@ -86,7 +87,7 @@ public class AudioStreamHeaderController extends BasePreferenceController
|
|||||||
updateSummary();
|
updateSummary();
|
||||||
mAudioStreamsHelper.startMediaService(
|
mAudioStreamsHelper.startMediaService(
|
||||||
mContext, mBroadcastId, mBroadcastName);
|
mContext, mBroadcastId, mBroadcastName);
|
||||||
} else if (audioSharingHysteresisModeFix()
|
} else if (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
&& AudioStreamsHelper.hasSourcePresent(state)) {
|
&& AudioStreamsHelper.hasSourcePresent(state)) {
|
||||||
// if source present but not connected, only update the summary
|
// if source present but not connected, only update the summary
|
||||||
updateSummary();
|
updateSummary();
|
||||||
@@ -171,13 +172,13 @@ public class AudioStreamHeaderController extends BasePreferenceController
|
|||||||
: mContext.getString(
|
: mContext.getString(
|
||||||
AUDIO_STREAM_HEADER_PRESENT_NOW_SUMMARY))
|
AUDIO_STREAM_HEADER_PRESENT_NOW_SUMMARY))
|
||||||
: mAudioStreamsHelper.getAllConnectedSources().stream()
|
: mAudioStreamsHelper.getAllConnectedSources().stream()
|
||||||
.map(
|
.map(
|
||||||
BluetoothLeBroadcastReceiveState
|
BluetoothLeBroadcastReceiveState
|
||||||
::getBroadcastId)
|
::getBroadcastId)
|
||||||
.anyMatch(
|
.anyMatch(
|
||||||
connectedBroadcastId ->
|
connectedBroadcastId ->
|
||||||
connectedBroadcastId
|
connectedBroadcastId
|
||||||
== mBroadcastId)
|
== mBroadcastId)
|
||||||
? mContext.getString(
|
? mContext.getString(
|
||||||
AUDIO_STREAM_HEADER_LISTENING_NOW_SUMMARY)
|
AUDIO_STREAM_HEADER_LISTENING_NOW_SUMMARY)
|
||||||
: AUDIO_STREAM_HEADER_NOT_LISTENING_SUMMARY;
|
: AUDIO_STREAM_HEADER_NOT_LISTENING_SUMMARY;
|
||||||
|
@@ -18,8 +18,6 @@ package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
|||||||
|
|
||||||
import static android.text.Spanned.SPAN_EXCLUSIVE_INCLUSIVE;
|
import static android.text.Spanned.SPAN_EXCLUSIVE_INCLUSIVE;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.audioSharingHysteresisModeFix;
|
|
||||||
|
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.text.SpannableString;
|
import android.text.SpannableString;
|
||||||
@@ -98,7 +96,8 @@ class AudioStreamStateHandler {
|
|||||||
newState
|
newState
|
||||||
== AudioStreamsProgressCategoryController
|
== AudioStreamsProgressCategoryController
|
||||||
.AudioStreamState.SOURCE_ADDED
|
.AudioStreamState.SOURCE_ADDED
|
||||||
|| (audioSharingHysteresisModeFix()
|
|| (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(
|
||||||
|
preference.getContext())
|
||||||
&& newState
|
&& newState
|
||||||
== AudioStreamsProgressCategoryController
|
== AudioStreamsProgressCategoryController
|
||||||
.AudioStreamState.SOURCE_PRESENT));
|
.AudioStreamState.SOURCE_PRESENT));
|
||||||
|
@@ -31,7 +31,6 @@ import com.android.settingslib.bluetooth.BluetoothCallback;
|
|||||||
import com.android.settingslib.bluetooth.BluetoothUtils;
|
import com.android.settingslib.bluetooth.BluetoothUtils;
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
import com.android.settingslib.bluetooth.LocalBluetoothManager;
|
||||||
import com.android.settingslib.flags.Flags;
|
|
||||||
|
|
||||||
import java.util.concurrent.Executor;
|
import java.util.concurrent.Executor;
|
||||||
import java.util.concurrent.Executors;
|
import java.util.concurrent.Executors;
|
||||||
@@ -80,13 +79,6 @@ public class AudioStreamsCategoryController extends AudioSharingBasePreferenceCo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getAvailabilityStatus() {
|
|
||||||
return Flags.enableLeAudioQrCodePrivateBroadcastSharing()
|
|
||||||
? AVAILABLE
|
|
||||||
: UNSUPPORTED_ON_DEVICE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateVisibility() {
|
public void updateVisibility() {
|
||||||
if (mPreference == null) return;
|
if (mPreference == null) return;
|
||||||
|
@@ -19,7 +19,6 @@ package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
|||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.BROADCAST_ID;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.BROADCAST_ID;
|
||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.BROADCAST_TITLE;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.BROADCAST_TITLE;
|
||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.DEVICES;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamMediaService.DEVICES;
|
||||||
import static com.android.settingslib.flags.Flags.audioSharingHysteresisModeFix;
|
|
||||||
|
|
||||||
import static java.util.Collections.emptyList;
|
import static java.util.Collections.emptyList;
|
||||||
|
|
||||||
@@ -271,7 +270,8 @@ public class AudioStreamsHelper {
|
|||||||
List<BluetoothLeBroadcastReceiveState> sourceList =
|
List<BluetoothLeBroadcastReceiveState> sourceList =
|
||||||
assistant.getAllSources(cachedDevice.getDevice());
|
assistant.getAllSources(cachedDevice.getDevice());
|
||||||
if (!sourceList.isEmpty()
|
if (!sourceList.isEmpty()
|
||||||
&& (audioSharingHysteresisModeFix()
|
&& (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(
|
||||||
|
localBtManager.getContext())
|
||||||
|| sourceList.stream().anyMatch(AudioStreamsHelper::isConnected))) {
|
|| sourceList.stream().anyMatch(AudioStreamsHelper::isConnected))) {
|
||||||
Log.d(
|
Log.d(
|
||||||
TAG,
|
TAG,
|
||||||
@@ -284,7 +284,8 @@ public class AudioStreamsHelper {
|
|||||||
List<BluetoothLeBroadcastReceiveState> list =
|
List<BluetoothLeBroadcastReceiveState> list =
|
||||||
assistant.getAllSources(device.getDevice());
|
assistant.getAllSources(device.getDevice());
|
||||||
if (!list.isEmpty()
|
if (!list.isEmpty()
|
||||||
&& (audioSharingHysteresisModeFix()
|
&& (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(
|
||||||
|
localBtManager.getContext())
|
||||||
|| list.stream().anyMatch(AudioStreamsHelper::isConnected))) {
|
|| list.stream().anyMatch(AudioStreamsHelper::isConnected))) {
|
||||||
Log.d(
|
Log.d(
|
||||||
TAG,
|
TAG,
|
||||||
|
@@ -16,19 +16,24 @@
|
|||||||
|
|
||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.audioSharingHysteresisModeFix;
|
|
||||||
|
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import com.android.settingslib.bluetooth.BluetoothUtils;
|
||||||
|
|
||||||
public class AudioStreamsProgressCategoryCallback extends AudioStreamsBroadcastAssistantCallback {
|
public class AudioStreamsProgressCategoryCallback extends AudioStreamsBroadcastAssistantCallback {
|
||||||
private static final String TAG = "AudioStreamsProgressCategoryCallback";
|
private static final String TAG = "AudioStreamsProgressCategoryCallback";
|
||||||
|
|
||||||
|
private final Context mContext;
|
||||||
private final AudioStreamsProgressCategoryController mCategoryController;
|
private final AudioStreamsProgressCategoryController mCategoryController;
|
||||||
|
|
||||||
public AudioStreamsProgressCategoryCallback(
|
public AudioStreamsProgressCategoryCallback(
|
||||||
|
Context context,
|
||||||
AudioStreamsProgressCategoryController audioStreamsProgressCategoryController) {
|
AudioStreamsProgressCategoryController audioStreamsProgressCategoryController) {
|
||||||
|
mContext = context;
|
||||||
mCategoryController = audioStreamsProgressCategoryController;
|
mCategoryController = audioStreamsProgressCategoryController;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -41,7 +46,8 @@ public class AudioStreamsProgressCategoryCallback extends AudioStreamsBroadcastA
|
|||||||
mCategoryController.handleSourceConnected(state);
|
mCategoryController.handleSourceConnected(state);
|
||||||
} else if (AudioStreamsHelper.isBadCode(state)) {
|
} else if (AudioStreamsHelper.isBadCode(state)) {
|
||||||
mCategoryController.handleSourceConnectBadCode(state);
|
mCategoryController.handleSourceConnectBadCode(state);
|
||||||
} else if (audioSharingHysteresisModeFix() && AudioStreamsHelper.hasSourcePresent(state)) {
|
} else if (BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
|
&& AudioStreamsHelper.hasSourcePresent(state)) {
|
||||||
// Keep this check as the last, source might also present in above states
|
// Keep this check as the last, source might also present in above states
|
||||||
mCategoryController.handleSourcePresent(state);
|
mCategoryController.handleSourcePresent(state);
|
||||||
}
|
}
|
||||||
|
@@ -16,8 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.audioSharingHysteresisModeFix;
|
|
||||||
|
|
||||||
import static java.util.Collections.emptyList;
|
import static java.util.Collections.emptyList;
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
@@ -101,7 +99,7 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
(p.getAudioStreamState()
|
(p.getAudioStreamState()
|
||||||
== AudioStreamsProgressCategoryController
|
== AudioStreamsProgressCategoryController
|
||||||
.AudioStreamState.SOURCE_ADDED
|
.AudioStreamState.SOURCE_ADDED
|
||||||
|| (audioSharingHysteresisModeFix()
|
|| (isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
&& p.getAudioStreamState()
|
&& p.getAudioStreamState()
|
||||||
== AudioStreamsProgressCategoryController
|
== AudioStreamsProgressCategoryController
|
||||||
.AudioStreamState
|
.AudioStreamState
|
||||||
@@ -147,7 +145,7 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
mAudioStreamsHelper = new AudioStreamsHelper(mBluetoothManager);
|
mAudioStreamsHelper = new AudioStreamsHelper(mBluetoothManager);
|
||||||
mMediaControlHelper = new MediaControlHelper(mContext, mBluetoothManager);
|
mMediaControlHelper = new MediaControlHelper(mContext, mBluetoothManager);
|
||||||
mLeBroadcastAssistant = mAudioStreamsHelper.getLeBroadcastAssistant();
|
mLeBroadcastAssistant = mAudioStreamsHelper.getLeBroadcastAssistant();
|
||||||
mBroadcastAssistantCallback = new AudioStreamsProgressCategoryCallback(this);
|
mBroadcastAssistantCallback = new AudioStreamsProgressCategoryCallback(context, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -258,7 +256,7 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
// change it's state.
|
// change it's state.
|
||||||
existingPreference.setAudioStreamMetadata(source);
|
existingPreference.setAudioStreamMetadata(source);
|
||||||
if (fromState != AudioStreamState.SOURCE_ADDED
|
if (fromState != AudioStreamState.SOURCE_ADDED
|
||||||
&& (!audioSharingHysteresisModeFix()
|
&& (!isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
|| fromState != AudioStreamState.SOURCE_PRESENT)) {
|
|| fromState != AudioStreamState.SOURCE_PRESENT)) {
|
||||||
Log.w(
|
Log.w(
|
||||||
TAG,
|
TAG,
|
||||||
@@ -364,7 +362,7 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
// not, means the source is removed from the sink, we move back the preference to SYNCED
|
// not, means the source is removed from the sink, we move back the preference to SYNCED
|
||||||
// state.
|
// state.
|
||||||
if ((preference.getAudioStreamState() == AudioStreamState.SOURCE_ADDED
|
if ((preference.getAudioStreamState() == AudioStreamState.SOURCE_ADDED
|
||||||
|| (audioSharingHysteresisModeFix()
|
|| (isAudioSharingHysteresisModeFixAvailable(mContext)
|
||||||
&& preference.getAudioStreamState()
|
&& preference.getAudioStreamState()
|
||||||
== AudioStreamState.SOURCE_PRESENT))
|
== AudioStreamState.SOURCE_PRESENT))
|
||||||
&& mAudioStreamsHelper.getAllConnectedSources().stream()
|
&& mAudioStreamsHelper.getAllConnectedSources().stream()
|
||||||
@@ -600,7 +598,7 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
// Handle QR code scan, display currently connected streams then start scanning
|
// Handle QR code scan, display currently connected streams then start scanning
|
||||||
// sequentially
|
// sequentially
|
||||||
handleSourceFromQrCodeIfExists();
|
handleSourceFromQrCodeIfExists();
|
||||||
if (audioSharingHysteresisModeFix()) {
|
if (isAudioSharingHysteresisModeFixAvailable(mContext)) {
|
||||||
// With hysteresis mode, we prioritize showing connected sources first.
|
// With hysteresis mode, we prioritize showing connected sources first.
|
||||||
// If no connected sources are found, we then show present sources.
|
// If no connected sources are found, we then show present sources.
|
||||||
List<BluetoothLeBroadcastReceiveState> sources =
|
List<BluetoothLeBroadcastReceiveState> sources =
|
||||||
@@ -702,4 +700,8 @@ public class AudioStreamsProgressCategoryController extends BasePreferenceContro
|
|||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean isAudioSharingHysteresisModeFixAvailable(Context context) {
|
||||||
|
return BluetoothUtils.isAudioSharingHysteresisModeFixAvailable(context);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
@@ -31,10 +32,12 @@ import static org.mockito.Mockito.verify;
|
|||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
||||||
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
@@ -46,6 +49,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
@@ -62,6 +66,7 @@ import org.mockito.junit.MockitoJUnit;
|
|||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@@ -73,6 +78,7 @@ import java.util.concurrent.Executor;
|
|||||||
shadows = {
|
shadows = {
|
||||||
ShadowThreadUtils.class,
|
ShadowThreadUtils.class,
|
||||||
ShadowAudioStreamsHelper.class,
|
ShadowAudioStreamsHelper.class,
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
})
|
})
|
||||||
public class AudioStreamButtonControllerTest {
|
public class AudioStreamButtonControllerTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@@ -95,6 +101,13 @@ public class AudioStreamButtonControllerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
||||||
when(mAudioStreamsHelper.getLeBroadcastAssistant()).thenReturn(mAssistant);
|
when(mAudioStreamsHelper.getLeBroadcastAssistant()).thenReturn(mAssistant);
|
||||||
mFeatureFactory = FakeFeatureFactory.setupForTest();
|
mFeatureFactory = FakeFeatureFactory.setupForTest();
|
||||||
@@ -261,6 +274,7 @@ public class AudioStreamButtonControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCallback_onReceiveStateChangedWithSourcePresent_updateButton() {
|
public void testCallback_onReceiveStateChangedWithSourcePresent_updateButton() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
String address = "11:22:33:44:55:66";
|
String address = "11:22:33:44:55:66";
|
||||||
|
|
||||||
|
@@ -20,6 +20,7 @@ import static com.android.settings.connecteddevice.audiosharing.audiostreams.Aud
|
|||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamHeaderController.AUDIO_STREAM_HEADER_NOT_LISTENING_SUMMARY;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamHeaderController.AUDIO_STREAM_HEADER_NOT_LISTENING_SUMMARY;
|
||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamHeaderController.AUDIO_STREAM_HEADER_PRESENT_NOW_SUMMARY;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamHeaderController.AUDIO_STREAM_HEADER_PRESENT_NOW_SUMMARY;
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
@@ -28,9 +29,11 @@ import static org.mockito.Mockito.times;
|
|||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
import android.bluetooth.BluetoothLeBroadcastAssistant;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
@@ -41,6 +44,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
||||||
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowEntityHeaderController;
|
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowEntityHeaderController;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
||||||
import com.android.settings.widget.EntityHeaderController;
|
import com.android.settings.widget.EntityHeaderController;
|
||||||
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
import com.android.settingslib.bluetooth.LocalBluetoothLeBroadcastAssistant;
|
||||||
@@ -57,6 +61,7 @@ import org.mockito.junit.MockitoJUnit;
|
|||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@@ -69,6 +74,7 @@ import java.util.concurrent.Executor;
|
|||||||
ShadowEntityHeaderController.class,
|
ShadowEntityHeaderController.class,
|
||||||
ShadowThreadUtils.class,
|
ShadowThreadUtils.class,
|
||||||
ShadowAudioStreamsHelper.class,
|
ShadowAudioStreamsHelper.class,
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
})
|
})
|
||||||
public class AudioStreamHeaderControllerTest {
|
public class AudioStreamHeaderControllerTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@@ -93,6 +99,13 @@ public class AudioStreamHeaderControllerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
|
||||||
ShadowEntityHeaderController.setUseMock(mHeaderController);
|
ShadowEntityHeaderController.setUseMock(mHeaderController);
|
||||||
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
||||||
@@ -260,6 +273,7 @@ public class AudioStreamHeaderControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCallback_onReceiveStateChangedWithSourcePresent_updateButton() {
|
public void testCallback_onReceiveStateChangedWithSourcePresent_updateButton() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
String address = "11:22:33:44:55:66";
|
String address = "11:22:33:44:55:66";
|
||||||
|
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
@@ -31,6 +32,8 @@ import static org.mockito.Mockito.spy;
|
|||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.text.SpannableString;
|
import android.text.SpannableString;
|
||||||
@@ -38,6 +41,8 @@ import android.text.SpannableString;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -47,8 +52,14 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.junit.MockitoJUnit;
|
import org.mockito.junit.MockitoJUnit;
|
||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(
|
||||||
|
shadows = {
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
|
})
|
||||||
public class AudioStreamStateHandlerTest {
|
public class AudioStreamStateHandlerTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@Rule public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
|
@Rule public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
|
||||||
@@ -64,6 +75,13 @@ public class AudioStreamStateHandlerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
mHandler = spy(new AudioStreamStateHandler());
|
mHandler = spy(new AudioStreamStateHandler());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -109,6 +127,7 @@ public class AudioStreamStateHandlerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testHandleStateChange_setNewState_sourcePresent() {
|
public void testHandleStateChange_setNewState_sourcePresent() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
|
||||||
when(mHandler.getStateEnum())
|
when(mHandler.getStateEnum())
|
||||||
|
@@ -135,47 +135,47 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_flagOn() {
|
public void getAvailabilityStatus_flagOn() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_flagOff() {
|
public void getAvailabilityStatus_flagOff() {
|
||||||
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onStart_flagOff_doNothing() {
|
public void onStart_flagOff_doNothing() {
|
||||||
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.onStart(mLifecycleOwner);
|
mController.onStart(mLifecycleOwner);
|
||||||
verify(mBluetoothEventManager, never()).registerCallback(any());
|
verify(mBluetoothEventManager, never()).registerCallback(any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onStart_flagOn_registerCallback() {
|
public void onStart_flagOn_registerCallback() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.onStart(mLifecycleOwner);
|
mController.onStart(mLifecycleOwner);
|
||||||
verify(mBluetoothEventManager).registerCallback(any());
|
verify(mBluetoothEventManager).registerCallback(any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onStop_flagOff_doNothing() {
|
public void onStop_flagOff_doNothing() {
|
||||||
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.onStop(mLifecycleOwner);
|
mController.onStop(mLifecycleOwner);
|
||||||
verify(mBluetoothEventManager, never()).unregisterCallback(any());
|
verify(mBluetoothEventManager, never()).unregisterCallback(any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onStop_flagOn_unregisterCallback() {
|
public void onStop_flagOn_unregisterCallback() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.onStop(mLifecycleOwner);
|
mController.onStop(mLifecycleOwner);
|
||||||
verify(mBluetoothEventManager).unregisterCallback(any());
|
verify(mBluetoothEventManager).unregisterCallback(any());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_flagOff_invisible() {
|
public void updateVisibility_flagOff_invisible() {
|
||||||
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.disableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.updateVisibility();
|
mController.updateVisibility();
|
||||||
shadowOf(Looper.getMainLooper()).idle();
|
shadowOf(Looper.getMainLooper()).idle();
|
||||||
assertThat(mPreference.isVisible()).isFalse();
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
@@ -183,7 +183,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_noConnectedLe_invisible() {
|
public void updateVisibility_noConnectedLe_invisible() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mController.updateVisibility();
|
mController.updateVisibility();
|
||||||
shadowOf(Looper.getMainLooper()).idle();
|
shadowOf(Looper.getMainLooper()).idle();
|
||||||
assertThat(mPreference.isVisible()).isFalse();
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
@@ -191,7 +191,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_isNotProfileReady_invisible() {
|
public void updateVisibility_isNotProfileReady_invisible() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
||||||
mCachedBluetoothDevice);
|
mCachedBluetoothDevice);
|
||||||
when(mVolumeControl.isProfileReady()).thenReturn(false);
|
when(mVolumeControl.isProfileReady()).thenReturn(false);
|
||||||
@@ -202,7 +202,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_isBroadcasting_invisible() {
|
public void updateVisibility_isBroadcasting_invisible() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
||||||
mCachedBluetoothDevice);
|
mCachedBluetoothDevice);
|
||||||
when(mBroadcast.isEnabled(any())).thenReturn(true);
|
when(mBroadcast.isEnabled(any())).thenReturn(true);
|
||||||
@@ -213,7 +213,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_isBluetoothOff_invisible() {
|
public void updateVisibility_isBluetoothOff_invisible() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
||||||
mCachedBluetoothDevice);
|
mCachedBluetoothDevice);
|
||||||
mShadowBluetoothAdapter.setEnabled(false);
|
mShadowBluetoothAdapter.setEnabled(false);
|
||||||
@@ -224,7 +224,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateVisibility_visible() {
|
public void updateVisibility_visible() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
ShadowAudioStreamsHelper.setCachedBluetoothDeviceInSharingOrLeConnected(
|
||||||
mCachedBluetoothDevice);
|
mCachedBluetoothDevice);
|
||||||
mController.displayPreference(mScreen);
|
mController.displayPreference(mScreen);
|
||||||
@@ -235,7 +235,7 @@ public class AudioStreamsCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onProfileConnectionStateChanged_updateVisibility() {
|
public void onProfileConnectionStateChanged_updateVisibility() {
|
||||||
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_QR_CODE_PRIVATE_BROADCAST_SHARING);
|
mSetFlagsRule.enableFlags(Flags.FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
ArgumentCaptor<BluetoothCallback> argumentCaptor =
|
ArgumentCaptor<BluetoothCallback> argumentCaptor =
|
||||||
ArgumentCaptor.forClass(BluetoothCallback.class);
|
ArgumentCaptor.forClass(BluetoothCallback.class);
|
||||||
mController.onStart(mLifecycleOwner);
|
mController.onStart(mLifecycleOwner);
|
||||||
|
@@ -20,6 +20,7 @@ import static android.content.res.Configuration.ORIENTATION_LANDSCAPE;
|
|||||||
import static android.content.res.Configuration.ORIENTATION_PORTRAIT;
|
import static android.content.res.Configuration.ORIENTATION_PORTRAIT;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
@@ -33,9 +34,11 @@ import static org.mockito.Mockito.spy;
|
|||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
@@ -45,6 +48,7 @@ import androidx.fragment.app.FragmentActivity;
|
|||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
import com.android.settingslib.bluetooth.CachedBluetoothDevice;
|
||||||
import com.android.settingslib.bluetooth.CachedBluetoothDeviceManager;
|
import com.android.settingslib.bluetooth.CachedBluetoothDeviceManager;
|
||||||
@@ -65,6 +69,7 @@ import org.mockito.junit.MockitoJUnit;
|
|||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@@ -74,6 +79,7 @@ import java.util.List;
|
|||||||
@Config(
|
@Config(
|
||||||
shadows = {
|
shadows = {
|
||||||
ShadowThreadUtils.class,
|
ShadowThreadUtils.class,
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
})
|
})
|
||||||
public class AudioStreamsHelperTest {
|
public class AudioStreamsHelperTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@@ -97,6 +103,13 @@ public class AudioStreamsHelperTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
when(mLocalBluetoothManager.getProfileManager()).thenReturn(mLocalBluetoothProfileManager);
|
when(mLocalBluetoothManager.getProfileManager()).thenReturn(mLocalBluetoothProfileManager);
|
||||||
when(mLocalBluetoothManager.getCachedDeviceManager()).thenReturn(mDeviceManager);
|
when(mLocalBluetoothManager.getCachedDeviceManager()).thenReturn(mDeviceManager);
|
||||||
when(mLocalBluetoothProfileManager.getLeAudioBroadcastAssistantProfile())
|
when(mLocalBluetoothProfileManager.getLeAudioBroadcastAssistantProfile())
|
||||||
@@ -229,6 +242,7 @@ public class AudioStreamsHelperTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAllPresentSources_noSource() {
|
public void getAllPresentSources_noSource() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
|
||||||
List<BluetoothDevice> devices = new ArrayList<>();
|
List<BluetoothDevice> devices = new ArrayList<>();
|
||||||
@@ -251,6 +265,7 @@ public class AudioStreamsHelperTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAllPresentSources_returnSource() {
|
public void getAllPresentSources_returnSource() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
String address = "11:22:33:44:55:66";
|
String address = "11:22:33:44:55:66";
|
||||||
|
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
package com.android.settings.connecteddevice.audiosharing.audiostreams;
|
||||||
|
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyBoolean;
|
import static org.mockito.ArgumentMatchers.anyBoolean;
|
||||||
@@ -24,11 +25,18 @@ import static org.mockito.ArgumentMatchers.anyString;
|
|||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.bluetooth.BluetoothAdapter;
|
||||||
import android.bluetooth.BluetoothDevice;
|
import android.bluetooth.BluetoothDevice;
|
||||||
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
|
import android.content.Context;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
|
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Rule;
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -37,15 +45,21 @@ import org.mockito.Mock;
|
|||||||
import org.mockito.junit.MockitoJUnit;
|
import org.mockito.junit.MockitoJUnit;
|
||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(
|
||||||
|
shadows = {
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
|
})
|
||||||
public class AudioStreamsProgressCategoryCallbackTest {
|
public class AudioStreamsProgressCategoryCallbackTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@Rule public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
|
@Rule public final SetFlagsRule mSetFlagsRule = new SetFlagsRule();
|
||||||
|
private final Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
@Mock private AudioStreamsProgressCategoryController mController;
|
@Mock private AudioStreamsProgressCategoryController mController;
|
||||||
@Mock private BluetoothDevice mDevice;
|
@Mock private BluetoothDevice mDevice;
|
||||||
@Mock private BluetoothLeBroadcastReceiveState mState;
|
@Mock private BluetoothLeBroadcastReceiveState mState;
|
||||||
@@ -56,7 +70,14 @@ public class AudioStreamsProgressCategoryCallbackTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.disableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
mCallback = new AudioStreamsProgressCategoryCallback(mController);
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
mCallback = new AudioStreamsProgressCategoryCallback(mContext, mController);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -71,6 +92,7 @@ public class AudioStreamsProgressCategoryCallbackTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testOnReceiveStateChanged_sourcePresent() {
|
public void testOnReceiveStateChanged_sourcePresent() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
String address = "11:22:33:44:55:66";
|
String address = "11:22:33:44:55:66";
|
||||||
|
|
||||||
|
@@ -26,6 +26,7 @@ import static com.android.settings.connecteddevice.audiosharing.audiostreams.Aud
|
|||||||
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamsProgressCategoryController.UNSET_BROADCAST_ID;
|
import static com.android.settings.connecteddevice.audiosharing.audiostreams.AudioStreamsProgressCategoryController.UNSET_BROADCAST_ID;
|
||||||
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
|
||||||
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
import static com.android.settingslib.flags.Flags.FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX;
|
||||||
|
import static com.android.settingslib.flags.Flags.FLAG_ENABLE_LE_AUDIO_SHARING;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
@@ -48,6 +49,7 @@ import android.bluetooth.BluetoothLeAudioContentMetadata;
|
|||||||
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
import android.bluetooth.BluetoothLeBroadcastMetadata;
|
||||||
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
import android.bluetooth.BluetoothLeBroadcastReceiveState;
|
||||||
import android.bluetooth.BluetoothProfile;
|
import android.bluetooth.BluetoothProfile;
|
||||||
|
import android.bluetooth.BluetoothStatusCodes;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.platform.test.flag.junit.SetFlagsRule;
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
@@ -62,6 +64,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
import com.android.settings.connecteddevice.audiosharing.audiostreams.testshadows.ShadowAudioStreamsHelper;
|
||||||
|
import com.android.settings.testutils.shadow.ShadowBluetoothAdapter;
|
||||||
import com.android.settings.testutils.shadow.ShadowBluetoothUtils;
|
import com.android.settings.testutils.shadow.ShadowBluetoothUtils;
|
||||||
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
import com.android.settings.testutils.shadow.ShadowThreadUtils;
|
||||||
import com.android.settingslib.bluetooth.BluetoothEventManager;
|
import com.android.settingslib.bluetooth.BluetoothEventManager;
|
||||||
@@ -84,6 +87,7 @@ import org.mockito.junit.MockitoJUnit;
|
|||||||
import org.mockito.junit.MockitoRule;
|
import org.mockito.junit.MockitoRule;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.annotation.Config;
|
import org.robolectric.annotation.Config;
|
||||||
|
import org.robolectric.shadow.api.Shadow;
|
||||||
import org.robolectric.shadows.ShadowAlertDialog;
|
import org.robolectric.shadows.ShadowAlertDialog;
|
||||||
import org.robolectric.shadows.androidx.fragment.FragmentController;
|
import org.robolectric.shadows.androidx.fragment.FragmentController;
|
||||||
|
|
||||||
@@ -97,6 +101,7 @@ import java.util.List;
|
|||||||
ShadowAudioStreamsHelper.class,
|
ShadowAudioStreamsHelper.class,
|
||||||
ShadowThreadUtils.class,
|
ShadowThreadUtils.class,
|
||||||
ShadowAlertDialog.class,
|
ShadowAlertDialog.class,
|
||||||
|
ShadowBluetoothAdapter.class,
|
||||||
})
|
})
|
||||||
public class AudioStreamsProgressCategoryControllerTest {
|
public class AudioStreamsProgressCategoryControllerTest {
|
||||||
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
@Rule public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
@@ -129,6 +134,13 @@ public class AudioStreamsProgressCategoryControllerTest {
|
|||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
|
ShadowBluetoothAdapter shadowBluetoothAdapter = Shadow.extract(
|
||||||
|
BluetoothAdapter.getDefaultAdapter());
|
||||||
|
shadowBluetoothAdapter.setEnabled(true);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastSourceSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
|
shadowBluetoothAdapter.setIsLeAudioBroadcastAssistantSupported(
|
||||||
|
BluetoothStatusCodes.FEATURE_SUPPORTED);
|
||||||
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
ShadowAudioStreamsHelper.setUseMock(mAudioStreamsHelper);
|
||||||
when(mAudioStreamsHelper.getLeBroadcastAssistant()).thenReturn(mLeBroadcastAssistant);
|
when(mAudioStreamsHelper.getLeBroadcastAssistant()).thenReturn(mLeBroadcastAssistant);
|
||||||
when(mAudioStreamsHelper.getAllConnectedSources()).thenReturn(emptyList());
|
when(mAudioStreamsHelper.getAllConnectedSources()).thenReturn(emptyList());
|
||||||
@@ -292,6 +304,7 @@ public class AudioStreamsProgressCategoryControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testOnStart_initHasDevice_getPresentSources() {
|
public void testOnStart_initHasDevice_getPresentSources() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_ENABLE_LE_AUDIO_SHARING);
|
||||||
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
mSetFlagsRule.enableFlags(FLAG_AUDIO_SHARING_HYSTERESIS_MODE_FIX);
|
||||||
|
|
||||||
// Setup a device
|
// Setup a device
|
||||||
|
Reference in New Issue
Block a user