blob: 6ce3ed3996df60baf54a96615767da1db725ba2b [file] [log] [blame]
Chung-yih Wangf35e9662009-09-29 11:20:28 +08001/*
2 * Copyright (C) 2009 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Kenny Root96ad6cb2012-08-10 12:39:15 -070017package android.security;
Chung-yih Wangf35e9662009-09-29 11:20:28 +080018
19import android.app.Activity;
Kenny Root78ad8492013-02-13 17:02:57 -080020import android.os.Process;
Chung-yih Wangf35e9662009-09-29 11:20:28 +080021import android.security.KeyStore;
22import android.test.ActivityUnitTestCase;
Kenny Root473c7122012-08-17 21:13:48 -070023import android.test.AssertionFailedError;
Chung-yih Wangf35e9662009-09-29 11:20:28 +080024import android.test.suitebuilder.annotation.MediumTest;
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -070025import java.nio.charset.Charsets;
26import java.util.Arrays;
Kenny Root473c7122012-08-17 21:13:48 -070027import java.util.Date;
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -070028import java.util.HashSet;
Chung-yih Wangf35e9662009-09-29 11:20:28 +080029
30/**
31 * Junit / Instrumentation test case for KeyStore class
32 *
33 * Running the test suite:
34 *
Kenny Root96ad6cb2012-08-10 12:39:15 -070035 * runtest keystore-unit
36 *
37 * Or this individual test case:
38 *
39 * runtest --path frameworks/base/keystore/tests/src/android/security/KeyStoreTest.java
Chung-yih Wangf35e9662009-09-29 11:20:28 +080040 */
41@MediumTest
42public class KeyStoreTest extends ActivityUnitTestCase<Activity> {
43 private static final String TEST_PASSWD = "12345678";
Chung-yih Wangf35e9662009-09-29 11:20:28 +080044 private static final String TEST_PASSWD2 = "87654321";
Brian Carlstrom5ea68db2012-07-17 23:40:49 -070045 private static final String TEST_KEYNAME = "test-key";
46 private static final String TEST_KEYNAME1 = "test-key.1";
Brian Carlstrom2a5b1472012-07-30 18:44:29 -070047 private static final String TEST_KEYNAME2 = "test-key\02";
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -070048 private static final byte[] TEST_KEYVALUE = "test value".getBytes(Charsets.UTF_8);
Chung-yih Wangf35e9662009-09-29 11:20:28 +080049
Nick Kralevich34c47c82010-03-09 13:28:14 -080050 // "Hello, World" in Chinese
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -070051 private static final String TEST_I18N_KEY = "\u4F60\u597D, \u4E16\u754C";
52 private static final byte[] TEST_I18N_VALUE = TEST_I18N_KEY.getBytes(Charsets.UTF_8);
Nick Kralevich34c47c82010-03-09 13:28:14 -080053
Kenny Root5423e682011-11-14 08:43:13 -080054 // Test vector data for signatures
Brian Carlstrom5ea68db2012-07-17 23:40:49 -070055 private static final byte[] TEST_DATA = new byte[256];
56 static {
57 for (int i = 0; i < TEST_DATA.length; i++) {
58 TEST_DATA[i] = (byte) i;
59 }
60 }
Kenny Root5423e682011-11-14 08:43:13 -080061
Chung-yih Wangf35e9662009-09-29 11:20:28 +080062 private KeyStore mKeyStore = null;
63
64 public KeyStoreTest() {
65 super(Activity.class);
66 }
67
Kenny Root5423e682011-11-14 08:43:13 -080068 private static final byte[] PRIVKEY_BYTES = hexToBytes(
69 "308204BE020100300D06092A864886F70D0101010500048204A8308204A4020100028201" +
70 "0100E0473E8AB8F2284FEB9E742FF9748FA118ED98633C92F52AEB7A2EBE0D3BE60329BE" +
71 "766AD10EB6A515D0D2CFD9BEA7930F0C306537899F7958CD3E85B01F8818524D312584A9" +
72 "4B251E3625B54141EDBFEE198808E1BB97FC7CB49B9EAAAF68E9C98D7D0EDC53BBC0FA00" +
73 "34356D6305FBBCC3C7001405386ABBC873CB0F3EF7425F3D33DF7B315AE036D2A0B66AFD" +
74 "47503B169BF36E3B5162515B715FDA83DEAF2C58AEB9ABFB3097C3CC9DD9DBE5EF296C17" +
75 "6139028E8A671E63056D45F40188D2C4133490845DE52C2534E9C6B2478C07BDAE928823" +
76 "B62D066C7770F9F63F3DBA247F530844747BE7AAA85D853B8BD244ACEC3DE3C89AB46453" +
77 "AB4D24C3AC6902030100010282010037784776A5F17698F5AC960DFB83A1B67564E648BD" +
78 "0597CF8AB8087186F2669C27A9ECBDD480F0197A80D07309E6C6A96F925331E57F8B4AC6" +
79 "F4D45EDA45A23269C09FC428C07A4E6EDF738A15DEC97FABD2F2BB47A14F20EA72FCFE4C" +
80 "36E01ADA77BD137CD8D4DA10BB162E94A4662971F175F985FA188F056CB97EE2816F43AB" +
81 "9D3747612486CDA8C16196C30818A995EC85D38467791267B3BF21F273710A6925862576" +
82 "841C5B6712C12D4BD20A2F3299ADB7C135DA5E9515ABDA76E7CAF2A3BE80551D073B78BF" +
83 "1162C48AD2B7F4743A0238EE4D252F7D5E7E6533CCAE64CCB39360075A2FD1E034EC3AE5" +
84 "CE9C408CCBF0E25E4114021687B3DD4754AE8102818100F541884BC3737B2922D4119EF4" +
85 "5E2DEE2CD4CBB75F45505A157AA5009F99C73A2DF0724AC46024306332EA898177634546" +
86 "5DC6DF1E0A6F140AFF3B7396E6A8994AC5DAA96873472FE37749D14EB3E075E629DBEB35" +
87 "83338A6F3649D0A2654A7A42FD9AB6BFA4AC4D481D390BB229B064BDC311CC1BE1B63189" +
88 "DA7C40CDECF2B102818100EA1A742DDB881CEDB7288C87E38D868DD7A409D15A43F445D5" +
89 "377A0B5731DDBFCA2DAF28A8E13CD5C0AFCEC3347D74A39E235A3CD9633F274DE2B94F92" +
90 "DF43833911D9E9F1CF58F27DE2E08FF45964C720D3EC2139DC7CAFC912953CDECB2F355A" +
91 "2E2C35A50FAD754CB3B23166424BA3B6E3112A2B898C38C5C15EDB238693390281805182" +
92 "8F1EC6FD996029901BAF1D7E337BA5F0AF27E984EAD895ACE62BD7DF4EE45A224089F2CC" +
93 "151AF3CD173FCE0474BCB04F386A2CDCC0E0036BA2419F54579262D47100BE931984A3EF" +
94 "A05BECF141574DC079B3A95C4A83E6C43F3214D6DF32D512DE198085E531E616B83FD7DD" +
95 "9D1F4E2607C3333D07C55D107D1D3893587102818100DB4FB50F50DE8EDB53FF34C80931" +
96 "88A0512867DA2CCA04897759E587C244010DAF8664D59E8083D16C164789301F67A9F078" +
97 "060D834A2ADBD367575B68A8A842C2B02A89B3F31FCCEC8A22FE395795C5C6C7422B4E5D" +
98 "74A1E9A8F30E7759B9FC2D639C1F15673E84E93A5EF1506F4315383C38D45CBD1B14048F" +
99 "4721DC82326102818100D8114593AF415FB612DBF1923710D54D07486205A76A3B431949" +
100 "68C0DFF1F11EF0F61A4A337D5FD3741BBC9640E447B8B6B6C47C3AC1204357D3B0C55BA9" +
101 "286BDA73F629296F5FA9146D8976357D3C751E75148696A40B74685C82CE30902D639D72" +
102 "4FF24D5E2E9407EE34EDED2E3B4DF65AA9BCFEB6DF28D07BA6903F165768");
103
104
105 private static byte[] hexToBytes(String s) {
106 int len = s.length();
107 byte[] data = new byte[len / 2];
108 for (int i = 0; i < len; i += 2) {
109 data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4) + Character.digit(
110 s.charAt(i + 1), 16));
111 }
112 return data;
113 }
114
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800115 @Override
116 protected void setUp() throws Exception {
117 mKeyStore = KeyStore.getInstance();
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700118 if (mKeyStore.state() != KeyStore.State.UNINITIALIZED) {
119 mKeyStore.reset();
120 }
Kenny Root5423e682011-11-14 08:43:13 -0800121 assertEquals("KeyStore should be in an uninitialized state",
122 KeyStore.State.UNINITIALIZED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800123 super.setUp();
124 }
125
126 @Override
127 protected void tearDown() throws Exception {
128 mKeyStore.reset();
129 super.tearDown();
130 }
131
Kenny Root78ad8492013-02-13 17:02:57 -0800132 public void testState() throws Exception {
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700133 assertEquals(KeyStore.State.UNINITIALIZED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800134 }
135
136 public void testPassword() throws Exception {
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800137 assertTrue(mKeyStore.password(TEST_PASSWD));
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700138 assertEquals(KeyStore.State.UNLOCKED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800139 }
140
Brian Carlstrombef5e5a2011-06-27 17:22:02 -0700141 public void testGet() throws Exception {
142 assertNull(mKeyStore.get(TEST_KEYNAME));
143 mKeyStore.password(TEST_PASSWD);
144 assertNull(mKeyStore.get(TEST_KEYNAME));
145 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE));
146 assertTrue(Arrays.equals(TEST_KEYVALUE, mKeyStore.get(TEST_KEYNAME)));
147 }
148
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800149 public void testPut() throws Exception {
Brian Carlstrombef5e5a2011-06-27 17:22:02 -0700150 assertNull(mKeyStore.get(TEST_KEYNAME));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800151 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE));
152 assertFalse(mKeyStore.contains(TEST_KEYNAME));
153 mKeyStore.password(TEST_PASSWD);
154 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE));
Brian Carlstrombef5e5a2011-06-27 17:22:02 -0700155 assertTrue(Arrays.equals(TEST_KEYVALUE, mKeyStore.get(TEST_KEYNAME)));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800156 }
157
Kenny Root78ad8492013-02-13 17:02:57 -0800158 public void testPut_grantedUid_Wifi() throws Exception {
159 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
160 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.WIFI_UID));
161 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
162 mKeyStore.password(TEST_PASSWD);
163 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.WIFI_UID));
164 assertTrue(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
165 }
166
167 public void testPut_ungrantedUid_Bluetooth() throws Exception {
168 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
169 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.BLUETOOTH_UID));
170 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
171 mKeyStore.password(TEST_PASSWD);
172 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.BLUETOOTH_UID));
173 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
174 }
175
Nick Kralevich34c47c82010-03-09 13:28:14 -0800176 public void testI18n() throws Exception {
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700177 assertFalse(mKeyStore.put(TEST_I18N_KEY, TEST_I18N_VALUE));
178 assertFalse(mKeyStore.contains(TEST_I18N_KEY));
179 mKeyStore.password(TEST_I18N_KEY);
180 assertTrue(mKeyStore.put(TEST_I18N_KEY, TEST_I18N_VALUE));
181 assertTrue(mKeyStore.contains(TEST_I18N_KEY));
Nick Kralevich34c47c82010-03-09 13:28:14 -0800182 }
183
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800184 public void testDelete() throws Exception {
Brian Carlstrom5ea68db2012-07-17 23:40:49 -0700185 assertFalse(mKeyStore.delete(TEST_KEYNAME));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800186 mKeyStore.password(TEST_PASSWD);
Brian Carlstrom5ea68db2012-07-17 23:40:49 -0700187 assertFalse(mKeyStore.delete(TEST_KEYNAME));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800188
Kenny Root78ad8492013-02-13 17:02:57 -0800189 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE));
Brian Carlstrombef5e5a2011-06-27 17:22:02 -0700190 assertTrue(Arrays.equals(TEST_KEYVALUE, mKeyStore.get(TEST_KEYNAME)));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800191 assertTrue(mKeyStore.delete(TEST_KEYNAME));
Brian Carlstrombef5e5a2011-06-27 17:22:02 -0700192 assertNull(mKeyStore.get(TEST_KEYNAME));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800193 }
194
Kenny Root78ad8492013-02-13 17:02:57 -0800195 public void testDelete_grantedUid_Wifi() throws Exception {
196 assertFalse(mKeyStore.delete(TEST_KEYNAME, Process.WIFI_UID));
197 mKeyStore.password(TEST_PASSWD);
198 assertFalse(mKeyStore.delete(TEST_KEYNAME, Process.WIFI_UID));
199
200 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.WIFI_UID));
201 assertTrue(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
202 assertTrue(mKeyStore.delete(TEST_KEYNAME, Process.WIFI_UID));
203 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
204 }
205
206 public void testDelete_ungrantedUid_Bluetooth() throws Exception {
207 assertFalse(mKeyStore.delete(TEST_KEYNAME, Process.BLUETOOTH_UID));
208 mKeyStore.password(TEST_PASSWD);
209 assertFalse(mKeyStore.delete(TEST_KEYNAME, Process.BLUETOOTH_UID));
210
211 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.BLUETOOTH_UID));
212 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
213 assertFalse(mKeyStore.delete(TEST_KEYNAME, Process.BLUETOOTH_UID));
214 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
215 }
216
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800217 public void testContains() throws Exception {
218 assertFalse(mKeyStore.contains(TEST_KEYNAME));
219
Kenny Root78ad8492013-02-13 17:02:57 -0800220 assertTrue(mKeyStore.password(TEST_PASSWD));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800221 assertFalse(mKeyStore.contains(TEST_KEYNAME));
222
Kenny Root78ad8492013-02-13 17:02:57 -0800223 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800224 assertTrue(mKeyStore.contains(TEST_KEYNAME));
225 }
226
Kenny Root78ad8492013-02-13 17:02:57 -0800227 public void testContains_grantedUid_Wifi() throws Exception {
228 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
229
230 assertTrue(mKeyStore.password(TEST_PASSWD));
231 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
232
233 assertTrue(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.WIFI_UID));
234 assertTrue(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
235 }
236
237 public void testContains_grantedUid_Bluetooth() throws Exception {
238 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
239
240 assertTrue(mKeyStore.password(TEST_PASSWD));
241 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
242
243 assertFalse(mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE, Process.BLUETOOTH_UID));
244 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
245 }
246
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800247 public void testSaw() throws Exception {
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700248 String[] emptyResult = mKeyStore.saw(TEST_KEYNAME);
249 assertNotNull(emptyResult);
250 assertEquals(0, emptyResult.length);
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800251
252 mKeyStore.password(TEST_PASSWD);
253 mKeyStore.put(TEST_KEYNAME1, TEST_KEYVALUE);
254 mKeyStore.put(TEST_KEYNAME2, TEST_KEYVALUE);
255
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700256 String[] results = mKeyStore.saw(TEST_KEYNAME);
257 assertEquals(new HashSet(Arrays.asList(TEST_KEYNAME1.substring(TEST_KEYNAME.length()),
258 TEST_KEYNAME2.substring(TEST_KEYNAME.length()))),
259 new HashSet(Arrays.asList(results)));
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800260 }
261
Kenny Root78ad8492013-02-13 17:02:57 -0800262 public void testSaw_ungrantedUid_Bluetooth() throws Exception {
263 String[] results1 = mKeyStore.saw(TEST_KEYNAME, Process.BLUETOOTH_UID);
264 assertNull(results1);
265
266 mKeyStore.password(TEST_PASSWD);
267 mKeyStore.put(TEST_KEYNAME1, TEST_KEYVALUE);
268 mKeyStore.put(TEST_KEYNAME2, TEST_KEYVALUE);
269
270 String[] results2 = mKeyStore.saw(TEST_KEYNAME, Process.BLUETOOTH_UID);
271 assertNull(results2);
272 }
273
274 public void testSaw_grantedUid_Wifi() throws Exception {
275 String[] results1 = mKeyStore.saw(TEST_KEYNAME, Process.WIFI_UID);
276 assertNotNull(results1);
277 assertEquals(0, results1.length);
278
279 mKeyStore.password(TEST_PASSWD);
280 mKeyStore.put(TEST_KEYNAME1, TEST_KEYVALUE, Process.WIFI_UID);
281 mKeyStore.put(TEST_KEYNAME2, TEST_KEYVALUE, Process.WIFI_UID);
282
283 String[] results2 = mKeyStore.saw(TEST_KEYNAME, Process.WIFI_UID);
284 assertEquals(new HashSet(Arrays.asList(TEST_KEYNAME1.substring(TEST_KEYNAME.length()),
285 TEST_KEYNAME2.substring(TEST_KEYNAME.length()))),
286 new HashSet(Arrays.asList(results2)));
287 }
288
289 public void testSaw_grantedUid_Vpn() throws Exception {
290 String[] results1 = mKeyStore.saw(TEST_KEYNAME, Process.VPN_UID);
291 assertNotNull(results1);
292 assertEquals(0, results1.length);
293
294 mKeyStore.password(TEST_PASSWD);
295 mKeyStore.put(TEST_KEYNAME1, TEST_KEYVALUE, Process.VPN_UID);
296 mKeyStore.put(TEST_KEYNAME2, TEST_KEYVALUE, Process.VPN_UID);
297
298 String[] results2 = mKeyStore.saw(TEST_KEYNAME, Process.VPN_UID);
299 assertEquals(new HashSet(Arrays.asList(TEST_KEYNAME1.substring(TEST_KEYNAME.length()),
300 TEST_KEYNAME2.substring(TEST_KEYNAME.length()))),
301 new HashSet(Arrays.asList(results2)));
302 }
303
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800304 public void testLock() throws Exception {
305 assertFalse(mKeyStore.lock());
306
307 mKeyStore.password(TEST_PASSWD);
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700308 assertEquals(KeyStore.State.UNLOCKED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800309
310 assertTrue(mKeyStore.lock());
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700311 assertEquals(KeyStore.State.LOCKED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800312 }
313
314 public void testUnlock() throws Exception {
315 mKeyStore.password(TEST_PASSWD);
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700316 assertEquals(KeyStore.State.UNLOCKED, mKeyStore.state());
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800317 mKeyStore.lock();
318
319 assertFalse(mKeyStore.unlock(TEST_PASSWD2));
320 assertTrue(mKeyStore.unlock(TEST_PASSWD));
321 }
Brian Carlstrom5cfee3f2011-05-31 01:00:15 -0700322
323 public void testIsEmpty() throws Exception {
324 assertTrue(mKeyStore.isEmpty());
325 mKeyStore.password(TEST_PASSWD);
326 assertTrue(mKeyStore.isEmpty());
327 mKeyStore.put(TEST_KEYNAME, TEST_KEYVALUE);
328 assertFalse(mKeyStore.isEmpty());
329 mKeyStore.reset();
330 assertTrue(mKeyStore.isEmpty());
331 }
Kenny Root5423e682011-11-14 08:43:13 -0800332
333 public void testGenerate_NotInitialized_Fail() throws Exception {
334 assertFalse("Should fail when keystore is not initialized",
335 mKeyStore.generate(TEST_KEYNAME));
336 }
337
338 public void testGenerate_Locked_Fail() throws Exception {
339 mKeyStore.password(TEST_PASSWD);
340 mKeyStore.lock();
341 assertFalse("Should fail when keystore is locked", mKeyStore.generate(TEST_KEYNAME));
342 }
343
344 public void testGenerate_Success() throws Exception {
Kenny Root78ad8492013-02-13 17:02:57 -0800345 assertTrue(mKeyStore.password(TEST_PASSWD));
Kenny Root5423e682011-11-14 08:43:13 -0800346
347 assertTrue("Should be able to generate key when unlocked",
348 mKeyStore.generate(TEST_KEYNAME));
Kenny Root78ad8492013-02-13 17:02:57 -0800349 assertTrue(mKeyStore.contains(TEST_KEYNAME));
350 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
351 }
352
353 public void testGenerate_grantedUid_Wifi_Success() throws Exception {
354 assertTrue(mKeyStore.password(TEST_PASSWD));
355
356 assertTrue("Should be able to generate key when unlocked",
357 mKeyStore.generate(TEST_KEYNAME, Process.WIFI_UID));
358 assertTrue(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
359 assertFalse(mKeyStore.contains(TEST_KEYNAME));
360 }
361
362 public void testGenerate_ungrantedUid_Bluetooth_Failure() throws Exception {
363 assertTrue(mKeyStore.password(TEST_PASSWD));
364
365 assertFalse(mKeyStore.generate(TEST_KEYNAME, Process.BLUETOOTH_UID));
366 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
367 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
368 assertFalse(mKeyStore.contains(TEST_KEYNAME));
Kenny Root5423e682011-11-14 08:43:13 -0800369 }
370
371 public void testImport_Success() throws Exception {
Kenny Root78ad8492013-02-13 17:02:57 -0800372 assertTrue(mKeyStore.password(TEST_PASSWD));
Kenny Root5423e682011-11-14 08:43:13 -0800373
374 assertTrue("Should be able to import key when unlocked",
375 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES));
Kenny Root78ad8492013-02-13 17:02:57 -0800376 assertTrue(mKeyStore.contains(TEST_KEYNAME));
377 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
378 }
379
380 public void testImport_grantedUid_Wifi_Success() throws Exception {
381 assertTrue(mKeyStore.password(TEST_PASSWD));
382
383 assertTrue("Should be able to import key when unlocked",
384 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES, Process.WIFI_UID));
385 assertTrue(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
386 assertFalse(mKeyStore.contains(TEST_KEYNAME));
387 }
388
389 public void testImport_ungrantedUid_Bluetooth_Failure() throws Exception {
390 assertTrue(mKeyStore.password(TEST_PASSWD));
391
392 assertFalse(mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES, Process.BLUETOOTH_UID));
393 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.BLUETOOTH_UID));
394 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
395 assertFalse(mKeyStore.contains(TEST_KEYNAME));
Kenny Root5423e682011-11-14 08:43:13 -0800396 }
397
398 public void testImport_Failure_BadEncoding() throws Exception {
399 mKeyStore.password(TEST_PASSWD);
400
401 assertFalse("Invalid DER-encoded key should not be imported",
402 mKeyStore.importKey(TEST_KEYNAME, TEST_DATA));
Kenny Root78ad8492013-02-13 17:02:57 -0800403 assertFalse(mKeyStore.contains(TEST_KEYNAME));
404 assertFalse(mKeyStore.contains(TEST_KEYNAME, Process.WIFI_UID));
Kenny Root5423e682011-11-14 08:43:13 -0800405 }
406
407 public void testSign_Success() throws Exception {
408 mKeyStore.password(TEST_PASSWD);
409
410 assertTrue(mKeyStore.generate(TEST_KEYNAME));
Kenny Root78ad8492013-02-13 17:02:57 -0800411 assertTrue(mKeyStore.contains(TEST_KEYNAME));
Kenny Root5423e682011-11-14 08:43:13 -0800412 final byte[] signature = mKeyStore.sign(TEST_KEYNAME, TEST_DATA);
413
414 assertNotNull("Signature should not be null", signature);
415 }
416
417 public void testVerify_Success() throws Exception {
418 mKeyStore.password(TEST_PASSWD);
419
420 assertTrue(mKeyStore.generate(TEST_KEYNAME));
Kenny Root78ad8492013-02-13 17:02:57 -0800421 assertTrue(mKeyStore.contains(TEST_KEYNAME));
Kenny Root5423e682011-11-14 08:43:13 -0800422 final byte[] signature = mKeyStore.sign(TEST_KEYNAME, TEST_DATA);
423
424 assertNotNull("Signature should not be null", signature);
425
426 assertTrue("Signature should verify with same data",
427 mKeyStore.verify(TEST_KEYNAME, TEST_DATA, signature));
428 }
429
430 public void testSign_NotInitialized_Failure() throws Exception {
431 assertNull("Should not be able to sign without first initializing the keystore",
432 mKeyStore.sign(TEST_KEYNAME, TEST_DATA));
433 }
434
435 public void testSign_NotGenerated_Failure() throws Exception {
436 mKeyStore.password(TEST_PASSWD);
437
438 assertNull("Should not be able to sign without first generating keys",
439 mKeyStore.sign(TEST_KEYNAME, TEST_DATA));
440 }
441
442 public void testGrant_Generated_Success() throws Exception {
443 assertTrue("Password should work for keystore",
444 mKeyStore.password(TEST_PASSWD));
445
446 assertTrue("Should be able to generate key for testcase",
447 mKeyStore.generate(TEST_KEYNAME));
448
449 assertTrue("Should be able to grant key to other user",
450 mKeyStore.grant(TEST_KEYNAME, 0));
451 }
452
453 public void testGrant_Imported_Success() throws Exception {
454 assertTrue("Password should work for keystore", mKeyStore.password(TEST_PASSWD));
455
456 assertTrue("Should be able to import key for testcase",
457 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES));
458
459 assertTrue("Should be able to grant key to other user", mKeyStore.grant(TEST_KEYNAME, 0));
460 }
461
462 public void testGrant_NoKey_Failure() throws Exception {
463 assertTrue("Should be able to unlock keystore for test",
464 mKeyStore.password(TEST_PASSWD));
465
466 assertFalse("Should not be able to grant without first initializing the keystore",
467 mKeyStore.grant(TEST_KEYNAME, 0));
468 }
469
470 public void testGrant_NotInitialized_Failure() throws Exception {
471 assertFalse("Should not be able to grant without first initializing the keystore",
472 mKeyStore.grant(TEST_KEYNAME, 0));
473 }
474
475 public void testUngrant_Generated_Success() throws Exception {
476 assertTrue("Password should work for keystore",
477 mKeyStore.password(TEST_PASSWD));
478
479 assertTrue("Should be able to generate key for testcase",
480 mKeyStore.generate(TEST_KEYNAME));
481
482 assertTrue("Should be able to grant key to other user",
483 mKeyStore.grant(TEST_KEYNAME, 0));
484
485 assertTrue("Should be able to ungrant key to other user",
486 mKeyStore.ungrant(TEST_KEYNAME, 0));
487 }
488
489 public void testUngrant_Imported_Success() throws Exception {
490 assertTrue("Password should work for keystore",
491 mKeyStore.password(TEST_PASSWD));
492
493 assertTrue("Should be able to import key for testcase",
494 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES));
495
496 assertTrue("Should be able to grant key to other user",
497 mKeyStore.grant(TEST_KEYNAME, 0));
498
499 assertTrue("Should be able to ungrant key to other user",
500 mKeyStore.ungrant(TEST_KEYNAME, 0));
501 }
502
503 public void testUngrant_NotInitialized_Failure() throws Exception {
504 assertFalse("Should fail to ungrant key when keystore not initialized",
505 mKeyStore.ungrant(TEST_KEYNAME, 0));
506 }
507
508 public void testUngrant_NoGrant_Failure() throws Exception {
509 assertTrue("Password should work for keystore",
510 mKeyStore.password(TEST_PASSWD));
511
512 assertTrue("Should be able to generate key for testcase",
513 mKeyStore.generate(TEST_KEYNAME));
514
515 assertFalse("Should not be able to revoke not existent grant",
516 mKeyStore.ungrant(TEST_KEYNAME, 0));
517 }
518
519 public void testUngrant_DoubleUngrant_Failure() throws Exception {
520 assertTrue("Password should work for keystore",
521 mKeyStore.password(TEST_PASSWD));
522
523 assertTrue("Should be able to generate key for testcase",
524 mKeyStore.generate(TEST_KEYNAME));
525
526 assertTrue("Should be able to grant key to other user",
527 mKeyStore.grant(TEST_KEYNAME, 0));
528
529 assertTrue("Should be able to ungrant key to other user",
530 mKeyStore.ungrant(TEST_KEYNAME, 0));
531
532 assertFalse("Should fail to ungrant key to other user second time",
533 mKeyStore.ungrant(TEST_KEYNAME, 0));
534 }
535
536 public void testUngrant_DoubleGrantUngrant_Failure() throws Exception {
537 assertTrue("Password should work for keystore",
538 mKeyStore.password(TEST_PASSWD));
539
540 assertTrue("Should be able to generate key for testcase",
541 mKeyStore.generate(TEST_KEYNAME));
542
543 assertTrue("Should be able to grant key to other user",
544 mKeyStore.grant(TEST_KEYNAME, 0));
545
546 assertTrue("Should be able to grant key to other user a second time",
547 mKeyStore.grant(TEST_KEYNAME, 0));
548
549 assertTrue("Should be able to ungrant key to other user",
550 mKeyStore.ungrant(TEST_KEYNAME, 0));
551
552 assertFalse("Should fail to ungrant key to other user second time",
553 mKeyStore.ungrant(TEST_KEYNAME, 0));
554 }
Kenny Root473c7122012-08-17 21:13:48 -0700555
556 /**
557 * The amount of time to allow before and after expected time for variance
558 * in timing tests.
559 */
560 private static final long SLOP_TIME_MILLIS = 15000L;
561
562 public void testGetmtime_Success() throws Exception {
563 assertTrue("Password should work for keystore",
564 mKeyStore.password(TEST_PASSWD));
565
566 assertTrue("Should be able to import key when unlocked",
567 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES));
568
569 long now = System.currentTimeMillis();
570 long actual = mKeyStore.getmtime(TEST_KEYNAME);
571
572 long expectedAfter = now - SLOP_TIME_MILLIS;
573 long expectedBefore = now + SLOP_TIME_MILLIS;
574
575 assertLessThan("Time should be close to current time", expectedBefore, actual);
576 assertGreaterThan("Time should be close to current time", expectedAfter, actual);
577 }
578
579 private static void assertLessThan(String explanation, long expectedBefore, long actual) {
580 if (actual >= expectedBefore) {
581 throw new AssertionFailedError(explanation + ": actual=" + actual
582 + ", expected before: " + expectedBefore);
583 }
584 }
585
586 private static void assertGreaterThan(String explanation, long expectedAfter, long actual) {
587 if (actual <= expectedAfter) {
588 throw new AssertionFailedError(explanation + ": actual=" + actual
589 + ", expected after: " + expectedAfter);
590 }
591 }
592
593 public void testGetmtime_NonExist_Failure() throws Exception {
594 assertTrue("Password should work for keystore",
595 mKeyStore.password(TEST_PASSWD));
596
597 assertTrue("Should be able to import key when unlocked",
598 mKeyStore.importKey(TEST_KEYNAME, PRIVKEY_BYTES));
599
600 assertEquals("-1 should be returned for non-existent key",
601 -1L, mKeyStore.getmtime(TEST_KEYNAME2));
602 }
Chung-yih Wangf35e9662009-09-29 11:20:28 +0800603}