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_sha1_test; | 6 library hmac_sha1_test; |
7 | 7 |
8 import "package:crypto/crypto.dart"; | 8 import "package:crypto/crypto.dart"; |
9 import "package:test/test.dart"; | 9 import "package:test/test.dart"; |
10 | 10 |
11 part 'hmac_sha1_test_vectors.dart'; | 11 part 'hmac_sha1_test_vectors.dart'; |
12 | 12 |
13 | |
14 void main() { | 13 void main() { |
15 test('standard vectors', () { | 14 test('standard vectors', () { |
16 _testStandardVectors(hmac_sha1_inputs, hmac_sha1_keys, hmac_sha1_macs); | 15 _testStandardVectors(hmac_sha1_inputs, hmac_sha1_keys, hmac_sha1_macs); |
17 }); | 16 }); |
18 } | 17 } |
19 | 18 |
20 void _testStandardVectors(inputs, keys, macs) { | 19 void _testStandardVectors(inputs, keys, macs) { |
21 for (var i = 0; i < inputs.length; i++) { | 20 for (var i = 0; i < inputs.length; i++) { |
22 var hmac = new HMAC(new SHA1(), keys[i]); | 21 var hmac = new HMAC(new SHA1(), keys[i]); |
23 hmac.add(inputs[i]); | 22 hmac.add(inputs[i]); |
24 var d = hmac.close(); | 23 var d = hmac.close(); |
25 expect(CryptoUtils.bytesToHex(d), startsWith(macs[i])); | 24 expect(CryptoUtils.bytesToHex(d), startsWith(macs[i])); |
26 } | 25 } |
27 } | 26 } |
OLD | NEW |