Fix appending body of an existing draft release

Don't just return the release without doing anything else, this
prevented "append_body" from having any effect when updating an existing
draft release.
This commit is contained in:
Vadim Zeitlin 2022-09-04 15:59:04 +02:00
parent cd28b0f5ee
commit 56aa1497d9
2 changed files with 23 additions and 16 deletions

2
dist/index.js vendored

File diff suppressed because one or more lines are too long

View file

@ -201,45 +201,52 @@ export const release = async (
try {
// you can't get a an existing draft by tag
// so we must find one in the list of all releases
let existingRelease;
if (config.input_draft) {
for await (const response of releaser.allReleases({
owner,
repo
})) {
let release = response.data.find(release => release.tag_name === tag);
let release = response.data.find(
release => release.name === config.input_name
);
if (release) {
return release;
existingRelease = release;
break;
}
}
} else {
existingRelease = (
await releaser.getReleaseByTag({
owner,
repo,
tag
})
).data;
}
let existingRelease = await releaser.getReleaseByTag({
owner,
repo,
tag
});
const release_id = existingRelease.data.id;
const release_id = existingRelease.id;
let target_commitish: string;
if (
config.input_target_commitish &&
config.input_target_commitish !== existingRelease.data.target_commitish
config.input_target_commitish !== existingRelease.target_commitish
) {
console.log(
`Updating commit from "${existingRelease.data.target_commitish}" to "${config.input_target_commitish}"`
`Updating commit from "${existingRelease.target_commitish}" to "${config.input_target_commitish}"`
);
target_commitish = config.input_target_commitish;
} else {
target_commitish = existingRelease.data.target_commitish;
target_commitish = existingRelease.target_commitish;
}
const tag_name = tag;
const name = config.input_name || existingRelease.data.name || tag;
const name = config.input_name || existingRelease.name || tag;
// revisit: support a new body-concat-strategy input for accumulating
// body parts as a release gets updated. some users will likely want this while
// others won't previously this was duplicating content for most which
// no one wants
const workflowBody = releaseBody(config) || "";
const existingReleaseBody = existingRelease.data.body || "";
const existingReleaseBody = existingRelease.body || "";
let body: string;
if (config.input_append_body && workflowBody && existingReleaseBody) {
body = existingReleaseBody + "\n" + workflowBody;
@ -250,11 +257,11 @@ export const release = async (
const draft =
config.input_draft !== undefined
? config.input_draft
: existingRelease.data.draft;
: existingRelease.draft;
const prerelease =
config.input_prerelease !== undefined
? config.input_prerelease
: existingRelease.data.prerelease;
: existingRelease.prerelease;
const release = await releaser.updateRelease({
owner,