From e7cc07518b2dedf0435d5835a057619466ea3247 Mon Sep 17 00:00:00 2001 From: Yansong Yang Date: Tue, 2 Apr 2024 15:28:02 -0500 Subject: [PATCH] [Release Notes Automation] several enhancements (#550) --- .../scripts/release_notes/android-release.js | 2 +- .../scripts/release_notes/github-release.js | 3 +-- .../release_notes/update-release-notes.js | 25 ++++++++++++++++--- 3 files changed, 23 insertions(+), 7 deletions(-) diff --git a/.github/scripts/release_notes/android-release.js b/.github/scripts/release_notes/android-release.js index 1606acf033..c4691a9a0a 100644 --- a/.github/scripts/release_notes/android-release.js +++ b/.github/scripts/release_notes/android-release.js @@ -158,7 +158,7 @@ function buildGitHubInfo(artifactId, artifactVersion) { case "identity": case "signal": return { - repoName: `aepsdk-${artifactId}-android`, + repoName: `aepsdk-core-android`, tagName: `v${artifactVersion}-${artifactId}` } diff --git a/.github/scripts/release_notes/github-release.js b/.github/scripts/release_notes/github-release.js index 8ce5f860d0..baa14a2a43 100644 --- a/.github/scripts/release_notes/github-release.js +++ b/.github/scripts/release_notes/github-release.js @@ -95,11 +95,10 @@ async function fetchReleaseInfoWithTagName(token, owner, repo, tag) { }; console.log(`request options: ${JSON.stringify(options)}`) - return new Promise((resolve) => { let reqGet = https.request(options, function (res) { if (res.statusCode != 200) { - console.error(`Error: response statusCode: ${res.statusCode}, please check if the tag (${tag}) exists in Github repo.`) + throw Error(`Error: response statusCode: ${res.statusCode}, please check if the tag (${tag}) exists in Github repo.`) } console.log(`response statusCode: ${res.statusCode}`) diff --git a/.github/scripts/release_notes/update-release-notes.js b/.github/scripts/release_notes/update-release-notes.js index aa0627b3f1..e8cb99654d 100644 --- a/.github/scripts/release_notes/update-release-notes.js +++ b/.github/scripts/release_notes/update-release-notes.js @@ -15,6 +15,7 @@ const { fetchAndroidReleaseInfo } = require('./android-release'); const { capitalizeFirstLetter, convertISODateToRleaseDateFormat, extractReleaseNotes } = require('./utils'); const lodashTemplate = require('lodash.template'); const fs = require("fs"); +const _ = require('lodash'); const repoNames = [ "aepsdk-roku", @@ -102,10 +103,27 @@ function extractBOMTableContent(releaseNote) { return newLines } +function cleanupReleaseContent(items) { + // Find the index of the first non-empty item + const firstNonEmptyIndex = _.findIndex(items, item => item.trim() !== ''); + + // Find the index of the last non-empty item + const lastNonEmptyIndex = _.findLastIndex(items, item => item.trim() !== ''); + + // If no non-empty items are found, return an empty array + if (firstNonEmptyIndex === -1 || lastNonEmptyIndex === -1) { + return []; + } + + // Return the array sliced from the first to the last non-empty item + const trimmedItems = items.slice(firstNonEmptyIndex, lastNonEmptyIndex + 1); + // If the first non-empty item is "-", replace it with "*" + return trimmedItems.map(item => item.replace(/^\s*-/, '*')) +} + function generateReleaseNoteSection(ISODateString, platform, extension, version, releaseNote) { let array = extractReleaseNotes(releaseNote) - // remove the empty lines - array = array.filter(line => line.trim() != '') + array = cleanupReleaseContent(array) let releaseNoteSection = releaseNoteTemplateGenerator({ date: convertISODateToRleaseDateFormat(ISODateString), title: `${platform} ${extension} ${version}`, @@ -116,8 +134,7 @@ function generateReleaseNoteSection(ISODateString, platform, extension, version, function generateReleaseNoteSectionWithoutDateLine(platform, extension, version, releaseNote) { let array = extractReleaseNotes(releaseNote) - // remove the empty lines - array = array.filter(line => line.trim() != '') + array = cleanupReleaseContent(array) let releaseNoteSection = releaseNoteWithoutDateTemplateGenerator({ title: `${platform} ${extension} ${version}`, note: array.join('\n')