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("dart:crypto"); | 8 import 'dart:crypto'; |
9 | 9 |
10 #source('hmac_sha256_test_vectors.dart'); | 10 part 'hmac_sha256_test_vectors.dart'; |
11 | 11 |
12 void testStandardVectors(inputs, keys, macs) { | 12 void testStandardVectors(inputs, keys, macs) { |
13 for (var i = 0; i < inputs.length; i++) { | 13 for (var i = 0; i < inputs.length; i++) { |
14 var d = new HMAC(new SHA256(), keys[i]).update(inputs[i]).digest(); | 14 var d = new HMAC(new SHA256(), keys[i]).update(inputs[i]).digest(); |
15 Expect.isTrue(CryptoUtils.bytesToHex(d).startsWith(macs[i]), '$i'); | 15 Expect.isTrue(CryptoUtils.bytesToHex(d).startsWith(macs[i]), '$i'); |
16 } | 16 } |
17 } | 17 } |
18 | 18 |
19 void main() { | 19 void main() { |
20 testStandardVectors(hmac_sha256_inputs, hmac_sha256_keys, hmac_sha256_macs); | 20 testStandardVectors(hmac_sha256_inputs, hmac_sha256_keys, hmac_sha256_macs); |
21 } | 21 } |
OLD | NEW |