Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
73 changes: 59 additions & 14 deletions build-automation.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,26 @@ const checkIfThereAreNewVersions = async (github) => {

for (let supportedVersion of supportedVersions) {
const { stdout } = await exec(`ls ${supportedVersion}`);
const baseVersions = stdout.trim().split("\n");

const { stdout: fullVersionOutput } = await exec(`. ./functions.sh && get_full_version ./${supportedVersion}/${stdout.trim().split("\n")[0]}`, { shell: "bash" });
const standardVersion = baseVersions.find(v => !v.startsWith("alpine"));
const alpineVersion = baseVersions.find(v => v.startsWith("alpine"));
//skip if no base version found
if (!standardVersion || !alpineVersion) {
continue;
}

const { stdout: standardVersionOutput } = await exec(`. ./functions.sh && get_full_version ./${supportedVersion}/${standardVersion}`, { shell: "bash" });
const { stdout: alpineVersionOutput } = await exec(`. ./functions.sh && get_full_version ./${supportedVersion}/${alpineVersion}`, { shell: "bash" });
Comment thread
ItsHarta marked this conversation as resolved.
Comment thread
ItsHarta marked this conversation as resolved.

console.log(fullVersionOutput);
const fullVersion = { main : standardVersionOutput.trim(), alpine: alpineVersionOutput.trim() };
console.log(`${supportedVersion}: main=${fullVersion.main}, alpine=${fullVersion.alpine}`);

latestSupportedVersions[supportedVersion] = { fullVersion: fullVersionOutput.trim() };
latestSupportedVersions[supportedVersion] = {
fullVersion: fullVersion.main,
alpineVersion: fullVersion.alpine,
alpineIsBehind: fullVersion.main !== fullVersion.alpine
};
}

const { data: availableVersionsJson } = await github.request('https://nodejs.org/download/release/index.json');
Expand All @@ -39,9 +53,25 @@ const checkIfThereAreNewVersions = async (github) => {
if (latestSupportedVersions[availableMajor] == null) {
continue;
}
const [_latestMajor, latestMinor, latestPatch] = latestSupportedVersions[availableMajor].fullVersion.split(".");
if (latestSupportedVersions[availableMajor] && (Number(availableMinor) > Number(latestMinor) || (availableMinor === latestMinor && Number(availablePatch) > Number(latestPatch)))) {
filteredNewerVersions[availableMajor] = { fullVersion: `${availableMajor}.${availableMinor}.${availablePatch}` };

const supported = latestSupportedVersions[availableMajor];
const [_latestMajor, latestMinor, latestPatch] = supported.fullVersion.split(".");
const [_alpineMajor, alpineMinor, alpinePatch] = supported.alpineVersion.split(".");

const availableFullVersion = `${availableMajor}.${availableMinor}.${availablePatch}`;

const newMainline = Number(availableMinor) > Number(latestMinor) || (availableMinor === latestMinor && Number(availablePatch) > Number(latestPatch));
const newAlpine = Number(availableMinor) > Number(alpineMinor) || (availableMinor === alpineMinor && Number(availablePatch) > Number(alpinePatch));

const isCatchup = supported.alpineIsBehind && newAlpine && availableFullVersion === supported.fullVersion;

// Alpine will be always behind or equal to main
// So if main is new version, then alpineOnly is always false. And vice versa
if (newMainline || isCatchup) {
filteredNewerVersions[availableMajor] = {
fullVersion: availableFullVersion,
alpineOnly: !newMainline
};
Comment thread
ItsHarta marked this conversation as resolved.
}
}

Expand Down Expand Up @@ -87,16 +117,31 @@ export default async function(github) {
} else {
const newVersions = await checkForMuslVersionsAndSecurityReleases(github, versions);
let updatedVersions = [];

for (const [version, newVersion] of Object.entries(newVersions)) {
if (newVersion.muslBuildExists) {
const { stdout } = await exec(`./update.sh ${newVersion.isSecurityRelease ? "-s " : ""}${version}`);
console.log(stdout);
updatedVersions.push(newVersion.fullVersion);
} else {
console.log(`There's no musl build for version ${newVersion.fullVersion} yet.`);
process.exit(0);
}
const { fullVersion, muslBuildExists, isSecurityRelease, alpineOnly } = newVersion;
// If MUSL is available: build everything (new versions) or alpine only (catch-up)
if (muslBuildExists) {
const updateScope = alpineOnly ? "alpine" : "";

console.log(`MUSL available. Updating ${fullVersion} ${updateScope}.`.trim());
const { stdout } = await exec(`./update.sh ${version} ${updateScope}`.trim());
console.log(stdout);

updatedVersions.push(`${fullVersion} ${updateScope}`.trim());
// Security release: no MUSL build
} else if (isSecurityRelease && !alpineOnly) {
console.log(`Updating ${fullVersion} for non-alpine.`);

const { stdout } = await exec(`./update.sh -s ${version}`);
console.log(stdout);

updatedVersions.push(`${fullVersion} (non-alpine)`);
} else {
console.log(`No MUSL build for ${fullVersion} yet.`);
}
}

const { stdout } = (await exec(`git diff`));
console.log(stdout);

Expand Down
2 changes: 1 addition & 1 deletion functions.sh
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ function get_variants() {
if [ ${#variantsfilter[@]} -gt 0 ]; then
for variant1 in "${availablevariants[@]}"; do
for variant2 in "${variantsfilter[@]}"; do
if [ "${variant1}" = "${variant2}" ]; then
if [[ "${variant1}" =~ ^"${variant2}" ]]; then
variants+=("${variant1}")
Comment thread
ItsHarta marked this conversation as resolved.
fi
done
Expand Down
14 changes: 14 additions & 0 deletions update.sh
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,14 @@ function update_node_version() {

nodeVersion="${version}.${fullVersion:-0}"

# preserve the existing YARN_VERSION
if [ "${SKIP}" = true ] && [ -f "${dockerfile}" ]; then
existing_yarn_version=$(grep -m1 'ENV YARN_VERSION=' "${dockerfile}" | cut -d'=' -f2 || echo "")
if [ -n "${existing_yarn_version}" ]; then
sed -Ei -e 's/^(ENV YARN_VERSION)=.*/\1='"${existing_yarn_version}"'/' "${dockerfile}-tmp"
fi
fi

sed -Ei -e 's/^FROM (.*)/FROM '"$fromprefix"'\1/' "${dockerfile}-tmp"
sed -Ei -e 's/^(ENV NODE_VERSION)=.*/\1='"${nodeVersion}"'/' "${dockerfile}-tmp"

Expand Down Expand Up @@ -208,6 +216,12 @@ for version in "${versions[@]}"; do
# Skip non-docker directories
[ -f "${version}/${variant}/Dockerfile" ] || continue

# Skip alpine variants when SKIP is true
if [ "${SKIP}" = true ] && is_alpine "${variant}"; then
Comment thread
ItsHarta marked this conversation as resolved.
info "SKIP=true; skipping alpine variant '${variant}' for version '${versionnum}' (will need updating once MUSL builds are available)"
continue
fi

update_variant=$(in_variants_to_update "${variant}")
template_file="${parentpath}/Dockerfile-${variant}.template"

Expand Down