- handbook
- Company
- Company
- Board
- Communications
- Decision making
- Guides
- KPIs and OKRs
- principles
- Remote Work
- Security
- Asset Management Policy
- Business Continuity & Disaster Recovery Policy
- Information Security Roles and Responsibilities
- Operations Security Policy
- Risk Management Policy
- Third-Party Risk Management Policy
- Human Resources Security Policy
- Access Control Policy
- Incident Response Plan
- Cryptography Policy
- Information Security Policy and Acceptable Use Policy
- Secure Development Policy
- Data Management Policy
- strategy
- values
- Operations
- Product
- Feedback
- Market Segments
- Metrics
- Node-RED Dashboard
- personas
- Pricing Principles
- Principles
- Responsibilities
- Strategy
- Versioning
- Customer department
- Customer
- Customer Success
- Hubspot
- Marketing
- How we work
- Marketing
- Video
- Customer Stories
- Social Media
- Community
- Marketing - Website
- FlowFuse Messaging
- Webinars
- blog
- Lead Generation
- Sales
- Engineering & Design Practices
- Design
- Engineering
- Certified Nodes
- Contributing
- Front End
- Packaging Guidelines
- Platform Ops
- Deployment
- Incident Response
- Observability
- Production Environment
- FlowFuse Dedicated
- Staging Environment
- Project Management
- Releases
- Security Policy
- tools
- Website A/B Testing
- Internal Operations
- People Ops
# Contributing
# Coding Best Practices
# Linting
All code repositories adopt our standard linting rules found in the flowforge/.github repository.
We use StandardJS, with one exception - 4 spaces not 2.
If you're using VSCode, then we recommend using the ESLint extenstion and setting all
for the Eslint › Code Actions On Save: Mode
setting:
In the case of working with vue
or njk
files (found in the frontend and website repositories), then you can add vue
and njk
to the Eslint: Probe
setting in order to enable auto-formatting on save for these file types.
# Editor Config
The website repository uses a .editorconfig
to allow editors to automatically pick up the correct style for that repository. Some editors, like neovim, has this pre-installed. If you're using VSCode, an
plugin
is available.
# Git Best Practices
# Committing
Take care when adding files to a commit. It's easy just to git add -A
(i.e. add all local changes to a commit) but this can result in commits and PRs being clogged with excessive changes that aren't linked to the actual issue/feature at hand.
Take your time when committing files. Review each file carefully and ensure what you're adding to a commit is relevant and necessary.
# Git Commit Messages
- Capitalise the first letter, no trailing dot, 72 chars or less.
- First line should be an imperative/present tense, e.g.
Change
(notChanged
orChanges
) - Do not include the issue number in the first line, this means that commit message are then suitable to include in a changelog as-is.
- Second line should either be blank, or reference to an issue/PR using one of the GitHub recognised keywords, e.g.
closes #...
fixes #...
part of #...
- The remainder should be any further narrative that is needed. Wrapped at 72 chars.
# Branching vs. Forking
Commits must never be pushed directly to main
. Instead, branch or fork from the relevant branch (most likely main
) and work from there.
It is preferred that new work be added on a branch (rather than in a forked repository), although this is not enforced. Branch names should be short, informative, and if directly linked to a single issue number, reference such issue number, e.g. 29-issue-summary
.
Once code is merged, please close any related branches in order to keep the repository tidy.
# Pull Requests
PRs, when opened, should have at least one reviewer assigned, and a consequent review approved, before any merge takes place. If a PR is opened for review/discussion purposes, this PR should be set to draft
state.
When merging a PR, you should choose the "Merge pull request" option. There is no need to rebase or squash the PR commits.
When conducting a PR review, if you are the last (or only) reviewer and all reviews (including your own) are approvals, unless there is a comment from the author stating otherwise, you are free to conduct the merge. Otherwise, leave the merge to the author of the PR, or a future reviewer.
For a comprehensive review of the Pull Request, utilize the designated FlowFuse pre-staging environment. As of the composition of this document, the pre-staging verification is only available for the primary FlowFuse NPM package.
Pre-staging environment is created for each Pull Request created within FlowFuse/flowfuse
repo which includes changes in the source code. Read more in the Test Changes in Staging section.
# Conducting Code Reviews
As part of our commitment to quality, all code changes should be reviewed by at least one other developer before being merged. This is to ensure that the code is of a high standard, and that any potential issues are caught early.
When code is ready to review, developer should open a Pull Request (PR) and assign a reviewer. The reviewer should then review the code, and provide feedback in the form of comments on the PR.
When reviewing code, consider the following:
- Functionality: Has the acceptance criteria on the attached issue been met? Does the code do what it is supposed to do? You must explicitly test the functionality. It is recommended to do so in a staging environment as well as pulling code changes locally and testing on your own machine.
- Test Coverage: Are there tests for the new code introduced? Are the test cases sufficient, and do they cover more than just golden path?
- Documentation: Ensure that supporting documentation has been written, this is especially important for new features and options introduced.
# Test Changes in Staging
For FlowFuse, when changes are merged into the main
branch, they are automatically deployed to the production environment. As such, it is vital a thorough review has been conducted before merging, and that the changes have been tested in a staging environment.
When a pull request includes modifications to the source code, a dedicated pre-staging environment is automatically generated. This pre-staging environment is a complete replica of the staging environment, ensuring that it mirrors the conditions and configurations found in staging. The pre-staging environment serves as a testing ground, allowing developers to thoroughly evaluate their changes before they are merged into the main codebase. This ensures that any issues can be identified and addressed in an isolated setting, maintaining the integrity of the staging environment.
The environment itself will then be available at: https://<pr-number>.flowfuse.dev/
. Information about the pre-staging deployment is sent to gh-pipelines
Slack channel.
Access credentials for the pre-staging environment are located in the FlowFuse 1Password vault.
The FlowFuse application deployed from the Pull Request comes pre-configured. The environment is terminated upon PR merging or closure.
# Custom Pre-Staging Environment
By default, a pre-staging environment is automatically created for each Pull Request made in the flowfuse/flowfuse
repository, containing changes from the related feature branch. However, there are instances where it is necessary to test changes or features made in the dependency packages of flowfuse/flowfuse
. This can be accomplished by triggering a GitHub Actions pipeline to create a pre-staging environment with additional input parameters.
To create a customized pre-staging environment, please follow the steps below:
- Push the changes you want to test to the feature branch of the specific package's repository, ie.
nr-project-nodes
. - In the
flowfuse/flowfuse
repository, create a new feature branch. Use this branch to make any necessary changes that depend on the updated package from step 1, if applicable. - Create a Pull Request for the changes in the
flowfuse/flowfuse
repository. - Navigate to the Create pre-staging environment workflow page in the Actions tab of the
flowfuse/flowfuse
repository. - On the right side, click the
Run workflow
button. - Complete the
Pull request number
field and the dependent package feature branch name.
- Click the
Run workflow
button and wait for the results. A Slack notification will be sent to thegh-pipelines
channel with the link to the pre-staging environment.