hardis
version:promote
Description
Command Behavior
Promotes a Salesforce package version from beta to released status in your Dev Hub.
This command is a critical step in the package development lifecycle, marking a package version as stable and ready for production use. Once promoted, a package version can be installed in production organizations.
Key functionalities:
- Package Version Selection: Allows you to select a specific package version to promote. If the
--autoflag is used, it automatically identifies package versions that are not yet released and promotes them. - Automated Promotion: When
--autois enabled, it queries for all unreleased package versions and promotes them without further user interaction. - Dev Hub Integration: Interacts with your connected Dev Hub to change the status of the package version.
Technical explanations
The command's technical implementation involves:
- Package Alias Retrieval: It retrieves package aliases from your
sfdx-project.jsonto identify available packages. - Automated Promotion Logic: If
--autois used, it executessf package version list --releasedto get a list of already released packages and then filters the available package aliases to find those that are not yet released. - Interactive Prompts: If not in auto mode, it uses the
promptslibrary to allow the user to select a package version to promote. - Salesforce CLI Integration: It constructs and executes the
sf package version promotecommand, passing the package version ID. execSfdxJson: This utility is used to execute the Salesforce CLI command and capture its JSON output.- Error Handling: It handles cases where a package version might already be promoted or if other errors occur during the promotion process.
Parameters
| Name | Type | Description | Default | Required | Options |
|---|---|---|---|---|---|
| auto -f |
boolean | Auto-detect which versions of which packages need to be promoted | |||
| debug -d |
boolean | Activate debug mode (more logs) | |||
| flags-dir | option | undefined | |||
| json | boolean | Format output as json. | |||
| skipauth | boolean | Skip authentication check when a default username is required | |||
| target-dev-hub -v |
option | undefined | |||
| websocket | option | Websocket host:port for VsCode SFDX Hardis UI integration |
Examples
$ sf hardis:package:version:promote
$ sf hardis:package:version:promote --auto