OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 // This test verifies that the bad certificate callback works. | 5 // This test verifies that the bad certificate callback works. |
6 | 6 |
7 import "dart:async"; | 7 import "dart:async"; |
8 import "dart:io"; | 8 import "dart:io"; |
9 | 9 |
10 import "package:expect/expect.dart"; | 10 import "package:expect/expect.dart"; |
11 | 11 |
12 final HOST_NAME = 'localhost'; | 12 final HOST_NAME = 'localhost'; |
13 | 13 |
14 String localFile(path) => Platform.script.resolve(path).toFilePath(); | 14 String localFile(path) => Platform.script.resolve(path).toFilePath(); |
15 List<int> readLocalFile(path) => (new File(localFile(path))).readAsBytesSync(); | |
16 | 15 |
17 SecurityContext serverContext = new SecurityContext() | 16 SecurityContext serverContext = new SecurityContext() |
18 ..useCertificateChainBytes(readLocalFile('certificates/server_chain.pem')) | 17 ..useCertificateChainSync(localFile('certificates/server_chain.pem')) |
19 ..usePrivateKeyBytes(readLocalFile('certificates/server_key.pem'), | 18 ..usePrivateKeySync(localFile('certificates/server_key.pem'), |
20 password: 'dartdart'); | 19 password: 'dartdart'); |
21 | 20 |
22 class CustomException {} | 21 class CustomException {} |
23 | 22 |
24 main() async { | 23 main() async { |
25 var HOST = (await InternetAddress.lookup(HOST_NAME)).first; | 24 var HOST = (await InternetAddress.lookup(HOST_NAME)).first; |
26 var server = await SecureServerSocket.bind(HOST_NAME, 0, serverContext); | 25 var server = await SecureServerSocket.bind(HOST_NAME, 0, serverContext); |
27 server.listen((SecureSocket socket) { | 26 server.listen((SecureSocket socket) { |
28 socket.listen((_) {}, onDone: () { | 27 socket.listen((_) {}, onDone: () { |
29 socket.close(); | 28 socket.close(); |
30 }); | 29 }); |
31 }, onError: (e) { if (e is! HandshakeException) throw e; }); | 30 }, onError: (e) { if (e is! HandshakeException) throw e; }); |
32 | 31 |
33 SecurityContext goodContext = new SecurityContext() | 32 SecurityContext goodContext = new SecurityContext() |
34 ..setTrustedCertificates(file: localFile('certificates/trusted_certs.pem')); | 33 ..setTrustedCertificatesSync(localFile('certificates/trusted_certs.pem')); |
35 SecurityContext badContext = new SecurityContext(); | 34 SecurityContext badContext = new SecurityContext(); |
36 SecurityContext defaultContext = SecurityContext.defaultContext; | 35 SecurityContext defaultContext = SecurityContext.defaultContext; |
37 | 36 |
38 await runClient(server.port, goodContext, true, 'pass'); | 37 await runClient(server.port, goodContext, true, 'pass'); |
39 await runClient(server.port, goodContext, false, 'pass'); | 38 await runClient(server.port, goodContext, false, 'pass'); |
40 await runClient(server.port, goodContext, 'fisk', 'pass'); | 39 await runClient(server.port, goodContext, 'fisk', 'pass'); |
41 await runClient(server.port, goodContext, 'exception', 'pass'); | 40 await runClient(server.port, goodContext, 'exception', 'pass'); |
42 await runClient(server.port, badContext, true, 'pass'); | 41 await runClient(server.port, badContext, true, 'pass'); |
43 await runClient(server.port, badContext, false, 'fail'); | 42 await runClient(server.port, badContext, false, 'fail'); |
44 await runClient(server.port, badContext, 'fisk', 'fail'); | 43 await runClient(server.port, badContext, 'fisk', 'fail'); |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
76 Expect.notEquals(result, 'pass'); | 75 Expect.notEquals(result, 'pass'); |
77 if (result == 'fail') { | 76 if (result == 'fail') { |
78 Expect.isTrue(error is HandshakeException || error is ArgumentError); | 77 Expect.isTrue(error is HandshakeException || error is ArgumentError); |
79 } else if (result == 'throw') { | 78 } else if (result == 'throw') { |
80 Expect.isTrue(error is CustomException); | 79 Expect.isTrue(error is CustomException); |
81 } else { | 80 } else { |
82 Expect.fail('Unknown expectation $result'); | 81 Expect.fail('Unknown expectation $result'); |
83 } | 82 } |
84 } | 83 } |
85 } | 84 } |
OLD | NEW |