diff options
author | Dianne Hackborn <hackbod@google.com> | 2014-12-09 00:16:31 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-12-09 00:16:31 +0000 |
commit | e68249c0e1840c061d488dc81a30ef28678a80b0 (patch) | |
tree | 208d223711b72b8cb6581c49539f06d0eedbad7a /tests | |
parent | 420f4bd3968de6536fc62b12e5c6d9ee42c10576 (diff) | |
parent | 7039f6b423d2795eea6bebc932c9cb0d8422de88 (diff) | |
download | frameworks_base-e68249c0e1840c061d488dc81a30ef28678a80b0.zip frameworks_base-e68249c0e1840c061d488dc81a30ef28678a80b0.tar.gz frameworks_base-e68249c0e1840c061d488dc81a30ef28678a80b0.tar.bz2 |
am 7039f6b4: am 7ca6cc75: am 7194bf4d: Merge "Add test for isolated services." into lmp-mr1-dev
* commit '7039f6b423d2795eea6bebc932c9cb0d8422de88':
Add test for isolated services.
Diffstat (limited to 'tests')
3 files changed, 80 insertions, 0 deletions
diff --git a/tests/ActivityTests/AndroidManifest.xml b/tests/ActivityTests/AndroidManifest.xml index 513f622..33d40ad 100644 --- a/tests/ActivityTests/AndroidManifest.xml +++ b/tests/ActivityTests/AndroidManifest.xml @@ -57,6 +57,8 @@ </service> <receiver android:name="UserTarget"> </receiver> + <service android:name="IsolatedService" android:isolatedProcess="true"> + </service> <receiver android:name="StartEmpty" android:exported="true"> <intent-filter> <action android:name="com.example.START_EMPTY" /> diff --git a/tests/ActivityTests/src/com/google/android/test/activity/ActivityTestMain.java b/tests/ActivityTests/src/com/google/android/test/activity/ActivityTestMain.java index b065b88..4281c68 100644 --- a/tests/ActivityTests/src/com/google/android/test/activity/ActivityTestMain.java +++ b/tests/ActivityTests/src/com/google/android/test/activity/ActivityTestMain.java @@ -62,6 +62,8 @@ public class ActivityTestMain extends Activity { ArrayList<ServiceConnection> mConnections = new ArrayList<ServiceConnection>(); + ServiceConnection mIsolatedConnection; + static final int MSG_SPAM = 1; final Handler mHandler = new Handler() { @@ -207,6 +209,34 @@ public class ActivityTestMain extends Activity { return true; } }); + menu.add("Rebind Isolated!").setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() { + @Override public boolean onMenuItemClick(MenuItem item) { + Intent intent = new Intent(ActivityTestMain.this, IsolatedService.class); + ServiceConnection conn = new ServiceConnection() { + @Override + public void onServiceConnected(ComponentName name, IBinder service) { + Log.i(TAG, "Isolated service connected " + name + " " + service); + } + @Override + public void onServiceDisconnected(ComponentName name) { + Log.i(TAG, "Isolated service disconnected " + name); + } + }; + if (mIsolatedConnection != null) { + Log.i(TAG, "Unbinding existing service: " + mIsolatedConnection); + unbindService(mIsolatedConnection); + mIsolatedConnection = null; + } + Log.i(TAG, "Binding new service: " + conn); + if (bindService(intent, conn, Context.BIND_AUTO_CREATE)) { + mIsolatedConnection = conn; + } else { + Toast.makeText(ActivityTestMain.this, "Failed to bind", + Toast.LENGTH_LONG).show(); + } + return true; + } + }); menu.add("Send!").setOnMenuItemClickListener(new MenuItem.OnMenuItemClickListener() { @Override public boolean onMenuItemClick(MenuItem item) { Intent intent = new Intent(ActivityTestMain.this, SingleUserReceiver.class); @@ -417,6 +447,10 @@ public class ActivityTestMain extends Activity { unbindService(conn); } mConnections.clear(); + if (mIsolatedConnection != null) { + unbindService(mIsolatedConnection); + mIsolatedConnection = null; + } } @Override diff --git a/tests/ActivityTests/src/com/google/android/test/activity/IsolatedService.java b/tests/ActivityTests/src/com/google/android/test/activity/IsolatedService.java new file mode 100644 index 0000000..f3bf42e --- /dev/null +++ b/tests/ActivityTests/src/com/google/android/test/activity/IsolatedService.java @@ -0,0 +1,44 @@ +/* + * Copyright (C) 2014 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.google.android.test.activity; + +import android.app.Service; +import android.content.Intent; +import android.os.Binder; +import android.os.IBinder; +import android.util.Log; + +public class IsolatedService extends Service { + Binder mBinder = new Binder(); + + @Override + public void onCreate() { + super.onCreate(); + Log.i("IsolatedService", "Service created in pid " + android.os.Process.myPid()); + } + + @Override + public IBinder onBind(Intent intent) { + return mBinder; + } + + @Override + public void onDestroy() { + super.onDestroy(); + Log.i("IsolatedService", "Service destroyed in pid " + android.os.Process.myPid()); + } +} |