diff options
author | Jeff Sharkey <jsharkey@android.com> | 2014-04-04 12:12:41 -0700 |
---|---|---|
committer | Jeff Sharkey <jsharkey@android.com> | 2014-04-22 21:06:49 -0700 |
commit | 846318a3250fa95f47a9decfbffb05a31dbd0006 (patch) | |
tree | c5d28f5d77e1fd625117e65bc9d24acfdfb6b94e /core/tests | |
parent | fb5d9f338153f569775bbc76177cab05441999c1 (diff) | |
download | frameworks_base-846318a3250fa95f47a9decfbffb05a31dbd0006.zip frameworks_base-846318a3250fa95f47a9decfbffb05a31dbd0006.tar.gz frameworks_base-846318a3250fa95f47a9decfbffb05a31dbd0006.tar.bz2 |
Allow prefix-based Uri permission grants.
Define new FLAG_GRANT_PREFIX_URI_PERMISSION which indicates that a
Uri permission grant should also apply to any other Uris that have
matching scheme, authority, and path segments. For example, a prefix
grant for /foo/ would allow /foo/bar/ but not /foo2/.
Allow persistable and prefix grants to be issued directly through
grantUriPermission(). Relaxing persistable is fine, since it still
requires the receiver to actively take the permission.
Since exact- and prefix-match grants for the same Uri can coexist,
we track them separately using a new UriGrant key. (Consider the
case where an app separately extends READ|PREFIX and WRITE for
the same Uri: we can't let that become READ|WRITE|PREFIX.)
Fix revoke to always take away persisted permissions. Move prefix
matching logic to Uri and add tests. Add new flags to "am" tool, and
various internal uses around Intent and Context. Switch some lagging
users to ArraySet.
Bug: 10607375
Change-Id: Ia8ce2b88421ff9f2fe5a979a27a026fc445d46f1
Diffstat (limited to 'core/tests')
-rw-r--r-- | core/tests/coretests/src/android/net/UriTest.java | 54 |
1 files changed, 53 insertions, 1 deletions
diff --git a/core/tests/coretests/src/android/net/UriTest.java b/core/tests/coretests/src/android/net/UriTest.java index 6fb8946..cd45017 100644 --- a/core/tests/coretests/src/android/net/UriTest.java +++ b/core/tests/coretests/src/android/net/UriTest.java @@ -19,12 +19,14 @@ package android.net; import android.content.ContentUris; import android.os.Parcel; import android.test.suitebuilder.annotation.SmallTest; + +import junit.framework.TestCase; + import java.io.File; import java.util.Arrays; import java.util.Iterator; import java.util.List; import java.util.Set; -import junit.framework.TestCase; public class UriTest extends TestCase { @@ -752,4 +754,54 @@ public class UriTest extends TestCase { assertEquals("d e", Uri.parse("http://a/b?c=d%20e").getQueryParameter("c")); assertEquals("d e", Uri.parse("http://a/b?c=d+e").getQueryParameter("c")); } + + public void testPathPrefixMatch() { + // Exact match + assertTrue(Uri.parse("content://com.example/path").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + assertTrue(Uri.parse("content://com.example/path").isPathPrefixMatch( + Uri.parse("content://com.example/path"))); + assertTrue(Uri.parse("content://com.example///path///").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + assertTrue(Uri.parse("content://com.example/path").isPathPrefixMatch( + Uri.parse("content://com.example///path///"))); + + // Child match + assertTrue(Uri.parse("content://com.example/path/to/child").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + assertTrue(Uri.parse("content://com.example/path/to/child").isPathPrefixMatch( + Uri.parse("content://com.example/path"))); + + // Extra parameters + assertTrue(Uri.parse("content://com.example/path#fragment").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + assertTrue(Uri.parse("content://com.example/path?q=v").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + assertTrue(Uri.parse("content://com.example/path/?q=v").isPathPrefixMatch( + Uri.parse("content://com.example/path/"))); + + // Different path + assertFalse(Uri.parse("content://com.example/path").isPathPrefixMatch( + Uri.parse("content://com.example/path/deeper/"))); + assertFalse(Uri.parse("content://com.example/path2").isPathPrefixMatch( + Uri.parse("content://com.example/path"))); + + // Top-level match + assertTrue(Uri.parse("content://com.example/path/").isPathPrefixMatch( + Uri.parse("content://com.example/"))); + assertTrue(Uri.parse("content://com.example/path/").isPathPrefixMatch( + Uri.parse("content://com.example"))); + + // Different prefixes + assertFalse(Uri.parse("content://com.example/path/").isPathPrefixMatch( + Uri.parse("file://com.example/path/"))); + assertFalse(Uri.parse("content://com.example/path/").isPathPrefixMatch( + Uri.parse("content://org.example/path/"))); + + // Escaping + assertTrue(Uri.parse("content://com.example/path path/").isPathPrefixMatch( + Uri.parse("content://com.example/path%20path/"))); + assertFalse(Uri.parse("content://com.example/path/path").isPathPrefixMatch( + Uri.parse("content://com.example/path%2Fpath"))); + } } |