aboutsummaryrefslogtreecommitdiff
path: root/.github/devcontainers-action/lib
diff options
context:
space:
mode:
authorJosh Spicer <joshspicer@github.com>2022-06-22 22:37:01 +0300
committerGitHub <noreply@github.com>2022-06-22 22:37:01 +0300
commit2e073cdeb0c92ed29f46c4723509dd56430d454e (patch)
tree18ef96684980835caabdb976e05235b7c4473829 /.github/devcontainers-action/lib
parent941f4d4245ebd01863d4ed8857f403823a609816 (diff)
no-ci update action (concurrency)
Diffstat (limited to '.github/devcontainers-action/lib')
-rw-r--r--.github/devcontainers-action/lib/main.js1
-rw-r--r--.github/devcontainers-action/lib/utils.js42
2 files changed, 20 insertions, 23 deletions
diff --git a/.github/devcontainers-action/lib/main.js b/.github/devcontainers-action/lib/main.js
index 2c0ea73..fca18f2 100644
--- a/.github/devcontainers-action/lib/main.js
+++ b/.github/devcontainers-action/lib/main.js
@@ -104,5 +104,4 @@ function packageTemplates(basePath) {
}
});
}
-// Kick off execution
run();
diff --git a/.github/devcontainers-action/lib/utils.js b/.github/devcontainers-action/lib/utils.js
index 1d2e281..ba206ae 100644
--- a/.github/devcontainers-action/lib/utils.js
+++ b/.github/devcontainers-action/lib/utils.js
@@ -91,30 +91,28 @@ function addCollectionsMetadataFile(featuresMetadata, templatesMetadata) {
exports.addCollectionsMetadataFile = addCollectionsMetadataFile;
function getFeaturesAndPackage(basePath) {
return __awaiter(this, void 0, void 0, function* () {
+ const featureDirs = fs.readdirSync(basePath);
let metadatas = [];
- fs.readdir(basePath, (err, files) => {
- if (err) {
- core.error(err.message);
- core.setFailed(`failed to get list of features: ${err.message}`);
- return;
- }
- files.forEach(file => {
- core.info(`feature ==> ${file}`);
- if (file !== '.' && file !== '..') {
- const featureFolder = path_1.default.join(basePath, file);
- const archiveName = `${file}.tgz`;
- tarDirectory(`${basePath}/${file}`, archiveName);
- const featureJsonPath = path_1.default.join(featureFolder, 'devcontainer-feature.json');
- if (!fs.existsSync(featureJsonPath)) {
- core.error(`Feature ${file} is missing a devcontainer-feature.json`);
- core.setFailed('All features must have a devcontainer-feature.json');
- return;
- }
- const featureMetadata = JSON.parse(fs.readFileSync(featureJsonPath, 'utf8'));
- metadatas.push(featureMetadata);
+ yield Promise.all(featureDirs.map((f) => __awaiter(this, void 0, void 0, function* () {
+ core.info(`feature ==> ${f}`);
+ if (f !== '.' && f !== '..') {
+ const featureFolder = path_1.default.join(basePath, f);
+ const archiveName = `${f}.tgz`;
+ yield tarDirectory(`${basePath}/${f}`, archiveName);
+ const featureJsonPath = path_1.default.join(featureFolder, 'devcontainer-feature.json');
+ if (!fs.existsSync(featureJsonPath)) {
+ core.error(`Feature ${f} is missing a devcontainer-feature.json`);
+ core.setFailed('All features must have a devcontainer-feature.json');
+ return;
}
- });
- });
+ const featureMetadata = JSON.parse(fs.readFileSync(featureJsonPath, 'utf8'));
+ metadatas.push(featureMetadata);
+ }
+ })));
+ if (metadatas.length === 0) {
+ core.setFailed('No features found');
+ return;
+ }
return metadatas;
});
}