OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS d.file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS d.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 d.file. | 3 // BSD-style license that can be found in the LICENSE d.file. |
4 | 4 |
5 import 'dart:io'; | 5 import 'dart:io'; |
6 | 6 |
7 import 'package:pathos/path.dart' as path; | 7 import 'package:pathos/path.dart' as path; |
8 import 'package:scheduled_test/scheduled_test.dart'; | 8 import 'package:scheduled_test/scheduled_test.dart'; |
9 | 9 |
10 import '../../../../pub/exit_codes.dart' as exit_codes; | 10 import '../../../lib/src/exit_codes.dart' as exit_codes; |
11 import '../../descriptor.dart' as d; | 11 import '../../descriptor.dart' as d; |
12 import '../../test_pub.dart'; | 12 import '../../test_pub.dart'; |
13 | 13 |
14 main() { | 14 main() { |
15 initConfig(); | 15 initConfig(); |
16 integration('path dependency to non-existent directory', () { | 16 integration('path dependency to non-existent directory', () { |
17 var badPath = path.join(sandboxDir, "bad_path"); | 17 var badPath = path.join(sandboxDir, "bad_path"); |
18 | 18 |
19 d.dir(appPath, [ | 19 d.dir(appPath, [ |
20 d.pubspec({ | 20 d.pubspec({ |
21 "name": "myapp", | 21 "name": "myapp", |
22 "dependencies": { | 22 "dependencies": { |
23 "foo": {"path": badPath} | 23 "foo": {"path": badPath} |
24 } | 24 } |
25 }) | 25 }) |
26 ]).create(); | 26 ]).create(); |
27 | 27 |
28 // TODO(rnystrom): The "\" in a Windows path gets treated like a regex | 28 // TODO(rnystrom): The "\" in a Windows path gets treated like a regex |
29 // character, so hack escape. A better fix is to use a literal string | 29 // character, so hack escape. A better fix is to use a literal string |
30 // instead of a RegExp to validate, but that requires us to move the | 30 // instead of a RegExp to validate, but that requires us to move the |
31 // stack traces out of the stderr when we invoke pub. See also: #4706. | 31 // stack traces out of the stderr when we invoke pub. See also: #4706. |
32 var escapePath = badPath.replaceAll(r"\", r"\\"); | 32 var escapePath = badPath.replaceAll(r"\", r"\\"); |
33 | 33 |
34 schedulePub(args: ['install'], | 34 schedulePub(args: ['install'], |
35 error: | 35 error: |
36 new RegExp("Could not find package 'foo' at '$escapePath'."), | 36 new RegExp("Could not find package 'foo' at '$escapePath'."), |
37 exitCode: exit_codes.DATA); | 37 exitCode: exit_codes.DATA); |
38 }); | 38 }); |
39 } | 39 } |
OLD | NEW |