diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..3180e34 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,17 @@ +# [2.5.2] - 2021-5-18 [PR: #41](https://github.com/dolittle/establish-context-action/pull/41) +## Summary + +The main purpose of this PR was to fix an issue we were having when we were releasing fixes while working on a new prerelease in a branch. So for example say we were working on `5.6.0-embeddings` while the latest release was on `5.5.2`. When we merged in a _patch_ to master, the expected new version should be `5.5.3`, but was `5.6.0`. + +Factored out the fetching of versions from `CurrentVersionFinder` so that we can write some specs for it, wrote specs, and fixed the implementation. Also cleaned up some documentation to make it all the same (a few different styles floating around), and removed some unused code. + +### Added + +- `IVersionFetcher` and implementation `GitHubTagsVersionFetcher` using existing code. +- Specifications for `CurrentVersionFinder` + +### Fixed + +- `CurrentVersionFinder` so that it disregards running prereleases when pulling in a normal release. Also found some other potential small issues that we have not encountered. + + diff --git a/release/index.js b/release/index.js index acc9c68..f99aae8 100644 --- a/release/index.js +++ b/release/index.js @@ -375,7 +375,7 @@ function run() { return __awaiter(this, void 0, void 0, function* () { try { const token = core_1.getInput('token', { required: true }); - const prereleaseBranches = (_b = (_a = core_1.getInput('prerelease-branches', { required: false })) === null || _a === void 0 ? void 0 : _a.split(',')) !== null && _b !== void 0 ? _b : []; + const prereleaseBranches = (_b = (_a = core_1.getInput('prerelease-branches', { required: false })) === null || _a === void 0 ? void 0 : _a.split(',').map(_ => _.trim())) !== null && _b !== void 0 ? _b : []; const currentVersion = (_c = core_1.getInput('current-version', { required: false })) !== null && _c !== void 0 ? _c : ''; const versionFile = (_d = core_1.getInput('version-file', { required: false })) !== null && _d !== void 0 ? _d : ''; const environmentBranch = core_1.getInput('environment-branch', { required: false }); @@ -443,7 +443,7 @@ function fail(error) { core_1.setFailed(error.message); } -//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Source/action.ts"],"names":[],"mappings":"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","file":"action.js","sourcesContent":["// Copyright (c) Dolittle. All rights reserved.\n// Licensed under the MIT license. See LICENSE file in the project root for full license information.\n\nimport { getInput, setOutput, setFailed } from '@actions/core';\nimport { getOctokit, context } from '@actions/github';\nimport { Logger } from '@dolittle/github-actions.shared.logging';\n\nimport {\n    CurrentVersionFinder,\n    IFindCurrentVersion,\n    DefinedVersionFinder,\n    SemVerVersionSorter\n} from './Version';\n\nimport { ReleaseTypeExtractor } from './ReleaseType/ReleaseTypeExtractor';\nimport { ContextEstablishers } from './ContextEstablishers';\nimport { CascadingContextEstablisher } from './CascadingBuildContextEstablisher';\nimport { MergedPullRequestContextEstablisher } from './MergedPullRequestContextEstablisher';\nimport { BuildContext } from './BuildContext';\nimport { VersionFromFileVersionFinder } from './Version/VersionFromFileVersionFinder';\nimport { GitHubTagsVersionFetcher } from './Version/GitHubTagsVersionFetcher';\n\nconst logger = new Logger();\n\nrun();\nexport async function run() {\n    try {\n        const token = getInput('token', { required: true });\n        const prereleaseBranches = getInput('prerelease-branches', { required: false })?.split(',') ?? [];\n        const currentVersion = getInput('current-version', { required: false }) ?? '';\n        const versionFile = getInput('version-file', { required: false }) ?? '';\n        const environmentBranch = getInput('environment-branch', { required: false });\n\n        logger.info(`Pushes to branches: [master, main, ${prereleaseBranches.join(', ')}] can trigger a release`);\n        const octokit = getOctokit(token);\n        const releaseTypeExtractor = new ReleaseTypeExtractor(logger);\n\n        let currentVersionFinder: IFindCurrentVersion;\n\n        logger.info('Inputs:');\n        logger.info(` prerelease-branches: '${prereleaseBranches}'`);\n        logger.info(` environment-branch: '${environmentBranch}'`);\n        logger.info(` currentVersion: '${currentVersion}'`);\n        logger.info(` versionFile: '${versionFile}'`);\n\n        if (versionFile.length > 0) {\n            logger.info('Using file strategy for finding version');\n            currentVersionFinder = new VersionFromFileVersionFinder(versionFile, logger);\n        } else if (currentVersion.length > 0) {\n            logger.info('Using defined version strategy for finding version');\n            currentVersionFinder = new DefinedVersionFinder(currentVersion);\n        } else {\n            logger.info('Using tag strategy for finding version');\n            currentVersionFinder = new CurrentVersionFinder(\n                new GitHubTagsVersionFetcher(context, octokit, logger),\n                new SemVerVersionSorter(logger),\n                logger);\n        }\n\n        const contextEstablishers = new ContextEstablishers(\n            new CascadingContextEstablisher(currentVersionFinder, logger),\n            new MergedPullRequestContextEstablisher(prereleaseBranches, environmentBranch, releaseTypeExtractor, currentVersionFinder, octokit, logger)\n        );\n        logger.info('Establishing context');\n        const buildContext = await contextEstablishers.establishFrom(context);\n        if (buildContext === undefined) {\n            logger.debug('No establisher found for context');\n            logger.debug(JSON.stringify(context, undefined, 2));\n            outputDefault();\n        }\n        else outputContext(buildContext);\n\n    } catch (error) {\n        fail(error);\n    }\n}\n\nfunction output(\n    shouldPublish: boolean,\n    cascadingRelease: boolean,\n    currentVersion?: string,\n    releaseType?: string,\n    prBody?: string,\n    prUrl?: string) {\n    logger.info('Outputting: ');\n    logger.info(`'should-publish': ${shouldPublish}`);\n    logger.info(`'cascading-release': ${cascadingRelease}`);\n    logger.info(`'current-version': ${currentVersion}`);\n    logger.info(`'release-type': ${releaseType}`);\n    logger.info(`'pr-body': ${prBody}`);\n    logger.info(`'pr-url': ${prUrl}`);\n\n    setOutput('should-publish', shouldPublish);\n    setOutput('cascading-release', cascadingRelease);\n    setOutput('current-version', currentVersion ?? '');\n    setOutput('release-type', releaseType ?? '');\n    setOutput('pr-body', prBody ?? '');\n    setOutput('pr-url', prUrl ?? '');\n}\nfunction outputContext(context: BuildContext) {\n    output(\n        context.shouldPublish,\n        context.cascadingRelease,\n        context.currentVersion,\n        context.releaseType,\n        context.pullRequestBody,\n        context.pullRequestUrl);\n}\n\nfunction outputDefault() {\n    output(false, false);\n}\n\nfunction fail(error: Error) {\n    logger.error(error.message);\n    setFailed(error.message);\n}\n\n"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Source/action.ts"],"names":[],"mappings":"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","file":"action.js","sourcesContent":["// Copyright (c) Dolittle. All rights reserved.\n// Licensed under the MIT license. See LICENSE file in the project root for full license information.\n\nimport { getInput, setOutput, setFailed } from '@actions/core';\nimport { getOctokit, context } from '@actions/github';\nimport { Logger } from '@dolittle/github-actions.shared.logging';\n\nimport {\n    CurrentVersionFinder,\n    IFindCurrentVersion,\n    DefinedVersionFinder,\n    SemVerVersionSorter\n} from './Version';\n\nimport { ReleaseTypeExtractor } from './ReleaseType/ReleaseTypeExtractor';\nimport { ContextEstablishers } from './ContextEstablishers';\nimport { CascadingContextEstablisher } from './CascadingBuildContextEstablisher';\nimport { MergedPullRequestContextEstablisher } from './MergedPullRequestContextEstablisher';\nimport { BuildContext } from './BuildContext';\nimport { VersionFromFileVersionFinder } from './Version/VersionFromFileVersionFinder';\nimport { GitHubTagsVersionFetcher } from './Version/GitHubTagsVersionFetcher';\n\nconst logger = new Logger();\n\nrun();\nexport async function run() {\n    try {\n        const token = getInput('token', { required: true });\n        const prereleaseBranches = getInput('prerelease-branches', { required: false })?.split(',').map(_ => _.trim()) ?? [];\n        const currentVersion = getInput('current-version', { required: false }) ?? '';\n        const versionFile = getInput('version-file', { required: false }) ?? '';\n        const environmentBranch = getInput('environment-branch', { required: false });\n\n        logger.info(`Pushes to branches: [master, main, ${prereleaseBranches.join(', ')}] can trigger a release`);\n        const octokit = getOctokit(token);\n        const releaseTypeExtractor = new ReleaseTypeExtractor(logger);\n\n        let currentVersionFinder: IFindCurrentVersion;\n\n        logger.info('Inputs:');\n        logger.info(` prerelease-branches: '${prereleaseBranches}'`);\n        logger.info(` environment-branch: '${environmentBranch}'`);\n        logger.info(` currentVersion: '${currentVersion}'`);\n        logger.info(` versionFile: '${versionFile}'`);\n\n        if (versionFile.length > 0) {\n            logger.info('Using file strategy for finding version');\n            currentVersionFinder = new VersionFromFileVersionFinder(versionFile, logger);\n        } else if (currentVersion.length > 0) {\n            logger.info('Using defined version strategy for finding version');\n            currentVersionFinder = new DefinedVersionFinder(currentVersion);\n        } else {\n            logger.info('Using tag strategy for finding version');\n            currentVersionFinder = new CurrentVersionFinder(\n                new GitHubTagsVersionFetcher(context, octokit, logger),\n                new SemVerVersionSorter(logger),\n                logger);\n        }\n\n        const contextEstablishers = new ContextEstablishers(\n            new CascadingContextEstablisher(currentVersionFinder, logger),\n            new MergedPullRequestContextEstablisher(prereleaseBranches, environmentBranch, releaseTypeExtractor, currentVersionFinder, octokit, logger)\n        );\n        logger.info('Establishing context');\n        const buildContext = await contextEstablishers.establishFrom(context);\n        if (buildContext === undefined) {\n            logger.debug('No establisher found for context');\n            logger.debug(JSON.stringify(context, undefined, 2));\n            outputDefault();\n        }\n        else outputContext(buildContext);\n\n    } catch (error) {\n        fail(error);\n    }\n}\n\nfunction output(\n    shouldPublish: boolean,\n    cascadingRelease: boolean,\n    currentVersion?: string,\n    releaseType?: string,\n    prBody?: string,\n    prUrl?: string) {\n    logger.info('Outputting: ');\n    logger.info(`'should-publish': ${shouldPublish}`);\n    logger.info(`'cascading-release': ${cascadingRelease}`);\n    logger.info(`'current-version': ${currentVersion}`);\n    logger.info(`'release-type': ${releaseType}`);\n    logger.info(`'pr-body': ${prBody}`);\n    logger.info(`'pr-url': ${prUrl}`);\n\n    setOutput('should-publish', shouldPublish);\n    setOutput('cascading-release', cascadingRelease);\n    setOutput('current-version', currentVersion ?? '');\n    setOutput('release-type', releaseType ?? '');\n    setOutput('pr-body', prBody ?? '');\n    setOutput('pr-url', prUrl ?? '');\n}\nfunction outputContext(context: BuildContext) {\n    output(\n        context.shouldPublish,\n        context.cascadingRelease,\n        context.currentVersion,\n        context.releaseType,\n        context.pullRequestBody,\n        context.pullRequestUrl);\n}\n\nfunction outputDefault() {\n    output(false, false);\n}\n\nfunction fail(error: Error) {\n    logger.error(error.message);\n    setFailed(error.message);\n}\n\n"]} /***/ }),