First off, thanks for taking the time to contribute! 🎉👍
These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.
This project is opinionated and follows patterns and practices used by the team at Very Good Ventures.
This is a mono repo, a repository that includes more than one individual project. In fact, the Dart Frog repository includes all the packages, example apps, CLIs, and IDE integration plugins that have a role in the Dart Frog developer experience.
The contents of the mono repo is divided into the following directories:
tool/
: contains internal operation scriptsassets/
: images to embed into READMEsdocs/
: source code for the docs site.examples/
: example projects of some of the several usages of Dart Frogextensions/
: Integrations with IDEs such as VS Code.bricks/
: Internal mason bricks used by dart_frog_cli to perform tasks such as creating new projects, starting a dev server, and building a prod server.packages/
: The source code of the packages that constitute the Dart Frog suite (dart_frog_cli
,dart_frog
anddart_frog_gen
) as well as companion packages (such asdart_frog_web_socket
).
Some of the included projects have more specific instructions on contribution. In these cases, the project root may include a CONTRIBUTING.md
file with such instructions.
If you intend to change the public API or make any non-trivial changes to the implementation, we recommend filing an issue. This lets us reach an agreement on your proposal before you put significant effort into it.
If you’re only fixing a bug, it’s fine to submit a pull request right away but we still recommend to filing an issue detailing what you’re fixing. This is helpful in case we don’t accept that specific fix but want to keep track of the issue. Please use the built-in Bug Report template and provide as much information as possible including detailed reproduction steps. Once one of the package maintainers has reviewed the issue and an agreement is reached regarding the fix, a pull request can be created.
Before creating a pull request please:
- Fork the repository and create your branch from
main
. - Install all dependencies (
dart pub get
). - Squash your commits and ensure you have a meaningful, semantic commit message.
- Add tests! Pull Requests without 100% test coverage will not be approved.
- Ensure the existing test suite passes locally.
- Format your code (
dart format .
). - Analyze your code (
dart analyze --fatal-infos --fatal-warnings .
). - Create the Pull Request.
- Verify that all status checks are passing.
While the prerequisites above must be satisfied prior to having your pull request reviewed, the reviewer(s) may ask you to complete additional work, tests, or other changes before your pull request can be ultimately accepted.
Prerequisites:
- Install a valid Dart SDK in your local environment, it should be compatible with the latest version of Dart Frog CLI. If you have Flutter installed, you likely have a valid Dart SDK version already installed.
- Mason CLI (to run and test the
bricks
); - Node.js, for working with the VS Code extension or the documentation website. Refer to their CONTRIBUTING files for further installation requirements.
- Capability to run shell scripts (for the scripts under
tool/
).
This is the user-facing package of the Dart Frog SDK, which means that Dart Frog users will be using its API to construct servers and runtime operations. It contains logic for request parsing, middleware, and response creation.
This is the internal package used by the Dart Frog tooling to interpret the file disposition and from it construct a Dart Frog server.
⚠️ Warning: this package is a dependency on the bricks bundled into the CLI. This means that any changes that break the bricks should be released with a major version, otherwise dart frog users may be blocked from performing tasks such asdev
,build
, andnew
.
A Dart command line interface package that serves as the main tool for Dart Frog. It includes bundled versions of the bricks under bricks/
. To sync the source code of the bricks with new bundles, run tool/generate_bundles.sh
.
The other items under packages/
are companion packages in which dart_frog users may include on their project for specific server-side capabilities, such as auth (dart_frog_auth
) and WebSockets (dart_frog_web_socket
)
Before starting the release process of an individual package, first check:
- If your local
main
branch is up to date:
# ☁️ Ensure you're up to date with the GitHub remote
git checkout main
git fetch
git status
-
Ensure the GitHub pipeline is green (has passed successfully) for your given package.
-
Run the script under
tool/release_ready.sh
within the package root repository and the desired new version.
# 🚀 Run the release ready script (from packages/<package>)
../../tool/release_ready.sh <version>
The above example will: update the version of <package>
to <version>
, update the dart_frog CHANGELOG.md, create and checkout to a local release branch.
-
Review the recently updated CHANGELOG file. You should manually amend the content were necessary. For example, by removing the redundant scope of some semantic pull requests or removing superfluous or unrelated logged changes.
-
Commit, push and open a pull request from the new release branch.
-
Once merged, create a release on GitHub. The publish workflow should take care of publishing the new version on the appropriate package manager.
-
Open follow-up pull requests updating this package usage in any other Dart Frog package that depends on this new release.