- Clone the repository, and
cd
into it.
git clone git@github.com:forcedotcom/salesforcedx-templates.git
- Ensure you have Yarn installed and run the following to build:
yarn install
yarn build
- We work in
develop
. - Our released (aka. production) branch is
main
. - Our work happens in topic branches (feature and/or bug-fix).
- feature as well as bug-fix branches are based on
develop
- Topic branches can live in forks (external contributors) or within this repository (committers).
** When creating topic branches in this repository please prefix with
<developer-name>/
.
- Topic branches can live in forks (external contributors) or within this repository (committers).
** When creating topic branches in this repository please prefix with
- branches should be kept up-to-date using
rebase
- see below for further merge instructions
- feature as well as bug-fix branches are based on
-
We try to limit merge commits as much as possible.
- They are usually only ok when done by our release automation.
-
Topic branches are:
- based on
develop
and will be - squash-merged into
develop
.
- based on
-
Hot-fix branches are an exception.
- Instead we aim for faster cycles and a generally stable
develop
branch.
- Instead we aim for faster cycles and a generally stable
- When a development cycle finishes, the content of the
develop
branch will become themain
branch
$ git checkout main
$ git reset --hard develop
$
$ # Using a custom commit message for the merge below
$ git merge -m 'Merge -s our (where _ours_ is develop) releasing stream x.y.z.' -s ours origin/main
$ git push origin main
Take a look at CONTRIBUTING doc for making and merging pull requests.
To test plugin locally, use bin/run
in place of sfdx
. For example:
./bin/run force:apex:class:create --classname 'TestClass' --template 'DefaultApexClass' --outputdir ./testsoutput/myApex/
To test plugin locally with Salesforce CLI, add "@salesforce/templates": "file://path/to/packages/templates"
to the plugin's package.json
.
Link your plugin to Salesforce CLI:
sfdx plugins:link .
Verify plugin is linked:
sfdx plugins
We recommend using the Visual Studio Code (VS Code) IDE for your plugin development. Included in the .vscode
directory of this plugin is a launch.json
config file, which allows you to attach a debugger to the node process when running your commands.
To debug the hello:org
command:
- If you linked your plugin to the Salesforce CLI, call your command with the
dev-suspend
switch:
$ sfdx hello:org -u myOrg@example.com --dev-suspend
Alternatively, to call your command using the bin/run
script, set the NODE_OPTIONS
environment variable to --inspect-brk
when starting the debugger:
$ NODE_OPTIONS=--inspect-brk bin/run hello:org -u myOrg@example.com
- Set some breakpoints in your command code.
- Click on the Debug icon in the Activity Bar on the side of VS Code to open up the Debug view.
- In the upper left hand corner of VS Code, verify that the "Attach to Remote" launch configuration is selected.
- Hit the green play button to the left of the "Attach to Remote" launch configuration window. The debugger should now be suspended on the first line of the program.
- Hit the green play button at the top middle of VS Code (this play button is to the right of the play button that you clicked in step #5).
Congrats, you are debugging!
Adding a new template:
- Define a new template type in
TemplateType
, and add available template options extendingTemplateOptions
in library types. - Create a generator extending
SfdxGenerator
in generators folder. Take a look atApexClassGenerator
for an example.
- Generator class file should default export a generator class extending
SfdxGenerator
- Generator class file should have a name same as the template type's name, except with the first letter lowercased
Run the following to test library and plugin:
yarn test
If you are using VS Code for development, the following launch configurations are available: "Run All Tests", "Run Current Test", "Run Current Test Without Compile". Have "debug.javascript.usePreview": true
in your user setting enabled so you can utilize vscode-js-debug
debugger. This setting is enabled by default in VS Code version 1.47.