Skip to content

Latest commit

 

History

History
50 lines (33 loc) · 2 KB

DEVELOPING.md

File metadata and controls

50 lines (33 loc) · 2 KB

Pre-requisites

  1. We use the active NodeJS LTS. If you need to work with multiple versions of Node, you might consider using nvm.
  2. This repository uses yarn to manage node dependencies. Please install yarn globally using npm install --global yarn.
  3. Tests are executed on the latest NodeJS as well as all active and maintained NodeJS LTS versions.

Typical workflow

You would only do this once after you cloned the repository.

  1. Clone this repository from git.
  2. cd into sfdx-core.
  3. We develop using feature brances off main and release from the main branch. At this point, you should run git checkout -t origin/main.
  4. yarn to bring in all the top-level dependencies.
  5. Open the project in your editor of choice.

When you are ready to commit

  1. We enforce commit message format. We recommend using commitizen by installing it with yarn global add commitizen then commit using git cz which will prompt you questions to format the commit message.
  2. Before commit and push, husky will run several hooks to ensure the message and that everything lints and compiles properly.

List of Useful commands

yarn compile

This compiles the typescript to javascript.

yarn clean

This cleans all generated files and directories. Run yarn clean-all to also clean up the node_module directories.

yarn test

This tests the typescript using ts-node.

yarn docs

This generates documentation into docs.

yarn lint

This lints all the typescript. If there are no errors/warnings from tslint, then you get clean output. But, if there are errors from tslint, you will see a long error that can be confusing – just focus on the tslint errors. The results of this are deeper than what the tslint extension in VS Code does because of semantic lint rules which requires a tsconfig.json to be passed to tslint.