{"id":28408328,"url":"https://github.com/gittools/actions","last_synced_at":"2026-02-19T17:03:34.608Z","repository":{"id":36973261,"uuid":"220321564","full_name":"GitTools/actions","owner":"GitTools","description":"GitHub Action that installs and uses the GitVersion and GitReleaseManager tools","archived":false,"fork":false,"pushed_at":"2026-02-18T12:06:56.000Z","size":121305,"stargazers_count":260,"open_issues_count":4,"forks_count":80,"subscribers_count":4,"default_branch":"main","last_synced_at":"2026-02-18T16:36:25.272Z","etag":null,"topics":["hacktoberfest"],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/GitTools.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2019-11-07T20:16:44.000Z","updated_at":"2026-02-18T12:06:58.000Z","dependencies_parsed_at":"2023-02-19T04:45:20.678Z","dependency_job_id":"d394cdd1-aeec-4018-96ea-96c9c238549e","html_url":"https://github.com/GitTools/actions","commit_stats":{"total_commits":873,"total_committers":26,"mean_commits":33.57692307692308,"dds":"0.41122565864833904","last_synced_commit":"a70449f3e0f118ebf7ed8d536359ae67a4ea9b48"},"previous_names":[],"tags_count":75,"template":false,"template_full_name":null,"purl":"pkg:github/GitTools/actions","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GitTools%2Factions","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GitTools%2Factions/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GitTools%2Factions/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GitTools%2Factions/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/GitTools","download_url":"https://codeload.github.com/GitTools/actions/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/GitTools%2Factions/sbom","scorecard":{"id":56602,"data":{"date":"2025-08-11","repo":{"name":"github.com/GitTools/actions","commit":"0a65fd7f1cce0306b7d531a5b3de53b539b77173"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":5.7,"checks":[{"name":"Code-Review","score":0,"reason":"Found 0/6 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Maintained","score":10,"reason":"30 commit(s) and 9 issue activity found in the last 90 days -- score normalized to 10","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Token-Permissions","score":10,"reason":"GitHub workflow tokens follow principle of least privilege","details":["Info: topLevel permissions set to 'read-all': .github/workflows/checkout-path.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/ci.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/examples-version.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/output-example-1.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/output-example-2.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/prerelease.yml:3","Info: topLevel permissions set to 'read-all': .github/workflows/release.yml:3","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Info: Possibly incomplete results: error parsing shell code: a command can only contain words and redirects; encountered (: .github/workflows/ci.yml:108","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/checkout-path.yml:26: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/checkout-path.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/checkout-path.yml:32: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/checkout-path.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/checkout-path.yml:38: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/checkout-path.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:38: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/ci.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:57: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/ci.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/examples-version.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/examples-version.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/output-example-1.yml:18: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-1.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/output-example-1.yml:23: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-1.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/output-example-1.yml:29: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-1.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/output-example-2.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-2.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/output-example-2.yml:29: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-2.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/output-example-2.yml:35: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/output-example-2.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/prerelease.yml:20: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/prerelease.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/release.yml:21: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/release.yml/main?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/release.yml:83: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/release.yml/main?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/stale.yml:16: update your workflow using https://app.stepsecurity.io/secureworkflow/GitTools/actions/stale.yml/main?enable=pin","Warn: npmCommand not pinned by hash: .github/workflows/ci.yml:43","Warn: npmCommand not pinned by hash: .github/workflows/prerelease.yml:26","Warn: npmCommand not pinned by hash: .github/workflows/release.yml:27","Info:   0 out of   9 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   8 third-party GitHubAction dependencies pinned","Info:   0 out of   3 npmCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Info: FSF or OSI recognized license: MIT License: LICENSE:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":0,"reason":"Project has not signed or included provenance with any releases.","details":["Warn: release artifact v4.1.0 not signed: https://api.github.com/repos/GitTools/actions/releases/237815206","Warn: release artifact v4.0.1 not signed: https://api.github.com/repos/GitTools/actions/releases/230596528","Warn: release artifact v4.0.0 not signed: https://api.github.com/repos/GitTools/actions/releases/228000273","Warn: release artifact v3.2.1 not signed: https://api.github.com/repos/GitTools/actions/releases/214802500","Warn: release artifact v3.2.0 not signed: https://api.github.com/repos/GitTools/actions/releases/209734287","Warn: release artifact v4.1.0 does not have provenance: https://api.github.com/repos/GitTools/actions/releases/237815206","Warn: release artifact v4.0.1 does not have provenance: https://api.github.com/repos/GitTools/actions/releases/230596528","Warn: release artifact v4.0.0 does not have provenance: https://api.github.com/repos/GitTools/actions/releases/228000273","Warn: release artifact v3.2.1 does not have provenance: https://api.github.com/repos/GitTools/actions/releases/214802500","Warn: release artifact v3.2.0 does not have provenance: https://api.github.com/repos/GitTools/actions/releases/209734287"],"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":-1,"reason":"internal error: error during branchesHandler.setup: internal error: githubv4.Query: Resource not accessible by integration","details":null,"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"SAST","score":8,"reason":"SAST tool is not run on all commits -- score normalized to 8","details":["Warn: 22 commits out of 26 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Vulnerabilities","score":9,"reason":"1 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-15T00:54:22.899Z","repository_id":36973261,"created_at":"2025-08-15T00:54:22.899Z","updated_at":"2025-08-15T00:54:22.899Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29623548,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-19T13:04:20.082Z","status":"ssl_error","status_checked_at":"2026-02-19T13:03:33.775Z","response_time":117,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["hacktoberfest"],"created_at":"2025-06-02T02:37:51.611Z","updated_at":"2026-02-19T17:03:29.599Z","avatar_url":"https://github.com/GitTools.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# GitTools actions\n\n![GitTools](docs/icon.png \"GitTools\")\n\nGitHub Actions that allow the setup and use of the [GitVersion](https://github.com/GitTools/GitVersion) and [GitReleaseManager](https://github.com/GitTools/GitReleaseManager) tools.\n\n[![CI Build Status](https://github.com/GitTools/actions/workflows/CI/badge.svg)](https://github.com/GitTools/actions/actions)\n[![Release Build Status](https://github.com/GitTools/actions/workflows/release/badge.svg)](https://github.com/GitTools/actions/actions)\n\n[![GitHub Release](https://img.shields.io/github/v/release/gittools/actions?logo=github\u0026sort=semver)](https://github.com/GitTools/actions/releases/latest)\n\n[![Github Action][gh-actions-badge]][gh-actions]\n[![Azure Pipelines Task][az-pipeline-task-badge]][az-pipeline-task]\n\n## Usage\n\n### GitVersion\n\nExamples for usage of **GitVersion**:\n\n- [GitHub Actions](docs/examples/github/gitversion/index.md)\n- [Azure Pipelines tasks](docs/examples/azure/gitversion/index.md)\n\n### GitReleaseManager\n\nExamples for usage of **GitReleaseManager**:\n\n- [GitHub Actions](docs/examples/github/gitreleasemanager/index.md)\n- [Azure Pipelines tasks](docs/examples/azure/gitreleasemanager/index.md)\n\n[gh-actions]: https://github.com/marketplace/actions/gittools\n\n[gh-actions-badge]: https://img.shields.io/badge/marketplace-gittools-blue?logo=github\n\n[az-pipeline-task]: https://marketplace.visualstudio.com/items?itemName=gittools.gittools\n\n[az-pipeline-task-badge]: https://img.shields.io/badge/marketplace-gittools-blue?logo=data:application/pdf;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAACXBIWXMAAA7DAAAOwwHHb6hkAAAAGXRFWHRTb2Z0d2FyZQB3d3cuaW5rc2NhcGUub3Jnm+48GgAABJlJREFUWIXFVk1sVFUU/u6dNzOd6fx2ftoGFNIfNa1prCW4ALHsGolIYmjQGH/CwmUXBl2gK0OihoUYE5G40GAEQ7QJ0IobQSEkLYLFH4QabSpUptPpTDs/773pzLvHRTvDm3lvpjOtxpOcTN69557vu+eec+YwIsL/KdK/4aRzz8WupubA4xKDrRZ7LS8yYxPZ4/RDX27dBLa8PLGnu7fjKxBYPee2ijgH8PG6CGwZvOptfbD1pNDqAwcAboUbWOcTeDb4R8CYfS1ZJLTl3zUT2Lr/xkvhVt82Ekb4TSGG9o12OOwc0cQSfp3OQVZLgySwDgLtg1e9nR0tR02w0bPZgofbXcVvt9OKjWGBr8cXIavcwIBjDbKhxTcCMLsgQK92K6GrzQUilKhN4ujeZCuxNUSg8/kxj1coq5aRsAdeCLUEtpm1D4+TVczGkM8Govy9BQYqEuh78WKPx2a9TmioCs4ZRyDYhErNS1YJlfqarGol58RKCCQAWNJYu8Sq5zJjDI3uAAioCJKQgWhCRchvvMjkXypKcmalCviycwuVv2e5Wi0OcHtDVRshGL77SUE0oRbfXxOEa5MpTEVLbQsiAUBeA6pFwMIscPgCFW+ul7TKMHpFQdClQJIYFtMEJWfMDEMSmpXUcnQApzsIgJkSaHJzLGQ0CKEDIYa5ZNGDqd98Lq/qCOQhhHlFNthcsNjsECYMgz4JPncj/F6BqZk08lrNPZEW4okLRQJCWAjceNjCOBzeJtPoNPuscLud0AhgxOF2cswntdWRibKxO9F9M9/03ywSAPEY9DUKAIzB5Q4CbKVgdRLySnC5HCi04WRaQawGcDWTvRyfS+2aGu5bKMIUavOBfZeGALxX2LBZHPAEmw1OQn4LvK5GEJZfN5mWEU3kDXZ6EUS5ZDQxdONkz4fle0zfHNr2fv8qZ+wwANgtjXCHwgZwXxn47CrgWVkej0eiA9NntyfM9ll5V2vbe+ktgN5gYLccDf5Jp8/zFACE/ZLh5rOJXEVgIkJ6fuHAbyd6DlcjaEj9P09tfxOE19Ss49FfjnfvlhfTX4R8ZeApGZF4zvCnU9AlRUE8cgdJFv+kanjMIlAuTx+c6gmGAtcz2XvglW5ORMgkYlCzGRAj5HMiNHO6P1bNf9V5YODgdGtvR/AKGEMkQZiNpRGp8OZLiozUQgyi0ORrbAkcAD44m3royHDq7SNfJh/Tb547tOnu3zH5MxKUi8bme/+Yip8QgqBXTRBSsSgW4rPIUx6CqKg1EyANnYzjdWblveUGnx5o3v/zzdv3jxzaPHHr8+7nMsnkGVq54JKiYP7ubWSyaQiQIRdqkZpGspF3uyIAwAZP2VqV8H25jAJihCWRqTqNS5JzVRp1zYRhJbxLI3pE0TIrK3VP4wapayacPfPEsBD0iv6dq2kyubrP0ggQnn3/dLp0KSd+HHrGM1b4nhvdeSzw5Hkw4KN6yNdGALQDhB0lS5y9A2BMvzQ/uvNY08AFDpCht+ulQZOzNREQsjLOnY7dZgbcit/N1uPn+o96B769BkLAbJ/Ap+Ln+9Nme3pZtRP+1/IPO814AQ1WwqwAAAAASUVORK5CYII=\n\n### Versioning and Compatibility\n\nYou can find the compatibility matrix in the [versions.md](docs/versions.md) file.\n\n## Contributing\n\n### Prerequisites\n\n1. **Linux** - Recommended to build and run\n2. **Node.js** - Latest LTS version recommended\n3. **.NET SDK** - Version 8.0 or later required for GitVersion and GitReleaseManager tools\n4. **Git** - Latest version recommended\n\n### Development Environment Setup\n\nThis project is designed to be run and worked on in a Linux or macOS environment.\nIf developing on Windows, please consider using WSL as it's likely you will run into issues with file paths etc\n\n1. Clone the repository:\n\n   ```bash\n   git clone https://github.com/GitTools/actions.git\n   cd actions\n   ```\n\n2. Install dependencies:\n\n   ```bash\n   npm install\n   ```\n\n3. Build the project:\n   - For local development: `npm run build:local`\n   - For Azure Pipelines: `npm run build:azure`\n   - For GitHub Actions: `npm run build:github`\n\n4. Test the project:\n\n   ```bash\n   npm run test\n   ```\n\n### Required Knowledge\n\n- **TypeScript/JavaScript** - Primary development languages\n- **GitHub Actions** - Understanding of action creation and workflows\n- **Azure Pipelines** - Familiarity with pipeline tasks and extensions\n- **.NET Tools** - Basic understanding of .NET CLI tools\n- **Git** - Strong knowledge of Git versioning and release management\n\n### Project Structure\n\n- `src/tools/` - Core implementation of GitVersion and GitReleaseManager integrations\n- `src/agents/` - Build agent implementations for different CI platforms\n- `src/__tests__/` - Test suites organized by component\n- `docs/examples/` - Usage examples for both GitHub Actions and Azure Pipelines\n\n### Creating Pull Requests\n\nWhen contributing to this project, please follow these guidelines for creating pull requests:\n\n1. **Fork and Clone**\n   - Fork the repository to your GitHub account\n   - Clone your fork locally: `git clone https://github.com/YOUR-USERNAME/actions.git`\n   - Add upstream remote: `git remote add upstream https://github.com/GitTools/actions.git`\n\n2. **Create a Feature Branch**\n   - Create a branch from main: `git checkout -b feature/your-feature-name`\n   - Use descriptive branch names (e.g., `feature/add-new-version-format`, `fix/issue-123`)\n\n3. **Keep Your Branch Updated**\n   - Fetch upstream changes: `git fetch upstream`\n   - Rebase your branch on upstream main:\n\n     ```bash\n     git checkout main\n     git rebase upstream/main\n     git checkout your-branch\n     git rebase main\n     ```\n\n   - Always use rebase instead of merge to maintain a clean history\n\n4. **Make Your Changes**\n   - Make commits with clear, descriptive messages\n   - Follow the project's code style and conventions\n   - Add tests for new features or bug fixes\n   - Run tests locally to ensure everything passes\n\n5. **Submit the Pull Request**\n   - Push your changes to your fork: `git push origin your-branch`\n   - Go to the original repository on GitHub\n   - Click \"New Pull Request\" and select your feature branch\n   - Link any related issues\n\n6. **PR Guidelines**\n   - Keep PRs focused and single-purpose\n   - Include tests and documentation updates\n   - Ensure CI checks pass\n\n7. **After PR is Merged**\n   - Delete your feature branch locally and remotely\n   - Update your main branch with the upstream changes\n   - Celebrate your contribution! 🎉\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgittools%2Factions","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fgittools%2Factions","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fgittools%2Factions/lists"}