Skip to content
Snippets Groups Projects
Commit 03c45260 authored by nweiz@google.com's avatar nweiz@google.com
Browse files

Create packages directories in test/ and bin/ as well as at the top level.

This is necessary to run Dart files in these directories.

Review URL: https://chromiumcodereview.appspot.com//10900015

git-svn-id: https://dart.googlecode.com/svn/branches/bleeding_edge@11549 260f80e4-7a28-3924-810f-c04153c831b5
parent ea3b4abe
No related branches found
No related tags found
No related merge requests found
......@@ -148,7 +148,9 @@ class Entrypoint {
if (id.source is RootSource) return new Future.immediate(id);
return install(id);
}));
}).chain(_saveLockFile).chain(_installSelfReference);
}).chain(_saveLockFile)
.chain(_installSelfReference)
.chain(_linkSecondaryPackageDirs);
}
/**
......@@ -226,6 +228,74 @@ class Entrypoint {
});
}
/**
* If `bin/`, `test/`, or `example/` directories exist, symlink `packages/`
* into them so that their entrypoints can be run. Do the same for any
* subdirectories of `test/` and `example/`.
*/
Future _linkSecondaryPackageDirs(_) {
var binDir = join(root.dir, 'bin');
var testDir = join(root.dir, 'test');
var exampleDir = join(root.dir, 'example');
return dirExists(binDir).chain((exists) {
if (!exists) return new Future.immediate(null);
return _linkSecondaryPackageDir(binDir);
}).chain((_) => _linkSecondaryPackageDirsRecursively(testDir))
.chain((_) => _linkSecondaryPackageDirsRecursively(exampleDir));
}
/**
* Creates a symlink to the `packages` directory in [dir] and all its
* subdirectories.
*/
Future _linkSecondaryPackageDirsRecursively(String dir) {
return dirExists(dir).chain((exists) {
if (!exists) return new Future.immediate(null);
return _linkSecondaryPackageDir(dir)
.chain((_) => _listDirWithoutPackages(dir))
.chain((files) {
return Futures.wait(files.map((file) {
return dirExists(file).chain((isDir) {
if (!isDir) return new Future.immediate(null);
return _linkSecondaryPackageDir(file);
});
}));
});
});
}
// TODO(nweiz): roll this into [listDir] in io.dart once issue 4775 is fixed.
/**
* Recursively lists the contents of [dir], excluding hidden `.DS_Store` files
* and `package` files.
*/
Future<List<String>> _listDirWithoutPackages(dir) {
return listDir(dir).chain((files) {
return Futures.wait(files.map((file) {
if (basename(file) == 'packages') return new Future.immediate([]);
return dirExists(file).chain((isDir) {
if (!isDir) return new Future.immediate([]);
return _listDirWithoutPackages(file);
}).transform((subfiles) {
var fileAndSubfiles = [file];
fileAndSubfiles.addAll(subfiles);
return fileAndSubfiles;
});
}));
}).transform(flatten);
}
/**
* Creates a symlink to the `packages` directory in [dir] if none exists.
*/
Future _linkSecondaryPackageDir(String dir) {
var to = join(dir, 'packages');
return exists(to).chain((exists) {
if (exists) return new Future.immediate(null);
return createSymlink(path, to);
});
}
/**
* Validate that the pubspec for the entrypoint exists and specifies the name
* of the root package.
......
......@@ -48,4 +48,76 @@ main() {
run();
});
group('creates a packages directory in', () {
test('"test/" and its subdirectories', () {
dir(appPath, [
appPubspec([]),
dir("test", [dir("subtest")])
]).scheduleCreate();
schedulePub(args: ['install'],
output: const RegExp(@"Dependencies installed!$"));
dir(appPath, [
dir("test", [
dir("packages", [
dir("myapp", [appPubspec([])])
]),
dir("subtest", [
dir("packages", [
dir("myapp", [appPubspec([])])
])
])
])
]).scheduleValidate();
run();
});
test('"example/" and its subdirectories', () {
dir(appPath, [
appPubspec([]),
dir("example", [dir("subexample")])
]).scheduleCreate();
schedulePub(args: ['install'],
output: const RegExp(@"Dependencies installed!$"));
dir(appPath, [
dir("example", [
dir("packages", [
dir("myapp", [appPubspec([])])
]),
dir("subexample", [
dir("packages", [
dir("myapp", [appPubspec([])])
])
])
])
]).scheduleValidate();
run();
});
test('"bin/"', () {
dir(appPath, [
appPubspec([]),
dir("bin")
]).scheduleCreate();
schedulePub(args: ['install'],
output: const RegExp(@"Dependencies installed!$"));
dir(appPath, [
dir("bin", [
dir("packages", [
dir("myapp", [appPubspec([])])
])
])
]).scheduleValidate();
run();
});
});
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment