| 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 |