system/hardware/interfaces
Révision | cd00105c383f8294dec26220ca05ed58f2a78123 (tree) |
---|---|
l'heure | 2019-04-19 08:14:11 |
Auteur | Branden Archer <brarcher@goog...> |
Commiter | Branden Archer |
Split Wifi Keystore HAL tests into smaller pieces
There was originally one test per function, which attempted many
possible error conditions and one success condition. It would be
easier to reason through the tests and maintain them if they
were smaller and each test attempted on thing.
Note that the logic on the "wrong user" tests was reversed; the
HAL expects the user to be the wifi user. The reverse may have
originally worked because the HAL library was run within the test
process.
Bug: 130207625
Test: On an AOSP build:
Change-Id: I534b7f66cdb1047a972a4dab708609b15cf287df
Merged-In: I282e151d0b38903578bd9077814c810e44b3b93d
@@ -63,7 +63,7 @@ class WifiKeystoreHalTest : public Test { | ||
63 | 63 | service_manager->getService(String16(kKeystoreServiceName)); |
64 | 64 | service = interface_cast<IKeystoreService>(keystore_binder); |
65 | 65 | |
66 | - EXPECT_NE(nullptr, service.get()); | |
66 | + ASSERT_TRUE(service); | |
67 | 67 | |
68 | 68 | resetState(); |
69 | 69 | } |
@@ -206,11 +206,8 @@ class WifiKeystoreHalTest : public Test { | ||
206 | 206 | sp<IKeystoreService> service; |
207 | 207 | }; |
208 | 208 | |
209 | -/** | |
210 | - * Test for the Wifi Keystore HAL's sign() call. | |
211 | - */ | |
212 | -TEST_F(WifiKeystoreHalTest, Sign) { | |
213 | - ::android::system::wifi::keystore::V1_0::IKeystore::KeystoreStatusCode statusCode; | |
209 | +TEST_F(WifiKeystoreHalTest, Sign_nullptr_key_name) { | |
210 | + IKeystore::KeystoreStatusCode statusCode; | |
214 | 211 | |
215 | 212 | auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, |
216 | 213 | const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { |
@@ -219,57 +216,109 @@ TEST_F(WifiKeystoreHalTest, Sign) { | ||
219 | 216 | }; |
220 | 217 | |
221 | 218 | ::android::hardware::hidl_vec<uint8_t> dataToSign; |
222 | - | |
223 | - // These attempts do not include an existing key to use | |
224 | - | |
219 | + dataToSign.resize(100); | |
225 | 220 | keystore->sign(nullptr, dataToSign, callback); |
226 | 221 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
222 | +} | |
223 | + | |
224 | +TEST_F(WifiKeystoreHalTest, Sign_empty_key_name) { | |
225 | + IKeystore::KeystoreStatusCode statusCode; | |
226 | + | |
227 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
228 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
229 | + statusCode = status; | |
230 | + return; | |
231 | + }; | |
227 | 232 | |
233 | + ::android::hardware::hidl_vec<uint8_t> dataToSign; | |
234 | + dataToSign.resize(100); | |
228 | 235 | keystore->sign("", dataToSign, callback); |
229 | 236 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
237 | +} | |
230 | 238 | |
231 | - bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, UID_SELF); | |
239 | +TEST_F(WifiKeystoreHalTest, Sign_empty_data) { | |
240 | + IKeystore::KeystoreStatusCode statusCode; | |
241 | + | |
242 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
243 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
244 | + statusCode = status; | |
245 | + return; | |
246 | + }; | |
247 | + | |
248 | + bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, AID_WIFI); | |
232 | 249 | EXPECT_EQ(result, true); |
233 | 250 | |
234 | 251 | // The data to sign is empty, and a failure is expected |
235 | - | |
252 | + ::android::hardware::hidl_vec<uint8_t> dataToSign; | |
236 | 253 | keystore->sign(kTestKeyName, dataToSign, callback); |
237 | 254 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
255 | +} | |
238 | 256 | |
239 | - // With data the signing attempt should succeed | |
257 | +TEST_F(WifiKeystoreHalTest, Sign_wrong_key_purpose) { | |
258 | + IKeystore::KeystoreStatusCode statusCode; | |
240 | 259 | |
241 | - dataToSign.resize(100); | |
242 | - keystore->sign(kTestKeyName, dataToSign, callback); | |
243 | - EXPECT_EQ(IKeystore::KeystoreStatusCode::SUCCESS, statusCode); | |
260 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
261 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
262 | + statusCode = status; | |
263 | + return; | |
264 | + }; | |
244 | 265 | |
245 | 266 | // Create a key which cannot sign; any signing attempt should fail. |
246 | - | |
247 | - result = deleteKey(kTestKeyName, UID_SELF); | |
248 | - EXPECT_EQ(result, true); | |
249 | - | |
250 | - result = generateKey(kTestKeyName, KeyPurpose::ENCRYPTION, UID_SELF); | |
267 | + bool result = generateKey(kTestKeyName, KeyPurpose::ENCRYPTION, AID_WIFI); | |
251 | 268 | EXPECT_EQ(result, true); |
252 | 269 | |
270 | + ::android::hardware::hidl_vec<uint8_t> dataToSign; | |
271 | + dataToSign.resize(100); | |
253 | 272 | keystore->sign(kTestKeyName, dataToSign, callback); |
254 | 273 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
274 | +} | |
275 | + | |
276 | +TEST_F(WifiKeystoreHalTest, Sign_wrong_key_type) { | |
277 | + IKeystore::KeystoreStatusCode statusCode; | |
278 | + | |
279 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
280 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
281 | + statusCode = status; | |
282 | + return; | |
283 | + }; | |
284 | + | |
285 | + ::android::hardware::hidl_vec<uint8_t> dataToSign; | |
255 | 286 | |
256 | 287 | // Generate a TYPE_GENERIC key instead of a TYPE_KEYMASTER_10 key. |
257 | 288 | // This also cannot be used to sign. |
258 | 289 | |
259 | - result = deleteKey(kTestKeyName, UID_SELF); | |
290 | + bool result = insert(kTestKeyName, AID_WIFI); | |
260 | 291 | EXPECT_EQ(result, true); |
261 | 292 | |
262 | - result = insert(kTestKeyName, UID_SELF); | |
293 | + keystore->sign(kTestKeyName, dataToSign, callback); | |
294 | + EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); | |
295 | +} | |
296 | + | |
297 | +TEST_F(WifiKeystoreHalTest, Sign_success) { | |
298 | + IKeystore::KeystoreStatusCode statusCode; | |
299 | + | |
300 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
301 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
302 | + statusCode = status; | |
303 | + return; | |
304 | + }; | |
305 | + | |
306 | + ::android::hardware::hidl_vec<uint8_t> dataToSign; | |
307 | + | |
308 | + bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, AID_WIFI); | |
263 | 309 | EXPECT_EQ(result, true); |
264 | 310 | |
311 | + // With data the signing attempt should succeed | |
312 | + | |
313 | + dataToSign.resize(100); | |
265 | 314 | keystore->sign(kTestKeyName, dataToSign, callback); |
266 | - EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); | |
315 | + EXPECT_EQ(IKeystore::KeystoreStatusCode::SUCCESS, statusCode); | |
316 | + | |
317 | + result = deleteKey(kTestKeyName, AID_WIFI); | |
318 | + EXPECT_EQ(result, true); | |
267 | 319 | } |
268 | 320 | |
269 | -/** | |
270 | - * Test for the Wifi Keystore HAL's getBlob() call. | |
271 | - */ | |
272 | -TEST_F(WifiKeystoreHalTest, GetBlob) { | |
321 | +TEST_F(WifiKeystoreHalTest, GetBlob_null_key_name) { | |
273 | 322 | IKeystore::KeystoreStatusCode statusCode; |
274 | 323 | |
275 | 324 | auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, |
@@ -279,18 +328,49 @@ TEST_F(WifiKeystoreHalTest, GetBlob) { | ||
279 | 328 | }; |
280 | 329 | |
281 | 330 | // Attempting to get a blob on a non-existent key should fail. |
282 | - | |
283 | 331 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
284 | 332 | keystore->getBlob(nullptr, callback); |
285 | 333 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
334 | +} | |
286 | 335 | |
336 | +TEST_F(WifiKeystoreHalTest, GetBlob_empty_key_name) { | |
337 | + IKeystore::KeystoreStatusCode statusCode; | |
338 | + | |
339 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
340 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
341 | + statusCode = status; | |
342 | + return; | |
343 | + }; | |
344 | + | |
345 | + // Attempting to get a blob on a non-existent key should fail. | |
287 | 346 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
288 | 347 | keystore->getBlob("", callback); |
289 | 348 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
349 | +} | |
290 | 350 | |
351 | +TEST_F(WifiKeystoreHalTest, GetBlob_missing_key) { | |
352 | + IKeystore::KeystoreStatusCode statusCode; | |
353 | + | |
354 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
355 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
356 | + statusCode = status; | |
357 | + return; | |
358 | + }; | |
359 | + | |
360 | + // Attempting to get a blob on a non-existent key should fail. | |
291 | 361 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
292 | 362 | keystore->getBlob(kTestKeyName, callback); |
293 | 363 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
364 | +} | |
365 | + | |
366 | +TEST_F(WifiKeystoreHalTest, GetBlob_wrong_user) { | |
367 | + IKeystore::KeystoreStatusCode statusCode; | |
368 | + | |
369 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
370 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
371 | + statusCode = status; | |
372 | + return; | |
373 | + }; | |
294 | 374 | |
295 | 375 | // The HAL is expecting the key to belong to the wifi user. |
296 | 376 | // If the key belongs to another user's space it should fail. |
@@ -300,13 +380,20 @@ TEST_F(WifiKeystoreHalTest, GetBlob) { | ||
300 | 380 | |
301 | 381 | keystore->getBlob(kTestKeyName, callback); |
302 | 382 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
383 | +} | |
303 | 384 | |
304 | - result = deleteKey(kTestKeyName, UID_SELF); | |
305 | - EXPECT_EQ(result, true); | |
385 | +TEST_F(WifiKeystoreHalTest, GetBlob_success) { | |
386 | + IKeystore::KeystoreStatusCode statusCode; | |
387 | + | |
388 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
389 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
390 | + statusCode = status; | |
391 | + return; | |
392 | + }; | |
306 | 393 | |
307 | 394 | // Accessing the key belonging to the wifi user should succeed. |
308 | 395 | |
309 | - result = insert(kTestKeyName, AID_WIFI); | |
396 | + bool result = insert(kTestKeyName, AID_WIFI); | |
310 | 397 | EXPECT_EQ(result, true); |
311 | 398 | |
312 | 399 | keystore->getBlob(kTestKeyName, callback); |
@@ -316,10 +403,7 @@ TEST_F(WifiKeystoreHalTest, GetBlob) { | ||
316 | 403 | EXPECT_EQ(result, true); |
317 | 404 | } |
318 | 405 | |
319 | -/** | |
320 | - * Test for the Wifi Keystore HAL's getPublicKey() call. | |
321 | - */ | |
322 | -TEST_F(WifiKeystoreHalTest, GetPublicKey) { | |
406 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_nullptr_key_name) { | |
323 | 407 | IKeystore::KeystoreStatusCode statusCode; |
324 | 408 | |
325 | 409 | auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, |
@@ -329,53 +413,104 @@ TEST_F(WifiKeystoreHalTest, GetPublicKey) { | ||
329 | 413 | }; |
330 | 414 | |
331 | 415 | // Attempting to export a non-existent key should fail. |
332 | - | |
333 | 416 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
334 | 417 | keystore->getPublicKey(nullptr, callback); |
335 | 418 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
419 | +} | |
336 | 420 | |
421 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_empty_key_name) { | |
422 | + IKeystore::KeystoreStatusCode statusCode; | |
423 | + | |
424 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
425 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
426 | + statusCode = status; | |
427 | + return; | |
428 | + }; | |
429 | + | |
430 | + // Attempting to export a non-existent key should fail. | |
337 | 431 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
338 | 432 | keystore->getPublicKey("", callback); |
339 | 433 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
434 | +} | |
435 | + | |
436 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_wrong_key_name) { | |
437 | + IKeystore::KeystoreStatusCode statusCode; | |
438 | + | |
439 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
440 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
441 | + statusCode = status; | |
442 | + return; | |
443 | + }; | |
340 | 444 | |
445 | + // Attempting to export a non-existent key should fail. | |
341 | 446 | statusCode = IKeystore::KeystoreStatusCode::SUCCESS; |
342 | 447 | keystore->getPublicKey(kTestKeyName, callback); |
343 | 448 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
449 | +} | |
450 | + | |
451 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_wrong_user) { | |
452 | + IKeystore::KeystoreStatusCode statusCode; | |
453 | + | |
454 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
455 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
456 | + statusCode = status; | |
457 | + return; | |
458 | + }; | |
344 | 459 | |
345 | - // The HAL is expecting the key to belong to the process' user. | |
346 | - // If the key belongs to another user's space (e.g. wifi) it should | |
460 | + // The HAL is expecting the key to belong to the wifi user. | |
461 | + // If the key belongs to another user's space (e.g. root) it should | |
347 | 462 | // not be accessible and should fail. |
348 | 463 | |
349 | - bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, AID_WIFI); | |
464 | + bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, UID_SELF); | |
350 | 465 | EXPECT_EQ(result, true); |
351 | 466 | |
352 | 467 | keystore->getPublicKey(kTestKeyName, callback); |
353 | 468 | EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); |
354 | 469 | |
355 | - result = deleteKey(kTestKeyName, AID_WIFI); | |
470 | + result = deleteKey(kTestKeyName, UID_SELF); | |
356 | 471 | EXPECT_EQ(result, true); |
472 | +} | |
473 | + | |
474 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_wrong_key_type) { | |
475 | + IKeystore::KeystoreStatusCode statusCode; | |
357 | 476 | |
358 | - // Accessing the key belonging to the process' uid should succeed. | |
477 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
478 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
479 | + statusCode = status; | |
480 | + return; | |
481 | + }; | |
359 | 482 | |
360 | - result = generateKey(kTestKeyName, KeyPurpose::SIGNING, UID_SELF); | |
483 | + // A TYPE_GENERIC key (instead of a TYPE_KEYMASTER_10 key) | |
484 | + // should also fail. | |
485 | + | |
486 | + bool result = insert(kTestKeyName, AID_WIFI); | |
361 | 487 | EXPECT_EQ(result, true); |
362 | 488 | |
363 | 489 | keystore->getPublicKey(kTestKeyName, callback); |
364 | - EXPECT_EQ(IKeystore::KeystoreStatusCode::SUCCESS, statusCode); | |
490 | + EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); | |
365 | 491 | |
366 | - result = deleteKey(kTestKeyName, UID_SELF); | |
492 | + result = deleteKey(kTestKeyName, AID_WIFI); | |
367 | 493 | EXPECT_EQ(result, true); |
494 | +} | |
368 | 495 | |
369 | - // A TYPE_GENERIC key (instead of a TYPE_KEYMASTER_10 key) | |
370 | - // should also fail. | |
496 | +TEST_F(WifiKeystoreHalTest, GetPublicKey_success) { | |
497 | + IKeystore::KeystoreStatusCode statusCode; | |
371 | 498 | |
372 | - result = insert(kTestKeyName, UID_SELF); | |
499 | + auto callback = [&statusCode](IKeystore::KeystoreStatusCode status, | |
500 | + const ::android::hardware::hidl_vec<uint8_t>& /*value*/) { | |
501 | + statusCode = status; | |
502 | + return; | |
503 | + }; | |
504 | + | |
505 | + // Accessing the key belonging to the wifi uid should succeed. | |
506 | + | |
507 | + bool result = generateKey(kTestKeyName, KeyPurpose::SIGNING, AID_WIFI); | |
373 | 508 | EXPECT_EQ(result, true); |
374 | 509 | |
375 | 510 | keystore->getPublicKey(kTestKeyName, callback); |
376 | - EXPECT_EQ(IKeystore::KeystoreStatusCode::ERROR_UNKNOWN, statusCode); | |
511 | + EXPECT_EQ(IKeystore::KeystoreStatusCode::SUCCESS, statusCode); | |
377 | 512 | |
378 | - result = deleteKey(kTestKeyName, UID_SELF); | |
513 | + result = deleteKey(kTestKeyName, AID_WIFI); | |
379 | 514 | EXPECT_EQ(result, true); |
380 | 515 | } |
381 | 516 |