From 9128217da1f8ae53f1c44f369934ff075ae5057b Mon Sep 17 00:00:00 2001 From: Andy Stadler Date: Mon, 24 Jan 2011 20:13:11 -0800 Subject: [PATCH] Merge forward small bug found in password storage While fixing bug 2981433 in Gingerbread, I discovered one additional place where passwords were being trimmed. This brings the fix forward into honeycomb, as well as a new unit test for the fix. Bug: 2981433 Change-Id: I566f5c0c6693ca7c0069bca9e74f320fca48e600 --- .../android/email/provider/EmailContent.java | 4 ++-- .../android/email/provider/ProviderTests.java | 21 +++++++++++++++++++ 2 files changed, 23 insertions(+), 2 deletions(-) diff --git a/src/com/android/email/provider/EmailContent.java b/src/com/android/email/provider/EmailContent.java index f9b633622..62768614b 100644 --- a/src/com/android/email/provider/EmailContent.java +++ b/src/com/android/email/provider/EmailContent.java @@ -2683,8 +2683,8 @@ public abstract class EmailContent { String userInfo = null; if ((mFlags & FLAG_AUTHENTICATE) != 0) { String trimUser = (mLogin != null) ? mLogin.trim() : ""; - String trimPassword = (mPassword != null) ? mPassword.trim() : ""; - userInfo = trimUser + ":" + trimPassword; + String password = (mPassword != null) ? mPassword : ""; + userInfo = trimUser + ":" + password; } String address = (mAddress != null) ? mAddress.trim() : null; String path = (mDomain != null) ? "/" + mDomain : null; diff --git a/tests/src/com/android/email/provider/ProviderTests.java b/tests/src/com/android/email/provider/ProviderTests.java index df3bf155b..71249903c 100644 --- a/tests/src/com/android/email/provider/ProviderTests.java +++ b/tests/src/com/android/email/provider/ProviderTests.java @@ -354,6 +354,27 @@ public class ProviderTests extends ProviderTestCase2 { assertEquals(587, ha.mPort); } + /** + * Test preservation of username & password in URI + */ + @SuppressWarnings("deprecation") + public void testHostAuthUri() { + HostAuth ha = new HostAuth(); + ha.setStoreUri("protocol://user:password@server:123"); + String getUri = ha.getStoreUri(); + assertEquals("protocol://user:password@server:123", getUri); + + // Now put spaces in/around username (they are trimmed) + ha.setStoreUri("protocol://%20us%20er%20:password@server:123"); + getUri = ha.getStoreUri(); + assertEquals("protocol://us%20er:password@server:123", getUri); + + // Now put spaces around password (should not be trimmed) + ha.setStoreUri("protocol://user:%20pass%20word%20@server:123"); + getUri = ha.getStoreUri(); + assertEquals("protocol://user:%20pass%20word%20@server:123", getUri); + } + /** * Test simple mailbox save/retrieve */