Naming conventions
REVIEWIt is important to adopt a naming convention:
- to clarify intent
- to group similar items
Terms
Terms used in the naming conventions are:
Term | Description | example |
---|---|---|
Department | The department that owns the service |
|
Service line | For grouping within a Department |
|
Service | The actual Service being delivered |
|
Function | The operational function of a repository or component |
|
Type | The type of component, repository or change |
For components:
|
Change ID | The identifier for a change, usually a Jira ticket such as a story, task, sub-task or bug |
|
Abbreviations
Service delivery teams often adopt short form or abbreviations of names. For example, the Maternity Exemption Certificate service is shorted to Matex, Immigration Health Surcharge is abbreviated to IHS. It is ok to use the short form for internal names such as code modules or system urls.
Use long form names whenever the content may be used outside of the service team. This includes service URLs, public hosted code repository names and READMEs.
Case
Different case standards should be applied depending on usage:
Natural
- Using natural language standard, with spaces to separate words and capitals for initial letter and proper nounskebab-case
- All lower case with dashes to separate wordsCamelCase
- Initial letters in words are uppercased, with no separators. First letter may be upper or lower.snake_case
- All lower case with underscores to separate words
For all cases except natural
, acronyms should be lowercased and treated as a single word.
Git
Git Repositories
Git repositories should be kebab-case
with this convention:
{optional service-line}-{service}-{function}-{type}
Gitlab and Github hosted repository names should use unabbreviated natural
case.
Git branches
All branches should be kebab-case
, although change ID should be uppercase
-
The mainline branch should be named
main
. -
release candidate branches should follow the convention:
develop-{version}
or
hotfix-{version}
-
change candidate branches should follow the convention:
{change ID}-{brief description}
Descriptions should be kept brief, not exceeding 50 characters.
See Git branching guidance for a more detailed explanation of Git branch naming
Gitlab groups
Repositories in Gitlab should be organised into ‘groups’. Use unabbreviated natural
case for the human readable form, and kebab-case
for the URL with this convention:
{department}/{service-line}/{service}
Merge/Pull Requests
Merge/pull requests should be raised with natural
case and this convention:
{change ID} - {brief description}
Commit messages
Commit messages should be natural
case and follow this convention:
{change ID} {brief description}
i.eHMOD-0001 added check your answers page
Its fine to use NO-JIRA
as the change ID if the change is a non-functional change, for example if its just updating the README file.
Commit message regex: ([A-Z]{3,4}\-([0-9]+)|Merge|Merging|NO-JIRA)[ ][a-z][a-zA-Z0-9 ]*
Languages
For language constructs refer to the standard language style guides.
Java
Java packages
should be all lower case concatenated with this convention:
uk.nhs.nhsbsa.{service}.{function}
Libraries may omit the service
when shared across multiple services.
Package managers and build tools
Maven
Maven group id
should be kebab-case
with this convention:
uk.nhs.nhsbsa.{optional department}.{optional service-line}.{service}
Maven artifact id
should follow kebab-case
and this convention:
{optional service-line}-{service}-{function}-{type}
Unit tests run by Maven Surefire plugin should follow the convention:
*Test.java
Integration tests run by Maven Failsafe plugin should follow the convention:
*IT.java
NPM
Package.json name
should be kebab-case
with this convention:
@nhsbsa/{optional service-line}-{service}-{function}-{type}
Improve the playbook
If you spot anything factually incorrect with this page or have ideas for improvement, please share your suggestions.
Before you start, you will need a GitHub account. Github is an open forum where we collect feedback.
Published:
Last reviewed:
Next review due: