| OLD | NEW |
| 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 // Library tag to allow the test to run on Dartium. | 5 // Library tag to allow the test to run on Dartium. |
| 6 library hmac_sha256_test; | 6 library hmac_sha256_test; |
| 7 | 7 |
| 8 import "package:expect/expect.dart"; |
| 8 import 'dart:crypto'; | 9 import 'dart:crypto'; |
| 9 | 10 |
| 10 part 'hmac_sha256_test_vectors.dart'; | 11 part 'hmac_sha256_test_vectors.dart'; |
| 11 | 12 |
| 12 void testStandardVectors(inputs, keys, macs) { | 13 void testStandardVectors(inputs, keys, macs) { |
| 13 for (var i = 0; i < inputs.length; i++) { | 14 for (var i = 0; i < inputs.length; i++) { |
| 14 var hmac = new HMAC(new SHA256(), keys[i]); | 15 var hmac = new HMAC(new SHA256(), keys[i]); |
| 15 hmac.add(inputs[i]); | 16 hmac.add(inputs[i]); |
| 16 var d = hmac.close(); | 17 var d = hmac.close(); |
| 17 Expect.isTrue(CryptoUtils.bytesToHex(d).startsWith(macs[i]), '$i'); | 18 Expect.isTrue(CryptoUtils.bytesToHex(d).startsWith(macs[i]), '$i'); |
| 18 } | 19 } |
| 19 } | 20 } |
| 20 | 21 |
| 21 void main() { | 22 void main() { |
| 22 testStandardVectors(hmac_sha256_inputs, hmac_sha256_keys, hmac_sha256_macs); | 23 testStandardVectors(hmac_sha256_inputs, hmac_sha256_keys, hmac_sha256_macs); |
| 23 } | 24 } |
| OLD | NEW |