зеркало из
1
0
Форкнуть 0
codeql-learninglab-actions/CONTRIBUTING.md

2.9 KiB

Contributing

Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.

Contributions to this project are released to the public under the project's open source license.

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Submitting a pull request

  1. Fork and clone the repository
  2. Configure and install the dependencies: script/bootstrap
  3. Make sure the tests pass on your machine: rake
  4. Create a new branch: git checkout -b my-branch-name
  5. Make your change, add tests, and make sure the tests still pass
  6. Push to your fork and submit a pull request
  7. Pat your self on the back and wait for your pull request to be reviewed and merged.

Here are a few things you can do that will increase the likelihood of your pull request being accepted:

  • Write tests.
  • Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as separate pull requests.
  • Write a good commit message.

Resources

Updating and Releasing

🐳 codeql-learninglab-check docker image

The top-level dependency is the codeql-learninglab-check docker image. To update its dependencies, or release a new version of it, please see the README for that docker image.

Courses included in the courses/ directory

Following changes to the codeql-learninglab-check base docker image, you'll likely want to update each of the individual courses to use the latest version. (This will be necessary for users to take advantage of the latest changes to the CodeQL libraries or tools). You can do this by updating the FROM line in the respective Dockerfile.

Changes to the courses, including changes to the Dockerfile, the configuration, or any of the expected results .csv files are automatically published when pushes are made to master. This is done by the respective publish.sh file for each course.

We generally want to ensure that we always push the version latest so that changes can immediately be used by all course participants, and we don't need to update any references to versions elsewhere.