1
1
mirror of https://github.com/leon-ai/leon.git synced 2024-12-20 15:21:36 +03:00
leon/scripts/release/generate-changelog.js

61 lines
1.9 KiB
JavaScript
Raw Normal View History

import { command } from 'execa'
2019-02-10 15:26:50 +03:00
import fs from 'fs'
import { LogHelper } from '@/helpers/log-helper'
2019-02-10 15:26:50 +03:00
/**
* Update version number in files which need version number
*/
2022-09-03 14:12:41 +03:00
export default (version) =>
new Promise(async (resolve, reject) => {
const changelog = 'CHANGELOG.md'
const tmpChangelog = 'TMP-CHANGELOG.md'
LogHelper.info(`Generating ${changelog}...`)
2022-09-03 14:12:41 +03:00
try {
await command(
`git-changelog --changelogrc .changelogrc --template scripts/assets/CHANGELOG-TEMPLATE.md --file scripts/tmp/${tmpChangelog} --version_name ${version}`,
{ shell: true }
)
} catch (e) {
LogHelper.error(`Error during git-changelog: ${e}`)
2022-09-03 14:12:41 +03:00
reject(e)
}
2019-02-10 15:26:50 +03:00
2022-09-03 14:12:41 +03:00
try {
LogHelper.info('Getting remote origin URL...')
LogHelper.info('Getting previous tag...')
2019-02-10 15:26:50 +03:00
2022-09-03 14:12:41 +03:00
const sh = await command(
'git config --get remote.origin.url && git tag | tail -n1',
{ shell: true }
)
2019-02-10 15:26:50 +03:00
2022-09-03 14:12:41 +03:00
const repoUrl = sh.stdout.substr(0, sh.stdout.lastIndexOf('.git'))
const previousTag = sh.stdout.substr(sh.stdout.indexOf('\n') + 1).trim()
const changelogData = fs.readFileSync(changelog, 'utf8')
const compareUrl = `${repoUrl}/compare/${previousTag}...v${version}`
let tmpData = fs.readFileSync(`scripts/tmp/${tmpChangelog}`, 'utf8')
2019-02-10 15:26:50 +03:00
LogHelper.success(`Remote origin URL gotten: ${repoUrl}.git`)
LogHelper.success(`Previous tag gotten: ${previousTag}`)
2019-02-10 15:26:50 +03:00
2022-09-03 14:12:41 +03:00
if (previousTag !== '') {
tmpData = tmpData.replace(version, `[${version}](${compareUrl})`)
}
2019-02-10 15:26:50 +03:00
2022-09-03 14:12:41 +03:00
fs.writeFile(changelog, `${tmpData}${changelogData}`, (err) => {
if (err) LogHelper.error(`Failed to write into file: ${err}`)
2022-09-03 14:12:41 +03:00
else {
fs.unlinkSync(`scripts/tmp/${tmpChangelog}`)
LogHelper.success(`${changelog} generated`)
2022-09-03 14:12:41 +03:00
resolve()
}
})
} catch (e) {
LogHelper.error(`Error during git commands: ${e}`)
2022-09-03 14:12:41 +03:00
reject(e)
2019-02-10 15:26:50 +03:00
}
2022-09-03 14:12:41 +03:00
})