From 81f243d4d53459d89882d838214a8b247372f3b1 Mon Sep 17 00:00:00 2001 From: Stefanos Anagnostou Date: Fri, 20 Dec 2024 18:37:38 +0200 Subject: [PATCH] chore(repo): Fix releases slack post [internal] --- .changeset/sharp-vans-sit.md | 2 ++ scripts/notify.mjs | 40 ++++++++++++++++++++++++++++-------- 2 files changed, 34 insertions(+), 8 deletions(-) create mode 100644 .changeset/sharp-vans-sit.md diff --git a/.changeset/sharp-vans-sit.md b/.changeset/sharp-vans-sit.md new file mode 100644 index 0000000000..a845151cc8 --- /dev/null +++ b/.changeset/sharp-vans-sit.md @@ -0,0 +1,2 @@ +--- +--- diff --git a/scripts/notify.mjs b/scripts/notify.mjs index 9e7c787e99..5f5a7b67ab 100644 --- a/scripts/notify.mjs +++ b/scripts/notify.mjs @@ -51,7 +51,6 @@ const getReleaseChannel = version => { const slackFormatter = { generateChangelog: ({ packageData, releasePrUrl, pusher }) => { const markdown = text => ({ type: 'section', text: { type: 'mrkdwn', text } }); - const divider = () => ({ type: 'divider' }); const header = text => ({ type: 'header', text: { type: 'plain_text', text } }); const context = (imgUrl, text) => ({ type: 'context', @@ -64,15 +63,12 @@ const slackFormatter = { const releaseChannel = getReleaseChannel(packageData?.[0]?.version); blocks.push(header(`Javascript SDKs - ${releaseChannel} Release - ${new Date().toLocaleDateString('en-US')}`)); + blocks.push(markdown(`All release PRs for this day can be found <${releasePrUrl}|here>.\nReleased packages:\n`)); - let body = ''; - for (const { name, version, changelogUrl } of packageData) { - body += `• <${changelogUrl}|Changelog> - \`${name}@${version}\`\n`; - } + createPackagesBody(packageData).forEach(body => { + blocks.push(markdown(body)); + }); - blocks.push(markdown(`All release PRs for this day can be found <${releasePrUrl}|here>.\nReleased packages:\n`)); - blocks.push(markdown(body)); - // blocks.push(divider()); blocks.push(markdown('\n')); blocks.push(context(pusher.avatarUrl, `<${pusher.profileUrl}|*${pusher.username}*> triggered this release.`)); @@ -80,6 +76,34 @@ const slackFormatter = { }, }; +/** + * @property {PackageData[]} packageData + */ +const createPackagesBody = packageData => { + // The Slack API has a limitation of ~3000 characters per block and + // also there is a limit on the number of blocks that can be sent in a single message. + // So, we split the body into fragments of 10 packages each. + const fragments = []; + let body = ''; + let count = 0; + for (const { name, version, changelogUrl } of packageData) { + body += `• <${changelogUrl}|Changelog> - \`${name}@${version}\`\n`; + count++; + + if (count === 10) { + fragments.push(body); + body = ''; + count = 0; + } + } + // This is the remaining + if (body) { + fragments.push(body); + } + + return fragments; +}; + /** * @type {Record} */