Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e736dc66 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Show current WebView package as selected in Dev Setting."

parents e5017dc6 4790d7e8
Loading
Loading
Loading
Loading
+12 −0
Original line number Diff line number Diff line
@@ -16,8 +16,10 @@ package com.android.settings.webview;

import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.os.RemoteException;
import android.graphics.Color;
import android.support.annotation.VisibleForTesting;
import android.view.LayoutInflater;
import android.view.View;
@@ -36,6 +38,7 @@ import java.util.List;
 */
class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
    private final LayoutInflater mInflater;
    private final String mCurrentWebViewPackageName;

    public WebViewAppListAdapter(Context context,
            WebViewUpdateServiceWrapper webviewUpdateServiceWrapper) {
@@ -53,6 +56,10 @@ class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
            packageInfoList.add(info);
        }
        addAll(packageInfoList);

        PackageInfo currentWebViewPackage = webviewUpdateServiceWrapper.getCurrentWebViewPackage();
        mCurrentWebViewPackageName =
                currentWebViewPackage == null ? null : currentWebViewPackage.packageName;
    }

    @Override
@@ -80,6 +87,11 @@ class WebViewAppListAdapter extends ArrayAdapter<WebViewApplicationInfo> {
        holder.disabled.setVisibility(View.GONE);
        // Only allow a package to be chosen if it is enabled and installed for all users.
        convertView.setEnabled(isEnabled(position));
        if (info.info.packageName.equals(mCurrentWebViewPackageName)) {
            convertView.setBackgroundColor(Color.GRAY);
        } else {
            convertView.setBackgroundColor(Color.WHITE);
        }
        return convertView;
    }

+4 −3
Original line number Diff line number Diff line
@@ -73,10 +73,11 @@ public class WebViewAppPreferenceController extends PreferenceController {
     * Handle the return-value from the WebViewAppPicker Activity.
     */
    public void onActivityResult(int resultCode, Intent data) {
        if (resultCode == Activity.RESULT_OK) {
        // Update the preference summary no matter whether we succeeded to change the webview
        // implementation correctly - we might have changed implementation to one the user did not
        // choose.
        updateState(null);
    }
    }

    private String getCurrentWebViewPackageLabel(Context context) {
        PackageInfo webViewPackage = mWebViewUpdateServiceWrapper.getCurrentWebViewPackage();
+2 −2
Original line number Diff line number Diff line
@@ -70,7 +70,7 @@ public class WebViewAppPreferenceControllerTest {
        verify(controller, times(1)).updateState(any());
    }

    @Test public void testOnActivityResultWithFailureDoesNothing() {
    @Test public void testOnActivityResultWithFailure() {
        WebViewUpdateServiceWrapper wvusWrapper = mock(WebViewUpdateServiceWrapper.class);

        WebViewAppPreferenceController controller =
@@ -78,6 +78,6 @@ public class WebViewAppPreferenceControllerTest {

        controller.displayPreference(mPreferenceScreen); // Makes sure Preference is non-null
        controller.onActivityResult(Activity.RESULT_CANCELED, new Intent(DEFAULT_PACKAGE_NAME));
        verify(controller, never()).updateState(any());
        verify(controller, times(1)).updateState(any());
    }
}