UNPKG

projen

Version:

CDK for software projects

361 lines • 66.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Release = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const path = require("path"); const publisher_1 = require("./publisher"); const release_trigger_1 = require("./release-trigger"); const consts_1 = require("../build/private/consts"); const component_1 = require("../component"); const github_1 = require("../github"); const constants_1 = require("../github/constants"); const util_1 = require("../github/private/util"); const workflows_model_1 = require("../github/workflows-model"); const runner_options_1 = require("../runner-options"); const util_2 = require("../util"); const name_1 = require("../util/name"); const path_1 = require("../util/path"); const version_1 = require("../version"); const BUILD_JOBID = "release"; const GIT_REMOTE_STEPID = "git_remote"; const TAG_EXISTS_STEPID = "check_tag_exists"; const LATEST_COMMIT_OUTPUT = "latest_commit"; const TAG_EXISTS_OUTPUT = "tag_exists"; /** * Conditional (Github Workflow Job `if`) to check if a release job should be run. */ const DEPENDENT_JOB_CONDITIONAL = `needs.${BUILD_JOBID}.outputs.${TAG_EXISTS_OUTPUT} != 'true' && needs.${BUILD_JOBID}.outputs.${LATEST_COMMIT_OUTPUT} == github.sha`; /** * Manages releases (currently through GitHub workflows). * * By default, no branches are released. To add branches, call `addBranch()`. */ class Release extends component_1.Component { /** * Returns the `Release` component of a project or `undefined` if the project * does not have a Release component. */ static of(project) { const isRelease = (c) => c instanceof Release; return project.components.find(isRelease); } /** * @param scope should be part of the project the Release belongs to. * @param options options to configure the Release Component. */ constructor(scope, options) { super(scope); this._branches = new Array(); this.jobs = {}; if (Array.isArray(options.releaseBranches)) { throw new Error('"releaseBranches" is no longer an array. See type annotations'); } this.github = github_1.GitHub.of(this.project.root); this.buildTask = options.task; this.preBuildSteps = options.releaseWorkflowSetupSteps ?? []; this.postBuildSteps = options.postBuildSteps ?? []; this.artifactsDirectory = options.artifactsDirectory ?? consts_1.DEFAULT_ARTIFACTS_DIRECTORY; (0, util_1.ensureNotHiddenPath)(this.artifactsDirectory, "artifactsDirectory"); this.versionFile = options.versionFile; this.releaseTrigger = options.releaseTrigger ?? release_trigger_1.ReleaseTrigger.continuous(); this.containerImage = options.workflowContainerImage; this.workflowRunsOn = options.workflowRunsOn; this.workflowRunsOnGroup = options.workflowRunsOnGroup; this.workflowPermissions = { contents: workflows_model_1.JobPermission.WRITE, ...options.workflowPermissions, }; this._branchHooks = []; /** * Use manual releases with no changelog if releaseEveryCommit is explicitly * disabled and no other trigger is set. * * TODO: Remove this when releaseEveryCommit and releaseSchedule are removed */ if (!((options.releaseEveryCommit ?? true) || options.releaseSchedule || options.releaseTrigger)) { this.releaseTrigger = release_trigger_1.ReleaseTrigger.manual({ changelog: false }); } if (options.releaseSchedule) { this.releaseTrigger = release_trigger_1.ReleaseTrigger.scheduled({ schedule: options.releaseSchedule, }); } this.version = new version_1.Version(this.project, { versionInputFile: this.versionFile, artifactsDirectory: this.artifactsDirectory, versionrcOptions: options.versionrcOptions, tagPrefix: options.releaseTagPrefix, releasableCommits: options.releasableCommits, bumpPackage: options.bumpPackage, nextVersionCommand: options.nextVersionCommand, }); this.releaseTagFilePath = path.posix.normalize(path.posix.join(this.artifactsDirectory, this.version.releaseTagFileName)); this.publisher = new publisher_1.Publisher(this.project, { artifactName: this.artifactsDirectory, condition: DEPENDENT_JOB_CONDITIONAL, buildJobId: BUILD_JOBID, jsiiReleaseVersion: options.jsiiReleaseVersion, failureIssue: options.releaseFailureIssue, failureIssueLabel: options.releaseFailureIssueLabel, ...(0, runner_options_1.filteredWorkflowRunsOnOptions)(options.workflowRunsOn, options.workflowRunsOnGroup), publishTasks: options.publishTasks, dryRun: options.publishDryRun, workflowNodeVersion: options.workflowNodeVersion, workflowContainerImage: options.workflowContainerImage, }); const githubRelease = options.githubRelease ?? true; if (githubRelease) { this.publisher.publishToGitHubReleases({ changelogFile: path.posix.join(this.artifactsDirectory, this.version.changelogFileName), versionFile: path.posix.join(this.artifactsDirectory, this.version.versionFileName), releaseTagFile: path.posix.join(this.artifactsDirectory, this.version.releaseTagFileName), }); } // add the default branch (we need the internal method which does not require majorVersion) this.defaultBranch = this._addBranch(options.branch, { prerelease: options.prerelease, majorVersion: options.majorVersion, minMajorVersion: options.minMajorVersion, workflowName: options.releaseWorkflowName ?? (0, name_1.workflowNameForProject)("release", this.project), tagPrefix: options.releaseTagPrefix, npmDistTag: options.npmDistTag, }); for (const [name, opts] of Object.entries(options.releaseBranches ?? {})) { this.addBranch(name, opts); } } /** * Add a hook that should be run for every branch (including those that will * be added by future `addBranch` calls). * @internal */ _forEachBranch(hook) { for (const branch of this._branches) { hook(branch.name); } this._branchHooks.push(hook); } /** * Adds a release branch. * * It is a git branch from which releases are published. If a project has more than one release * branch, we require that `majorVersion` is also specified for the primary branch in order to * ensure branches always release the correct version. * * @param branch The branch to monitor (e.g. `main`, `v2.x`) * @param options Branch definition */ addBranch(branch, options) { this._addBranch(branch, options); // run all branch hooks for (const hook of this._branchHooks) { hook(branch); } } /** * Adds a release branch. * * It is a git branch from which releases are published. If a project has more than one release * branch, we require that `majorVersion` is also specified for the primary branch in order to * ensure branches always release the correct version. * * @param branch The branch to monitor (e.g. `main`, `v2.x`) * @param options Branch definition */ _addBranch(branch, options) { if (this._branches.find((b) => b.name === branch)) { throw new Error(`The release branch ${branch} is already defined`); } // if we add a branch, we require that the default branch will also define a // major version. if (this.defaultBranch && options.majorVersion && this.defaultBranch.majorVersion === undefined) { throw new Error('you must specify "majorVersion" for the default branch when adding multiple release branches'); } const releaseBranch = { name: branch, ...options, workflow: this.createWorkflow(branch, options), }; this._branches.push(releaseBranch); return releaseBranch; } preSynthesize() { for (const branch of this._branches) { if (!branch.workflow) { continue; } branch.workflow.addJobs(this.publisher._renderJobsForBranch(branch.name, branch)); branch.workflow.addJobs(this.jobs); } } /** * Adds jobs to all release workflows. * @param jobs The jobs to add (name => job) */ addJobs(jobs) { for (const [name, job] of Object.entries(jobs)) { this.jobs[name] = job; } } /** * Retrieve all release branch names */ get branches() { return this._branches.map((b) => b.name); } /** * @returns a workflow or `undefined` if github integration is disabled. */ createWorkflow(branchName, branch) { const workflowName = branch.workflowName ?? (0, name_1.workflowNameForProject)(`release-${branchName}`, this.project); // to avoid race conditions between two commits trying to release the same // version, we check if the head sha is identical to the remote sha. if // not, we will skip the release and just finish the build. const noNewCommits = `\${{ steps.${GIT_REMOTE_STEPID}.outputs.${LATEST_COMMIT_OUTPUT} == github.sha }}`; // The arrays are being cloned to avoid accumulating values from previous branches const preBuildSteps = [...this.preBuildSteps]; const env = { RELEASE: "true", ...this.version.envForBranch({ majorVersion: branch.majorVersion, minorVersion: branch.minorVersion, minMajorVersion: branch.minMajorVersion, prerelease: branch.prerelease, tagPrefix: branch.tagPrefix, }), }; // the "release" task prepares a release but does not publish anything. the // output of the release task is: `dist`, `.version.txt`, and // `.changelog.md`. this is what publish tasks expect. // if this is the release for "main" or "master", just call it "release". // otherwise, "release:BRANCH" const releaseTaskName = branchName === "main" || branchName === "master" ? "release" : `release:${branchName}`; const releaseTask = this.project.addTask(releaseTaskName, { description: `Prepare a release from "${branchName}" branch`, env, }); releaseTask.exec(`rm -fr ${this.artifactsDirectory}`); releaseTask.spawn(this.version.bumpTask); releaseTask.spawn(this.buildTask); releaseTask.spawn(this.version.unbumpTask); // anti-tamper check (fails if there were changes to committed files) // this will identify any non-committed files generated during build (e.g. test snapshots) releaseTask.exec(Release.ANTI_TAMPER_CMD); if (this.releaseTrigger.isManual) { const publishTask = this.publisher.publishToGit({ changelogFile: path.posix.join(this.artifactsDirectory, this.version.changelogFileName), versionFile: path.posix.join(this.artifactsDirectory, this.version.versionFileName), releaseTagFile: path.posix.join(this.artifactsDirectory, this.version.releaseTagFileName), projectChangelogFile: this.releaseTrigger.changelogPath, gitBranch: branchName, gitPushCommand: this.releaseTrigger.gitPushCommand, }); releaseTask.spawn(publishTask); } const postBuildSteps = [...this.postBuildSteps]; // Read the releasetag, then check if it already exists. // If it does, we will cancel this release postBuildSteps.push(github_1.WorkflowSteps.tagExists(`$(cat ${this.releaseTagFilePath})`, { name: "Check if version has already been tagged", id: TAG_EXISTS_STEPID, })); // check if new commits were pushed to the repo while we were building. // if new commits have been pushed, we will cancel this release postBuildSteps.push({ name: "Check for new commits", id: GIT_REMOTE_STEPID, run: [ `echo "${LATEST_COMMIT_OUTPUT}=$(git ls-remote origin -h \${{ github.ref }} | cut -f1)" >> $GITHUB_OUTPUT`, "cat $GITHUB_OUTPUT", ].join("\n"), }); const projectPathRelativeToRoot = path.relative(this.project.root.outdir, this.project.outdir); const normalizedProjectPathRelativeToRoot = (0, util_2.normalizePersistedPath)(projectPathRelativeToRoot); postBuildSteps.push({ name: "Backup artifact permissions", if: noNewCommits, continueOnError: true, run: `cd ${this.artifactsDirectory} && getfacl -R . > ${constants_1.PERMISSION_BACKUP_FILE}`, }, github_1.WorkflowSteps.uploadArtifact({ if: noNewCommits, with: { name: constants_1.BUILD_ARTIFACT_NAME, path: normalizedProjectPathRelativeToRoot.length > 0 ? `${normalizedProjectPathRelativeToRoot}/${this.artifactsDirectory}` : this.artifactsDirectory, }, })); if (this.github && !this.releaseTrigger.isManual) { // Use target (possible parent) GitHub to create the workflow const workflow = new github_1.GithubWorkflow(this.github, workflowName, { // see https://github.com/projen/projen/issues/3761 limitConcurrency: true, }); workflow.on({ schedule: this.releaseTrigger.schedule ? [{ cron: this.releaseTrigger.schedule }] : undefined, push: this.releaseTrigger.isContinuous ? { branches: [branchName], paths: this.releaseTrigger.paths } : undefined, workflowDispatch: {}, // allow manual triggering }); // Create job based on child (only?) project GitHub const taskjob = new github_1.TaskWorkflowJob(this, releaseTask, { outputs: { [LATEST_COMMIT_OUTPUT]: { stepId: GIT_REMOTE_STEPID, outputName: LATEST_COMMIT_OUTPUT, }, [TAG_EXISTS_OUTPUT]: { stepId: TAG_EXISTS_STEPID, outputName: "exists", }, }, container: this.containerImage ? { image: this.containerImage } : undefined, env: { CI: "true", }, permissions: this.workflowPermissions, checkoutWith: { // fetch-depth= indicates all history for all branches and tags // we must use this in order to fetch all tags // and to inspect the history to decide if we should release fetchDepth: 0, }, preBuildSteps, postBuildSteps, jobDefaults: normalizedProjectPathRelativeToRoot.length > 0 // is subproject ? { run: { workingDirectory: (0, path_1.ensureRelativePathStartsWithDot)(normalizedProjectPathRelativeToRoot), }, } : undefined, ...(0, runner_options_1.filteredRunsOnOptions)(this.workflowRunsOn, this.workflowRunsOnGroup), }); workflow.addJob(BUILD_JOBID, taskjob); return workflow; } else { return undefined; } } } exports.Release = Release; _a = JSII_RTTI_SYMBOL_1; Release[_a] = { fqn: "projen.release.Release", version: "0.93.0" }; Release.ANTI_TAMPER_CMD = "git diff --ignore-space-at-eol --exit-code"; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"release.js","sourceRoot":"","sources":["../../src/release/release.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from \"path\";\nimport { IConstruct } from \"constructs\";\nimport { Publisher } from \"./publisher\";\nimport { ReleaseTrigger } from \"./release-trigger\";\nimport { DEFAULT_ARTIFACTS_DIRECTORY } from \"../build/private/consts\";\nimport { Component } from \"../component\";\nimport {\n  GitHub,\n  GithubWorkflow,\n  TaskWorkflowJob,\n  WorkflowSteps,\n} from \"../github\";\nimport {\n  BUILD_ARTIFACT_NAME,\n  PERMISSION_BACKUP_FILE,\n} from \"../github/constants\";\nimport { ensureNotHiddenPath } from \"../github/private/util\";\nimport {\n  Job,\n  JobPermission,\n  JobPermissions,\n  JobStep,\n} from \"../github/workflows-model\";\nimport { Project } from \"../project\";\nimport {\n  GroupRunnerOptions,\n  filteredRunsOnOptions,\n  filteredWorkflowRunsOnOptions,\n} from \"../runner-options\";\nimport { Task } from \"../task\";\nimport { normalizePersistedPath } from \"../util\";\nimport { workflowNameForProject } from \"../util/name\";\nimport { ensureRelativePathStartsWithDot } from \"../util/path\";\nimport { ReleasableCommits, Version } from \"../version\";\n\nconst BUILD_JOBID = \"release\";\nconst GIT_REMOTE_STEPID = \"git_remote\";\nconst TAG_EXISTS_STEPID = \"check_tag_exists\";\n\nconst LATEST_COMMIT_OUTPUT = \"latest_commit\";\nconst TAG_EXISTS_OUTPUT = \"tag_exists\";\n\n/**\n * Conditional (Github Workflow Job `if`) to check if a release job should be run.\n */\nconst DEPENDENT_JOB_CONDITIONAL = `needs.${BUILD_JOBID}.outputs.${TAG_EXISTS_OUTPUT} != 'true' && needs.${BUILD_JOBID}.outputs.${LATEST_COMMIT_OUTPUT} == github.sha`;\n\ntype BranchHook = (branch: string) => void;\n\n/**\n * Project options for release.\n */\nexport interface ReleaseProjectOptions {\n  /**\n   * Automatically release new versions every commit to one of branches in `releaseBranches`.\n   *\n   * @default true\n   *\n   * @deprecated Use `releaseTrigger: ReleaseTrigger.continuous()` instead\n   */\n  readonly releaseEveryCommit?: boolean;\n\n  /**\n   * CRON schedule to trigger new releases.\n   *\n   * @default - no scheduled releases\n   *\n   * @deprecated Use `releaseTrigger: ReleaseTrigger.scheduled()` instead\n   */\n  readonly releaseSchedule?: string;\n\n  /**\n   * The release trigger to use.\n   *\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   */\n  readonly releaseTrigger?: ReleaseTrigger;\n\n  /**\n   * A set of workflow steps to execute in order to setup the workflow\n   * container.\n   */\n  readonly releaseWorkflowSetupSteps?: JobStep[];\n\n  /**\n   * Container image to use for GitHub workflows.\n   *\n   * @default - default image\n   */\n  readonly workflowContainerImage?: string;\n\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   */\n  readonly jsiiReleaseVersion?: string;\n\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   */\n  readonly postBuildSteps?: JobStep[];\n\n  /**\n   * Major version to release from the default branch.\n   *\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   *\n   * @default - Major version is not enforced.\n   */\n  readonly majorVersion?: number;\n\n  /**\n   * Minimal Major version to release\n   *\n   *\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   *\n   * @default - No minimum version is being enforced\n   */\n  readonly minMajorVersion?: number;\n\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\",\n   * \"alpha\", \"pre\").\n   *\n   * @default - normal semantic versions\n   */\n  readonly prerelease?: string;\n\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   *\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   *\n   * @default \"latest\"\n   */\n  readonly npmDistTag?: string;\n\n  /**\n   * The name of the default release workflow.\n   *\n   * @default \"release\"\n   */\n  readonly releaseWorkflowName?: string;\n\n  /**\n   * Defines additional release branches. A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   *\n   * @default - no additional branches are used for release. you can use\n   * `addBranch()` to add additional branches.\n   */\n  readonly releaseBranches?: { [name: string]: BranchOptions };\n\n  /**\n   * Create a github issue on every failed publishing task.\n   *\n   * @default false\n   */\n  readonly releaseFailureIssue?: boolean;\n\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   *\n   * @default \"failed-release\"\n   */\n  readonly releaseFailureIssueLabel?: string;\n\n  /**\n   * Automatically add the given prefix to release tags.\n   * Useful if you are releasing on multiple branches with overlapping\n   * version numbers.\n   *\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   *\n   * @default \"v\"\n   */\n  readonly releaseTagPrefix?: string;\n\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   *\n   * @default - standard configuration applicable for GitHub repositories\n   */\n  readonly versionrcOptions?: Record<string, any>;\n\n  /**\n   * Github Runner selection labels\n   * @default [\"ubuntu-latest\"]\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: string[];\n\n  /**\n   * Github Runner Group selection options\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   *\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   *\n   * @default false\n   */\n  readonly publishTasks?: boolean;\n\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   *\n   * @default false\n   */\n  readonly publishDryRun?: boolean;\n\n  /**\n   * Find commits that should be considered releasable\n   * Used to decide if a release is required.\n   *\n   * @default ReleasableCommits.everyCommit()\n   */\n  readonly releasableCommits?: ReleasableCommits;\n\n  /**\n   * The `commit-and-tag-version` compatible package used to bump the package version, as a dependency string.\n   *\n   * This can be any compatible package version, including the deprecated `standard-version@9`.\n   *\n   * @default - A recent version of \"commit-and-tag-version\"\n   */\n  readonly bumpPackage?: string;\n\n  /**\n   * A shell command to control the next version to release.\n   *\n   * If present, this shell command will be run before the bump is executed, and\n   * it determines what version to release. It will be executed in the following\n   * environment:\n   *\n   * - Working directory: the project directory.\n   * - `$VERSION`: the current version. Looks like `1.2.3`.\n   * - `$LATEST_TAG`: the most recent tag. Looks like `prefix-v1.2.3`, or may be unset.\n   * - `$SUGGESTED_BUMP`: the suggested bump action based on commits. One of `major|minor|patch|none`.\n   *\n   * The command should print one of the following to `stdout`:\n   *\n   * - Nothing: the next version number will be determined based on commit history.\n   * - `x.y.z`: the next version number will be `x.y.z`.\n   * - `major|minor|patch`: the next version number will be the current version number\n   *   with the indicated component bumped.\n   *\n   * This setting cannot be specified together with `minMajorVersion`; the invoked\n   * script can be used to achieve the effects of `minMajorVersion`.\n   *\n   * @default - The next version will be determined based on the commit history and project settings.\n   */\n  readonly nextVersionCommand?: string;\n}\n\n/**\n * Options for `Release`.\n */\nexport interface ReleaseOptions extends ReleaseProjectOptions {\n  /**\n   * The task to execute in order to create the release artifacts. Artifacts are\n   * expected to reside under `artifactsDirectory` (defaults to `dist/`) once\n   * build is complete.\n   */\n  readonly task: Task;\n\n  /**\n   * A name of a .json file to set the `version` field in after a bump.\n   *\n   * @example \"package.json\"\n   */\n  readonly versionFile: string;\n\n  /**\n   * The default branch name to release from.\n   *\n   * Use `majorVersion` to restrict this branch to only publish releases with a\n   * specific major version.\n   *\n   * You can add additional branches using `addBranch()`.\n   */\n  readonly branch: string;\n\n  /**\n   * Create a GitHub release for each release.\n   *\n   * @default true\n   */\n  readonly githubRelease?: boolean;\n\n  /**\n   * A directory which will contain build artifacts.\n   *\n   * @default \"dist\"\n   */\n  readonly artifactsDirectory: string;\n\n  /**\n   * Node version to setup in GitHub workflows if any node-based CLI utilities\n   * are needed. For example `publib`, the CLI projen uses to publish releases,\n   * is an npm library.\n   *\n   * @default \"lts/*\"\"\n   */\n  readonly workflowNodeVersion?: string;\n\n  /**\n   * Permissions granted to the release workflow job\n   * @default `{ contents: JobPermission.WRITE }`\n   */\n  readonly workflowPermissions?: JobPermissions;\n}\n\n/**\n * Manages releases (currently through GitHub workflows).\n *\n * By default, no branches are released. To add branches, call `addBranch()`.\n */\nexport class Release extends Component {\n  public static readonly ANTI_TAMPER_CMD =\n    \"git diff --ignore-space-at-eol --exit-code\";\n\n  /**\n   * Returns the `Release` component of a project or `undefined` if the project\n   * does not have a Release component.\n   */\n  public static of(project: Project): Release | undefined {\n    const isRelease = (c: Component): c is Release => c instanceof Release;\n    return project.components.find(isRelease);\n  }\n\n  /**\n   * Package publisher.\n   */\n  public readonly publisher: Publisher;\n\n  /**\n   * Location of build artifacts.\n   */\n  public readonly artifactsDirectory: string;\n\n  private readonly buildTask: Task;\n  private readonly version: Version;\n  private readonly postBuildSteps: JobStep[];\n  private readonly versionFile: string;\n  private readonly releaseTrigger: ReleaseTrigger;\n  private readonly preBuildSteps: JobStep[];\n  private readonly containerImage?: string;\n  private readonly _branches = new Array<ReleaseBranch>();\n  private readonly jobs: Record<string, Job> = {};\n  private readonly defaultBranch: ReleaseBranch;\n  private readonly github?: GitHub;\n  private readonly workflowRunsOn?: string[];\n  private readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  private readonly workflowPermissions: JobPermissions;\n  private readonly releaseTagFilePath: string;\n  private readonly _branchHooks: BranchHook[];\n\n  /**\n   * @param scope should be part of the project the Release belongs to.\n   * @param options options to configure the Release Component.\n   */\n  constructor(scope: IConstruct, options: ReleaseOptions) {\n    super(scope);\n\n    if (Array.isArray(options.releaseBranches)) {\n      throw new Error(\n        '\"releaseBranches\" is no longer an array. See type annotations'\n      );\n    }\n\n    this.github = GitHub.of(this.project.root);\n    this.buildTask = options.task;\n    this.preBuildSteps = options.releaseWorkflowSetupSteps ?? [];\n    this.postBuildSteps = options.postBuildSteps ?? [];\n    this.artifactsDirectory =\n      options.artifactsDirectory ?? DEFAULT_ARTIFACTS_DIRECTORY;\n    ensureNotHiddenPath(this.artifactsDirectory, \"artifactsDirectory\");\n    this.versionFile = options.versionFile;\n    this.releaseTrigger = options.releaseTrigger ?? ReleaseTrigger.continuous();\n    this.containerImage = options.workflowContainerImage;\n    this.workflowRunsOn = options.workflowRunsOn;\n    this.workflowRunsOnGroup = options.workflowRunsOnGroup;\n    this.workflowPermissions = {\n      contents: JobPermission.WRITE,\n      ...options.workflowPermissions,\n    };\n    this._branchHooks = [];\n\n    /**\n     * Use manual releases with no changelog if releaseEveryCommit is explicitly\n     * disabled and no other trigger is set.\n     *\n     * TODO: Remove this when releaseEveryCommit and releaseSchedule are removed\n     */\n    if (\n      !(\n        (options.releaseEveryCommit ?? true) ||\n        options.releaseSchedule ||\n        options.releaseTrigger\n      )\n    ) {\n      this.releaseTrigger = ReleaseTrigger.manual({ changelog: false });\n    }\n\n    if (options.releaseSchedule) {\n      this.releaseTrigger = ReleaseTrigger.scheduled({\n        schedule: options.releaseSchedule,\n      });\n    }\n\n    this.version = new Version(this.project, {\n      versionInputFile: this.versionFile,\n      artifactsDirectory: this.artifactsDirectory,\n      versionrcOptions: options.versionrcOptions,\n      tagPrefix: options.releaseTagPrefix,\n      releasableCommits: options.releasableCommits,\n      bumpPackage: options.bumpPackage,\n      nextVersionCommand: options.nextVersionCommand,\n    });\n\n    this.releaseTagFilePath = path.posix.normalize(\n      path.posix.join(this.artifactsDirectory, this.version.releaseTagFileName)\n    );\n\n    this.publisher = new Publisher(this.project, {\n      artifactName: this.artifactsDirectory,\n      condition: DEPENDENT_JOB_CONDITIONAL,\n      buildJobId: BUILD_JOBID,\n      jsiiReleaseVersion: options.jsiiReleaseVersion,\n      failureIssue: options.releaseFailureIssue,\n      failureIssueLabel: options.releaseFailureIssueLabel,\n      ...filteredWorkflowRunsOnOptions(\n        options.workflowRunsOn,\n        options.workflowRunsOnGroup\n      ),\n      publishTasks: options.publishTasks,\n      dryRun: options.publishDryRun,\n      workflowNodeVersion: options.workflowNodeVersion,\n      workflowContainerImage: options.workflowContainerImage,\n    });\n\n    const githubRelease = options