Skip to content

The following template is comprised of best practices for creating and organizing your repository's README, as well as minimum requirements for making code available on ITS CodeHub.

License

Notifications You must be signed in to change notification settings

eberlyn/codehub-readme-template

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 

Repository files navigation

codehub-readme-template

Summary of what a README file is:

A README file contains important information about the associated source code, files, dependencies and related details that make up an application. In order to leverage applications and their associated source code, members of the open source community rely on clear and concise READMEs.

The following is a README template comprised of best practices for what information users expect to be included within a README.md file and how to organize for better user experience, as well as requirements for making code available on the ITS CodeHub. Pease feel free to copy and paste this template into your own repository's README space.

README Outline:

  • Project Description
  • Contact Information
  • Release Notes
  • Getting Started
  • Prerequisites
  • Installing
  • Testing
  • Deployment
  • Builds
  • Contributions
  • Versioning
  • License
  • Acknowledgments
  • Additional Notes

Project Description

Required - Insert your project's title, a one paragraph description of its code and what the code does.

Example:

README Template

This project is a README template for users to copy-paste into their project's README file and fill out with their project's information in order to provide useful and relevant information to users of a repository, as well as to be compliant with ITS JPO requirements for making source code available on ITS CodeHub.

Contact Information

Required - Provide a primary contact and associated contact information (e.g. email and phone number) for the ITS JPO to contact regarding questions for this repository.

Example:

Contact Name: ITS JPO Contact Information: data.itsjpo@dot.gov, (888)-888-8888

Release Notes

Required - A statement of the status of the source code (prototype, alpha, beta, release, etc.), how often users can expect activity on this repository, and a list of changes included in every release of your project.

Example:

Status: this project is in the release phase.

This project is updated approximately once every 2-3 weeks.

Release 1.0.2 (Apr 2, 2020)

  • Fixed bug with popup

Release 1.0.1 (Mar 19, 2020)

  • Added unit tests
    • Unit tests can be run using mvn clean test

Release 1.0.0 (Mar 5, 2020)

  • Initial release

Getting Started

Required - Place instructions for standing up a copy of the project on a user's local machine for development and testing purposes. You can could also include deployment notes for pushing to the production environment.

Prerequisites

Detail what actions users may need to take before they can stand up the project. This might include instructions and examples for installing additional software.

Example:

Requires:

  • Java 8 (or higher)
  • Maven 3.5.4

Installing

Insert step-by-step instructions that a user needs to follow to stand up a development environment of your project.

Example:

Step 1: Set up a cloud environment.

Provide details. 

Step 2: Set up cloud alarms.

Provide details

Testing

Required - Provide explanation for how to run automated and manual tests for this project.

End-to-End Testing

Detail each test and the reasoning behind it. It is also a best practice to provide several situational examples.

Example:

To run the unit tests, run the following command:

mvn clean test

Code standard tests

Detail each test and the reasoning behind them. It is also a best practice to provide several situational examples.

To run ESLint tests run the following command:

eslint myfile.js

Deployment

Optional - Add any additional notes users may need for how to deploy the project on a live system.

Example:

Deploy this function as an AWS Lambda function, following this guide.

Builds

Required - Detail the open code standard(s) used, frameworks, and any applications used to create and run the project. If a non-open code standard is used, explain why.

Example:

Contributions

Required - Create a file named "CONTRIBUTING.md" explaining how users can interact with this project's repository, your expectations for their conduct, and how contributions by users will be released (e.g. whether they will be released under the same license and whether those contributors waive their rights accordingly).

Example:

Please read CONTRIBUTING.md for details on our Code of Conduct, the process for submitting pull requests to us, and how contributions will be released.

Versioning

Optional - use this section to explain what versioning technique your project uses and how major and minor versions differ.

Example:

We use SemVer for versioning. For the versions available, see the tags on this repository.

License

Required - Create a file named "LICENSE.md" that contains at least the licensing status of the code and the full text of the open source license or a link to where the license is officially maintained. If for some reason the source code does not use an open license, explain why.

Example:

This project is licensed under the Apache 2.0 License - see the LICENSE.md file for details.

Acknowledgments

Required - describe how users should reference your code if they use it to build additional software, list the Digital Object Identifier for this project, and (optional) list if you have a 3rd party or any specific contributor to give credit.

Example:

To track how this government-funded code is used, we request that if you decide to build additional software using this code please acknowledge its Digital Object Identifier in your software's README/documentation.

Digital Object Identifier: https://www.doi.org/

Shout out to PurpleBooth for their README template.

Additional Notes

Optional - include any other relevant technical details on how to build, make, install or use the software, including dependencies.

About

The following template is comprised of best practices for creating and organizing your repository's README, as well as minimum requirements for making code available on ITS CodeHub.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published