Welcome to YouShallNotPass and thank you for contributing your time and expertise to the project. This document describes the contribution guidelines for the project
- Setup
- Contributing Steps
- Contributing Checks
- Conventions
- PR Process
- Before creating a PR
- Adding New Checks
You must install these tools:
A testing file testing/test.sh is used make the running of tests easier.
For unit testing run:
testing/test.sh unit
Integration testing sets up set of docker images to perform testing on.
To build the docker images run:
testing/test.sh integration build
To run the integration tests run:
testing/test.sh integration
- Submit an issue describing your proposed change to the repo.
- For the repo, develop, and test your code changes
- Submit a pull request
To Contribute Checks to YouShallNotPass follow the following steps:
- Create an issue describing the new check to be added (with the enhancement label)
- Create a Fork of the YouShallNotPass repository
- Create a new module in pkg/checks with the name of the check to be created
- Please name the new module the check name in lowercase with no separations.
- Example, Script Hash Check -> pkg/checks/scripthash.
- Create a struct and initializer to pass in the check configuration and other information (besides the whitelist) that is necessary for the check's completion
- Example, the Script Hash Check ->
func NewScriptHashCheck(config config.CheckConfig, jobName string, scriptLines []string) ScriptHashCheck
.
- Example, the Script Hash Check ->
- Implement the IsValidForCheckType function from the Check interface given here
- This function should return true if the checkType is valid for the given check (valid checkTypes are ImageCheck, ScriptCheck, and All).
- Example, the Script Hash Check is only valid for Script Checks and All Checks -> returns true when
checkType == ScriptCheck
ORcheckType == All
.
- Implement the IsValidForPlatform function from the Check interface given here
- This function should return true if the CI Platform is valid for a given check (valid ciPlatforms are the lowercase of a given platform - i.e. gitlab, github, ...).
- For example, a Gitlab Linter Check would only be valid for the "gitlab" platform -> return true if
ciPlatform == "gitlab"
- Implement the Check function from the Check interface given here
- This is where the magic of your check happens. In this function all of the necessary logic that must occur to check whether or not your check has been passed happens.
- All checks are given access to the whitelist in addition to any information they have stored as a part of their initializer.
- To make things slightly easier every Check implementation should start with
defer wg.Done()
. This lets the wait group the check is part of know that the check has completed its necessary tasks and the main thread can read the results of each check. - After a check has come to a conclusion as to the success of its execution it will create a checkResult and send it through the channel provided through the function. This CheckResult is then read by the main thread after every check is completed to create a "scorecard" for the YouShallNotPass execution.
- Create a second file title
{checkname}_test.go
and create a series of unit tests to ensure that the check you created does exactly what you expect it to do. - Add the check to the checkparser and checkparser unit tests.
- Add the new check to the unit testing bash script
- more or less this is basically running go test with the path to the new check
go test "${currentDir}/../../pkg/checks/newcheckname"
- more or less this is basically running go test with the path to the new check
- Add the check (and configuration options) to the README
- Create a PR documenting the new check and linking it back to the Issue created (or found) in step 1.
- modules should be all lowercase characters
- variables should be named using mixedCase
Every PR should be annotated with an icon indicating whether it's a:
- Breaking change: (:warning:)
- Non-breaking feature: (:sparkles:)
- Patch fix: (:bug:)
- Docs: (:book:)
- Tests/Other: (:seedling:)
- No release note: (:ghost:)
Only the final PR needs to be marked with its icon.
The following tests can be run to test your local changes.
Command | Description | Is called in the CI? |
---|---|---|
testing/test.sh unit | Runs go test | yes |
testing/test.sh integration | Runs integration tests | partialy |
When adding new tests please follow the guidelines in TESTING.md