Remove drawer from settings
Change-Id: Ib11376206cf8366c86c427104c47740c3ca8b0d0 Fix: 35809663 Test: make RunSettingsRoboTests
This commit is contained in:
@@ -1,21 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Copyright (C) 2016 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<com.android.settings.widget.RtlCompatibleViewPager
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:id="@+id/pager"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="match_parent"/>
|
|
@@ -1,23 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Copyright (C) 2016 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<com.android.settings.widget.SlidingTabLayout
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:id="@+id/sliding_tabs"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="wrap_content"
|
|
||||||
android:layout_marginStart="@dimen/dashboard_header_margin_start"
|
|
||||||
android:layout_marginEnd="@dimen/dashboard_header_margin_end"/>
|
|
@@ -21,10 +21,6 @@
|
|||||||
<dimen name="dashboard_padding_start">160dp</dimen>
|
<dimen name="dashboard_padding_start">160dp</dimen>
|
||||||
<dimen name="dashboard_padding_end">160dp</dimen>
|
<dimen name="dashboard_padding_end">160dp</dimen>
|
||||||
|
|
||||||
<!-- Dashboard Header margin in its container -->
|
|
||||||
<dimen name="dashboard_header_margin_start">304dp</dimen>
|
|
||||||
<dimen name="dashboard_header_margin_end">304dp</dimen>
|
|
||||||
|
|
||||||
<!-- ActionBar contentInsetStart -->
|
<!-- ActionBar contentInsetStart -->
|
||||||
<dimen name="actionbar_contentInsetStart">128dp</dimen>
|
<dimen name="actionbar_contentInsetStart">128dp</dimen>
|
||||||
<dimen name="actionbar_subsettings_contentInsetStart">128dp</dimen>
|
<dimen name="actionbar_subsettings_contentInsetStart">128dp</dimen>
|
||||||
|
@@ -42,10 +42,6 @@
|
|||||||
<dimen name="dashboard_padding_start">80dp</dimen>
|
<dimen name="dashboard_padding_start">80dp</dimen>
|
||||||
<dimen name="dashboard_padding_end">80dp</dimen>
|
<dimen name="dashboard_padding_end">80dp</dimen>
|
||||||
|
|
||||||
<!-- Dashboard Header margin in its container -->
|
|
||||||
<dimen name="dashboard_header_margin_start">176dp</dimen>
|
|
||||||
<dimen name="dashboard_header_margin_end">176dp</dimen>
|
|
||||||
|
|
||||||
<!-- Dashboard category padding start / end -->
|
<!-- Dashboard category padding start / end -->
|
||||||
<dimen name="dashboard_category_padding_start">24dp</dimen>
|
<dimen name="dashboard_category_padding_start">24dp</dimen>
|
||||||
<dimen name="dashboard_category_padding_end">24dp</dimen>
|
<dimen name="dashboard_category_padding_end">24dp</dimen>
|
||||||
|
@@ -88,10 +88,6 @@
|
|||||||
<dimen name="dashboard_padding_top">0dp</dimen>
|
<dimen name="dashboard_padding_top">0dp</dimen>
|
||||||
<dimen name="dashboard_padding_bottom">0dp</dimen>
|
<dimen name="dashboard_padding_bottom">0dp</dimen>
|
||||||
|
|
||||||
<!-- Dashboard Header margin in its container -->
|
|
||||||
<dimen name="dashboard_header_margin_start">0dp</dimen>
|
|
||||||
<dimen name="dashboard_header_margin_end">0dp</dimen>
|
|
||||||
|
|
||||||
<!-- Dashboard category padding start / end -->
|
<!-- Dashboard category padding start / end -->
|
||||||
<dimen name="dashboard_category_padding_start">0dp</dimen>
|
<dimen name="dashboard_category_padding_start">0dp</dimen>
|
||||||
<dimen name="dashboard_category_padding_end">0dp</dimen>
|
<dimen name="dashboard_category_padding_end">0dp</dimen>
|
||||||
|
@@ -58,7 +58,6 @@ import com.android.settings.backup.BackupSettingsActivity;
|
|||||||
import com.android.settings.core.gateway.SettingsGateway;
|
import com.android.settings.core.gateway.SettingsGateway;
|
||||||
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
import com.android.settings.core.instrumentation.SharedPreferencesLogger;
|
import com.android.settings.core.instrumentation.SharedPreferencesLogger;
|
||||||
import com.android.settings.dashboard.DashboardContainerFragment;
|
|
||||||
import com.android.settings.dashboard.DashboardFeatureProvider;
|
import com.android.settings.dashboard.DashboardFeatureProvider;
|
||||||
import com.android.settings.dashboard.DashboardSummary;
|
import com.android.settings.dashboard.DashboardSummary;
|
||||||
import com.android.settings.dashboard.SearchResultsSummary;
|
import com.android.settings.dashboard.SearchResultsSummary;
|
||||||
@@ -154,6 +153,7 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
public static final String EXTRA_SHOW_FRAGMENT_AS_SUBSETTING =
|
public static final String EXTRA_SHOW_FRAGMENT_AS_SUBSETTING =
|
||||||
":settings:show_fragment_as_subsetting";
|
":settings:show_fragment_as_subsetting";
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
public static final String EXTRA_HIDE_DRAWER = ":settings:hide_drawer";
|
public static final String EXTRA_HIDE_DRAWER = ":settings:hide_drawer";
|
||||||
|
|
||||||
public static final String META_DATA_KEY_FRAGMENT_CLASS =
|
public static final String META_DATA_KEY_FRAGMENT_CLASS =
|
||||||
@@ -367,9 +367,6 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
if (intent.hasExtra(EXTRA_UI_OPTIONS)) {
|
if (intent.hasExtra(EXTRA_UI_OPTIONS)) {
|
||||||
getWindow().setUiOptions(intent.getIntExtra(EXTRA_UI_OPTIONS, 0));
|
getWindow().setUiOptions(intent.getIntExtra(EXTRA_UI_OPTIONS, 0));
|
||||||
}
|
}
|
||||||
if (intent.getBooleanExtra(EXTRA_HIDE_DRAWER, false)) {
|
|
||||||
setIsDrawerPresent(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
mDevelopmentPreferences = getSharedPreferences(DevelopmentSettings.PREF_FILE,
|
mDevelopmentPreferences = getSharedPreferences(DevelopmentSettings.PREF_FILE,
|
||||||
Context.MODE_PRIVATE);
|
Context.MODE_PRIVATE);
|
||||||
@@ -461,17 +458,8 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
mDisplaySearch = true;
|
mDisplaySearch = true;
|
||||||
mInitialTitleResId = R.string.dashboard_title;
|
mInitialTitleResId = R.string.dashboard_title;
|
||||||
|
|
||||||
// add argument to indicate which settings tab should be initially selected
|
switchToFragment(DashboardSummary.class.getName(), null /* args */, false, false,
|
||||||
final Bundle args = new Bundle();
|
|
||||||
final String extraName = DashboardContainerFragment.EXTRA_SELECT_SETTINGS_TAB;
|
|
||||||
args.putString(extraName, intent.getStringExtra(extraName));
|
|
||||||
if (isDashboardFeatureEnabled()) {
|
|
||||||
switchToFragment(DashboardSummary.class.getName(), args, false, false,
|
|
||||||
mInitialTitleResId, mInitialTitle, false);
|
mInitialTitleResId, mInitialTitle, false);
|
||||||
} else {
|
|
||||||
switchToFragment(DashboardContainerFragment.class.getName(), args, false, false,
|
|
||||||
mInitialTitleResId, mInitialTitle, false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -957,12 +945,7 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
|
|
||||||
if (UserHandle.MU_ENABLED && !isAdmin) {
|
if (UserHandle.MU_ENABLED && !isAdmin) {
|
||||||
// When on restricted users, disable all extra categories (but only the settings ones).
|
// When on restricted users, disable all extra categories (but only the settings ones).
|
||||||
List<DashboardCategory> categories;
|
final List<DashboardCategory> categories = mDashboardFeatureProvider.getAllCategories();
|
||||||
if (isDashboardFeatureEnabled()) {
|
|
||||||
categories = mDashboardFeatureProvider.getAllCategories();
|
|
||||||
} else {
|
|
||||||
categories = getDashboardCategories();
|
|
||||||
}
|
|
||||||
|
|
||||||
for (DashboardCategory category : categories) {
|
for (DashboardCategory category : categories) {
|
||||||
for (Tile tile : category.tiles) {
|
for (Tile tile : category.tiles) {
|
||||||
@@ -1017,15 +1000,6 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean isDashboardFeatureEnabled() {
|
|
||||||
if (mDashboardFeatureProvider == null) {
|
|
||||||
mDashboardFeatureProvider =
|
|
||||||
FeatureFactory.getFactory(this).getDashboardFeatureProvider(this);
|
|
||||||
}
|
|
||||||
return mDashboardFeatureProvider.isEnabled();
|
|
||||||
}
|
|
||||||
|
|
||||||
// give subclasses access to the Next button
|
// give subclasses access to the Next button
|
||||||
public boolean hasNextButton() {
|
public boolean hasNextButton() {
|
||||||
return mNextButton != null;
|
return mNextButton != null;
|
||||||
@@ -1084,16 +1058,6 @@ public class SettingsActivity extends SettingsDrawerActivity
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onTileClicked(Tile tile) {
|
|
||||||
if (mIsShowingDashboard) {
|
|
||||||
// If on dashboard, don't finish so the back comes back to here.
|
|
||||||
openTile(tile);
|
|
||||||
} else {
|
|
||||||
super.onTileClicked(tile);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onProfileTileOpen() {
|
public void onProfileTileOpen() {
|
||||||
if (!mIsShowingDashboard) {
|
if (!mIsShowingDashboard) {
|
||||||
|
@@ -46,7 +46,6 @@ public class AccessibilitySettingsForSetupWizardActivity extends SettingsActivit
|
|||||||
|
|
||||||
// Finish configuring the content view.
|
// Finish configuring the content view.
|
||||||
getActionBar().setDisplayHomeAsUpEnabled(true);
|
getActionBar().setDisplayHomeAsUpEnabled(true);
|
||||||
setIsDrawerPresent(false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -1,194 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 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.dashboard;
|
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.app.Fragment;
|
|
||||||
import android.app.FragmentManager;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.os.Bundle;
|
|
||||||
import android.support.v13.app.FragmentPagerAdapter;
|
|
||||||
import android.text.TextUtils;
|
|
||||||
import android.view.LayoutInflater;
|
|
||||||
import android.view.View;
|
|
||||||
import android.view.ViewGroup;
|
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto;
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settings.SettingsActivity;
|
|
||||||
import com.android.settings.core.InstrumentedFragment;
|
|
||||||
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
|
||||||
import com.android.settings.overlay.SupportFeatureProvider;
|
|
||||||
import com.android.settings.widget.RtlCompatibleViewPager;
|
|
||||||
import com.android.settings.widget.SlidingTabLayout;
|
|
||||||
import com.android.settingslib.drawer.SettingsDrawerActivity;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Container for Dashboard fragments.
|
|
||||||
*/
|
|
||||||
public final class DashboardContainerFragment extends InstrumentedFragment {
|
|
||||||
|
|
||||||
public static final String EXTRA_SELECT_SETTINGS_TAB = ":settings:select_settings_tab";
|
|
||||||
|
|
||||||
private static final String ARG_SUPPORT_TAB = "SUPPORT";
|
|
||||||
private static final String ARG_SUMMARY_TAB = "SUMMARY";
|
|
||||||
private static final int INDEX_SUMMARY_FRAGMENT = 0;
|
|
||||||
private static final int INDEX_SUPPORT_FRAGMENT = 1;
|
|
||||||
|
|
||||||
private RtlCompatibleViewPager mViewPager;
|
|
||||||
private View mHeaderView;
|
|
||||||
private DashboardViewPagerAdapter mPagerAdapter;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getMetricsCategory() {
|
|
||||||
return MetricsProto.MetricsEvent.DASHBOARD_CONTAINER;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
|
||||||
setHasOptionsMenu(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public View onCreateView(LayoutInflater inflater, ViewGroup parent, Bundle savedInstanceState) {
|
|
||||||
final View content = inflater.inflate(R.layout.dashboard_container, parent, false);
|
|
||||||
mViewPager = (RtlCompatibleViewPager) content.findViewById(R.id.pager);
|
|
||||||
mPagerAdapter = new DashboardViewPagerAdapter(getContext(),
|
|
||||||
getChildFragmentManager(), mViewPager);
|
|
||||||
mViewPager.setAdapter(mPagerAdapter);
|
|
||||||
mViewPager.addOnPageChangeListener(
|
|
||||||
new TabChangeListener((SettingsActivity) getActivity(), mMetricsFeatureProvider));
|
|
||||||
|
|
||||||
// check if support tab needs to be selected
|
|
||||||
final String selectedTab = getArguments().
|
|
||||||
getString(EXTRA_SELECT_SETTINGS_TAB, ARG_SUMMARY_TAB);
|
|
||||||
if (TextUtils.equals(selectedTab, ARG_SUPPORT_TAB)) {
|
|
||||||
mViewPager.setCurrentItem(INDEX_SUPPORT_FRAGMENT);
|
|
||||||
} else {
|
|
||||||
mViewPager.setCurrentItem(INDEX_SUMMARY_FRAGMENT);
|
|
||||||
}
|
|
||||||
|
|
||||||
mHeaderView = inflater.inflate(R.layout.dashboard_container_header, parent, false);
|
|
||||||
((SlidingTabLayout) mHeaderView).setViewPager(mViewPager);
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onResume() {
|
|
||||||
super.onResume();
|
|
||||||
if (mPagerAdapter.getCount() > 1) {
|
|
||||||
final Activity activity = getActivity();
|
|
||||||
if (activity instanceof SettingsDrawerActivity) {
|
|
||||||
((SettingsDrawerActivity) getActivity()).setContentHeaderView(mHeaderView);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final class DashboardViewPagerAdapter extends FragmentPagerAdapter {
|
|
||||||
|
|
||||||
private final Context mContext;
|
|
||||||
private final SupportFeatureProvider mSupportFeatureProvider;
|
|
||||||
private final RtlCompatibleViewPager mViewPager;
|
|
||||||
|
|
||||||
public DashboardViewPagerAdapter(Context context, FragmentManager fragmentManager,
|
|
||||||
RtlCompatibleViewPager viewPager) {
|
|
||||||
super(fragmentManager);
|
|
||||||
mContext = context;
|
|
||||||
mSupportFeatureProvider =
|
|
||||||
FeatureFactory.getFactory(context).getSupportFeatureProvider(context);
|
|
||||||
mViewPager = viewPager;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public CharSequence getPageTitle(int position) {
|
|
||||||
switch (position) {
|
|
||||||
case INDEX_SUMMARY_FRAGMENT:
|
|
||||||
return mContext.getString(R.string.page_tab_title_summary);
|
|
||||||
case INDEX_SUPPORT_FRAGMENT:
|
|
||||||
return mContext.getString(R.string.page_tab_title_support);
|
|
||||||
}
|
|
||||||
return super.getPageTitle(position);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Fragment getItem(int position) {
|
|
||||||
switch (position) {
|
|
||||||
case INDEX_SUMMARY_FRAGMENT:
|
|
||||||
return new DashboardSummary();
|
|
||||||
case INDEX_SUPPORT_FRAGMENT:
|
|
||||||
return new SupportFragment();
|
|
||||||
default:
|
|
||||||
throw new IllegalArgumentException(
|
|
||||||
String.format(
|
|
||||||
"Position %d does not map to a valid dashboard fragment",
|
|
||||||
position));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Object instantiateItem(ViewGroup container, int position) {
|
|
||||||
return super.instantiateItem(container,
|
|
||||||
mViewPager.getRtlAwareIndex(position));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getCount() {
|
|
||||||
return mSupportFeatureProvider == null ? 1 : 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final class TabChangeListener
|
|
||||||
implements RtlCompatibleViewPager.OnPageChangeListener {
|
|
||||||
|
|
||||||
private final SettingsActivity mActivity;
|
|
||||||
private final MetricsFeatureProvider mMetricsFeatureProvider;
|
|
||||||
|
|
||||||
public TabChangeListener(SettingsActivity activity,
|
|
||||||
MetricsFeatureProvider metricsFeatureProvider) {
|
|
||||||
mActivity = activity;
|
|
||||||
mMetricsFeatureProvider = metricsFeatureProvider;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
|
|
||||||
// Do nothing.
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPageScrollStateChanged(int state) {
|
|
||||||
// Do nothing
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onPageSelected(int position) {
|
|
||||||
switch (position) {
|
|
||||||
case INDEX_SUMMARY_FRAGMENT:
|
|
||||||
mMetricsFeatureProvider.action(
|
|
||||||
mActivity, MetricsProto.MetricsEvent.ACTION_SELECT_SUMMARY);
|
|
||||||
mActivity.setDisplaySearchMenu(true);
|
|
||||||
break;
|
|
||||||
case INDEX_SUPPORT_FRAGMENT:
|
|
||||||
mMetricsFeatureProvider.action(
|
|
||||||
mActivity, MetricsProto.MetricsEvent.ACTION_SELECT_SUPPORT_FRAGMENT);
|
|
||||||
mActivity.setDisplaySearchMenu(false);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,108 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2016 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.dashboard;
|
|
||||||
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.support.test.InstrumentationRegistry;
|
|
||||||
import android.support.test.filters.SmallTest;
|
|
||||||
import android.support.test.rule.ActivityTestRule;
|
|
||||||
import android.support.test.runner.AndroidJUnit4;
|
|
||||||
import com.android.settings.Settings;
|
|
||||||
import org.junit.Rule;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
|
|
||||||
import static android.support.test.espresso.Espresso.onView;
|
|
||||||
import static android.support.test.espresso.assertion.ViewAssertions.matches;
|
|
||||||
import static android.support.test.espresso.matcher.ViewMatchers.isSelected;
|
|
||||||
import static android.support.test.espresso.matcher.ViewMatchers.withText;
|
|
||||||
import static org.hamcrest.core.IsNot.not;
|
|
||||||
|
|
||||||
@RunWith(AndroidJUnit4.class)
|
|
||||||
@SmallTest
|
|
||||||
public class TabSelectionOnLaunchTest {
|
|
||||||
@Rule
|
|
||||||
public ActivityTestRule<Settings> mActivityRule =
|
|
||||||
new ActivityTestRule<>(Settings.class, true, false);
|
|
||||||
|
|
||||||
private final int FLAG_RESTART = Intent.FLAG_ACTIVITY_CLEAR_TASK|Intent.FLAG_ACTIVITY_NEW_TASK;
|
|
||||||
private final String ARG_SELECT_SUPPORT_TAB = "SUPPORT";
|
|
||||||
private final String ARG_SELECT_FAKE_TAB = "NOT_SUPPORT";
|
|
||||||
|
|
||||||
@Test
|
|
||||||
/* cold start for settings app with correct flags and extra always selects support tab */
|
|
||||||
public void test_ColdStartWithCorrectArgsCorrectFlags_SupportSelected() {
|
|
||||||
launchSettingsWithFlags(ARG_SELECT_SUPPORT_TAB, FLAG_RESTART);
|
|
||||||
verifySupportSelected();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
/* cold start with correct flags and wrong extra defaults to all tab */
|
|
||||||
public void test_ColdStartWithWrongExtra_DoesNotSelectSupport() {
|
|
||||||
launchSettingsWithFlags(ARG_SELECT_FAKE_TAB, FLAG_RESTART);
|
|
||||||
verifySupportNotSelected();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
/* warm start from elsewhere in settings with wrong flags does not select support */
|
|
||||||
public void test_WarmStartSummarySelectedCorrectExtraWrongFlags_DoesNotSelectSupport() {
|
|
||||||
InstrumentationRegistry.getContext().
|
|
||||||
startActivity(new Intent(android.provider.Settings.ACTION_SETTINGS));
|
|
||||||
launchSettingsNoFlags(ARG_SELECT_SUPPORT_TAB);
|
|
||||||
verifySupportNotSelected();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
/* warm start from elsewhere in settings with with wrong flags & extra does not select support*/
|
|
||||||
public void test_WarmStartSummarySelectedWrongExtraWrongFlags_DoesNotSelectSupport() {
|
|
||||||
InstrumentationRegistry.getContext().
|
|
||||||
startActivity(new Intent(android.provider.Settings.ACTION_SETTINGS));
|
|
||||||
launchSettingsNoFlags(ARG_SELECT_FAKE_TAB);
|
|
||||||
verifySupportNotSelected();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
/* settings does not crash on null string */
|
|
||||||
public void test_DoesNotCrashOnNullExtra_DoesNotSelectSupport() {
|
|
||||||
launchSettingsWithFlags(null, FLAG_RESTART);
|
|
||||||
verifySupportNotSelected();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void verifySupportNotSelected() {
|
|
||||||
onView(withText(mActivityRule.getActivity().getApplicationContext().
|
|
||||||
getString(com.android.settings.R.string.page_tab_title_support))).
|
|
||||||
check(matches(not(isSelected())));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void verifySupportSelected() {
|
|
||||||
onView(withText(mActivityRule.getActivity().getApplicationContext().
|
|
||||||
getString(com.android.settings.R.string.page_tab_title_support))).
|
|
||||||
check(matches(isSelected()));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void launchSettingsWithFlags(String extra, int flags) {
|
|
||||||
Intent intent = new Intent(android.provider.Settings.ACTION_SETTINGS);
|
|
||||||
intent.setFlags(flags);
|
|
||||||
intent.putExtra(DashboardContainerFragment.EXTRA_SELECT_SETTINGS_TAB, extra);
|
|
||||||
mActivityRule.launchActivity(intent);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void launchSettingsNoFlags(String extra) {
|
|
||||||
Intent intent = new Intent(android.provider.Settings.ACTION_SETTINGS);
|
|
||||||
intent.putExtra(DashboardContainerFragment.EXTRA_SELECT_SETTINGS_TAB, extra);
|
|
||||||
mActivityRule.launchActivity(intent);
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user