CCS Frontend Helpers
The CCS Frontend Helpers gem was created for use in the Crown Marketplace projects at the Crown Commercial Service. This project contains two applications (both use the Ruby on Rails framework):
Compatibility
The following table shows the version of CCS Frontend Helpers that you should use for your targeted version of GOV.UK Frontend:
CCS Frontend Helpers Version | Target GOV.UK Frontend Version | Target CCS Frontend Version |
---|---|---|
2.1.0 | 5.7.1 | 1.3.2 |
2.0.0 | 5.7.1 | 1.2.0 |
1.2.0 | 5.6.0 | 1.1.3 |
1.1.2 | 5.5.0 | 1.1.2 |
1.1.1 | 5.4.1 | 1.1.1 |
1.1.0 | 5.4.0 | 1.1.0 |
1.0.0 | 5.4.0 | 1.0.0 |
0.4.0 | 5.4.0 | N/A |
0.3.0 | 5.3.0 | N/A |
0.2.0 | 5.2.0 | N/A |
0.1.2 | 4.7.0 | N/A |
Any other versions of GOV.UK Frontend not shown above may still be compatible, but have not been specifically tested and verified.
Installation
Install the gem and add to the application's Gemfile by executing:
$ bundle add ccs-frontend_helpers
If bundler is not being used to manage dependencies, install the gem by executing:
$ gem install ccs-frontend_helpers
Usage
To use this gem, simply add it to your Gemfile (as described above).
Helpers
To include the helper methods from the GovUKFrontend
and CCSFrontend
module, you can include the CCS::FrontendHelpers
module in your app/helpers/application_helper.rb
file like so:
module ApplicationHelper
include CCS::FrontendHelpers
end
This will give you access to a variety of GDS components and CCS components to use in your application views.
The GovUKFrontend
components are based on the components found in GOV.UK Frontend v4.5.0.
Documentation for the helper methods can be found at LINK TO RDOCS
Development
After checking out the repo, run bin/setup
to install dependencies. Then, run rake spec
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
.
Linting
The rubocop & rubocop-rspec gems are used to enforce standard coding styles.
Some "cops" in the standard configuration have been disabled or adjusted in .rubocop.yml
.
Rubocop linting is run as part of the default Rake task, but can be run individually using rake rubocop
.
Testing
Unit testing
There is an automated RSpec-based test suite.
You can run all the unit tests with:
bundle exec rake
To run a specific unit test, use:
bundle exec rspec /path/to/file_spec.rb
All the specs are run as part of the Pull Request process.
Code coverage
Code coverage is measured by simplecov
After running the Rspec tests, open coverage/index.html in a browser to see the code coverage percentage.
Managing dependencies
We use dependabot and Snyk to help manage our dependencies.
We schedule dependabot
to run every Sunday night which will get the latest dependency updates.
Snyk is used more for analysing security issues and it will raise PRs itself for a developer to analyse.
Releasing
-
Check out the main branch and pull the latest changes.
-
Update the version number in
version.rb
(we follow Semantic Versioning). -
Run
bundle install
to update theGemfile.lock
-
Create and check out a new branch (
release-[version]
)
git switch -c "release-$(./bin/version)"
-
Update the
CHANGELOG.md
by:- changing the 'Unreleased' heading to the new version number and release type. For example, '3.11.0 (Feature release)'
- adding a new 'Unreleased' heading above the new version number and release type, so users will know where to add PRs to the changelog
- if the changelog has headings from a pre release, regroup the content under those headings in a single block
- saving your changes
-
Run
./bin/build-release.sh
to:- commit the changes
- push a branch to GitHub
You will now be prompted to continue or cancel. Check the details and enter
y
to continue. If something does not look right, pressN
to cancel the build and creation of the branch on GitHub. -
Create a pull request and copy the changelog text. When reviewing the PR, check that the version numbers have been updated and that the compiled assets use this version number.
-
Once a reviewer approves the pull request, merge it to main. The gem will then automatically be published to rubygems.org via a GitHub action.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/Crown-Commercial-Service/ccs-frontend_helpers.
To contribute to the project, you should checkout a new branch from main
and make your changes.
Before pushing to the remote, you should squash your commits into a single commit.
This can be done using git rebase -i main
and changing pick
to s
for the commits you want to squash (usually all but the first).
This is not required but it helps keep the commit history fairly neat and tidy
Once you have pushed your changes, you should open a Pull Request on the main branch. This will run:
- Rubocop
- Unit tests
Once all these have passed, and the PR has been reviewed and approved by another developer, you can merge the PR.
Licence
The gem is available as open source under the terms of the MIT Licence.