Skip to content

Latest commit

 

History

History
117 lines (81 loc) · 6.93 KB

CONTRIBUTING.md

File metadata and controls

117 lines (81 loc) · 6.93 KB

Contributing

We would love for you to contribute to KoliBriand help make it even better than it is today! As a contributor, we ask that you follow the following guidelines:

Code of Conduct

Help us keep KoliBri open and inclusive. Please read and follow our Code of Conduct.

Questions and problems

Please do not create issue tickets for general support questions. We want to use the ticket system for tracking bug reports and feature requests.

Instead, we recommend first checking Stack Overflow to see whether someone else has already solved the question or problem. You can also create new questions with the tag “hummingbird”. To save your time and ours, we will close all general questions in the ticket system and redirect those asking to Stack Overflow.

If you would like to contact us, please send us an email to kolibri@itzbund.de.

Report an error

If you find an error in the source code, you can report it to our ticket system.

It would be even better if you suggested a solution to us as a pull request.

Further development

You can request new features by submitting an issue to our ticket system. If you would like to implement a new function, please note the following steps for further action:

  • It is helpful to read the KoliBri architecture concept before implementing.
  • For major innovations, please create a ticket with the description of the new function.
  • For small innovations, you can offer and justify the implementation directly as a pull request.

Git flow

We work according to the Git flow: https://medium.com/android-news/gitflow-with-github-c675aa4f606a

Developing

  1. For contributing, you need a GitHub account
  2. Fork our repository on GitHub
  3. Open your preferred command line interface
  4. Clone the forked repository to your local machine
  5. Navigate the project root directory
  6. Create a new branch for your changes
  7. Install PNPM on you local machine
  8. Install all packages with pnpm i
  9. Build all packages within the mono repository pnpm -r build
  10. Navigate to the desired package in our monorepo
  11. When you want to start the project navigate to packages/components/ and run pnpm dev
  12. To watch for changes navigate to packages/samples/react/ and execute pnpm start. http://localhost:8080/ will open automatically

Develop new component

Refer to new component tutorial.

Switching between branches

When changing the current working branch, it is important to reinstall all dependencies, as these may have changed. It is very important that all packages are built when working on dependents. This is because the packages always use the built state of the referenced packages in the mono repo. To avoid unexpected problems, it is therefore always advisable to build all packages once. This can be done with these steps:

  • Reinstall all dependencies: pnpm i
  • Build all packages: pnpm -r build
  • You can then switch to the package to be processed and start it with pnpm start.

If it is also necessary to edit dependent packages such as @public-ui/components, these must be rebuilt for each change. Such packages offer the dev script for this purpose. This automatically rebuilds the package after each change.

Back porting to older Major-Versions

By default, development is carried out in the development branch for the following version. However, if it becomes necessary to provide an issue for an older major release, such as version 1.x.x, the code change must also be merged into the corresponding release branch. In this case, it would be the release/1 branch. It is important that the branch that was created from the develop is not merged into the release branch, as otherwise the next patch version will receive all the changes from the current development status. The simplest procedure is therefore to create a new branch from the release branch (e.g. release/1) and transfer the individual commits of the feature branch from the develop to the new branch using cherry-picking. This branch can then be merged into the release branch as normal with a new pull request.

Snapshot Testing for Visual Changes

The Continuous Integration (CI) pipeline incorporates automated visual regression testing using the React sample app across all available themes.

When introducing visual modifications to components, themes, or the React sample app, initial test failures are expected. To address this, the update-snapshots.yml action on GitHub should be executed, followed by a careful review of the changes.

How to Update Snapshots

The following methods can be used to update the snapshots.

  1. GitHub website: Update the snapshots directly on the GitHub website by following these steps.
  • Navigate to the Actions tab in the kolibri repository.
  • Execute the 03 - Update Snapshots action.
  • Select the desired branch in which you want to update the snapshots.
  • The workflow checks out the branch, updates all snapshot files, and commits the changes to that branch.
  1. Terminal Command: Use the GitHub CLI (gh) to run the update-snapshots.yml action from the local terminal. This method is recommended for updating snapshots on the current branch without navigating to the GitHub website. For terminal convenience, the GitHub CLI (gh) needs to be installed.
  • Run the following command within the project directory to update the snapshots in your checked-out branch:
    gh workflow run update-snapshots.yml -r `git rev-parse --abbrev-ref HEAD`
  • If your want to delete all snapshots before regenerating them add -f purge_snapshots=true to the command:
    gh workflow run update-snapshots.yml -r `git rev-parse --abbrev-ref HEAD` -f purge_snapshots=true
  • You can also run the action on a different branch by specifying the another target branch with the -r <branch_name> flag. For example, to update snapshots on the main branch:
    gh workflow run update-snapshots.yml -r main

These steps ensure that visual snapshots are updated systematically, maintaining the integrity of the testing process.