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