feat: setup readme #2
21
.gitea/workflows/pr.yml
Normal file
|
@ -0,0 +1,21 @@
|
|||
name: "Lint Pull Request"
|
||||
|
||||
on:
|
||||
pull_request:
|
||||
types: [opened, edited, reopened, synchronize]
|
||||
|
||||
jobs:
|
||||
lint:
|
||||
name: Lint PR Title
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
if: github.base_ref != 'release'
|
||||
|
||||
steps:
|
||||
- name: Install go
|
||||
uses: actions/setup-go@v5
|
||||
with:
|
||||
go-version: 1.24.2
|
||||
|
||||
- name: Run Pull Request Lint Action
|
||||
uses: https://git.kjan.de/actions/pull-request-lint@main
|
76
.gitea/workflows/release.yml
Normal file
|
@ -0,0 +1,76 @@
|
|||
name: Release
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- release
|
||||
|
||||
jobs:
|
||||
release:
|
||||
name: Release
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
env:
|
||||
GITEA_DOMAIN: git.kjan.de # Your Gitea instance domain
|
||||
GIT_EMAIL: "gitea-actions@git.kjan.de" # Valid email for Git config
|
||||
GIT_USERNAME: "Gitea Actions" # Name for Git config
|
||||
SKIP_MERGE: false # Set to true to skip merging back to main
|
||||
TARGET_BRANCH: main #Branch to merge into
|
||||
RELEASE_BRANCH: release # The name of the release branch
|
||||
|
||||
permissions:
|
||||
contents: write
|
||||
issues: write
|
||||
pull-requests: write
|
||||
id-token: write
|
||||
|
||||
steps:
|
||||
- name: Create Release
|
||||
uses: https://git.kjan.de/actions/semantic-release@main
|
||||
id: semantic
|
||||
with:
|
||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||
|
||||
- name: Configure SSH
|
||||
if: ${{ steps.semantic.outputs.new_release_published }}
|
||||
run: |
|
||||
mkdir -p ~/.ssh
|
||||
echo "${{ secrets.DEPLOY_KEY }}" > ~/.ssh/id_rsa
|
||||
chmod 400 ~/.ssh/id_rsa
|
||||
ssh-keyscan ${{ env.GITEA_DOMAIN }} >> ~/.ssh/known_hosts
|
||||
chmod 400 ~/.ssh/known_hosts
|
||||
|
||||
- name: Configure Git
|
||||
if: ${{ steps.semantic.outputs.new_release_published }}
|
||||
run: |
|
||||
git config --global user.email "${{ env.GIT_EMAIL }}"
|
||||
git config --global user.name "${{ env.GIT_USERNAME }}"
|
||||
|
||||
- name: Make changes
|
||||
if: ${{ steps.semantic.outputs.new_release_published }}
|
||||
run: |
|
||||
git add docs/
|
||||
git commit -m "chore(release): [skip ci]"
|
||||
continue-on-error: true
|
||||
|
||||
- name: Push changes to release branch
|
||||
if: ${{ steps.semantic.outputs.new_release_published }}
|
||||
run: |
|
||||
git remote set-url origin git@${{ env.GITEA_DOMAIN }}:${{ github.repository }}.git
|
||||
git push origin HEAD:${{ env.RELEASE_BRANCH }}
|
||||
continue-on-error: true
|
||||
|
||||
- name: Checkout target branch
|
||||
if: ${{ !(env.SKIP_MERGE == true) }}
|
||||
run: git reset --hard && git checkout ${{ env.TARGET_BRANCH }} && git pull
|
||||
|
||||
- name: Merge release
|
||||
if: ${{ !(env.SKIP_MERGE == true) }}
|
||||
run: git merge ${{ env.RELEASE_BRANCH }}
|
||||
|
||||
- name: Push changes to target branch
|
||||
if: ${{ !(env.SKIP_MERGE == true) }}
|
||||
run: |
|
||||
git remote set-url origin git@${{ env.GITEA_DOMAIN }}:${{ github.repository }}.git
|
||||
git push origin HEAD:${{ env.TARGET_BRANCH }}
|
94
README.md
|
@ -1,2 +1,94 @@
|
|||
# ci-template
|
||||
# CI Template
|
||||
|
||||
A template repository for setting up continuous integration and automatic semantic versioning with Gitea.
|
||||
|
||||
## Features
|
||||
|
||||
- Automated semantic versioning with [semantic-release](https://github.com/semantic-release/semantic-release)
|
||||
- Integration with Gitea for releases
|
||||
- Changelog generation
|
||||
- Pull request workflows
|
||||
|
||||
## Setup Instructions
|
||||
|
||||
Follow these steps to set up the CI pipeline and release process:
|
||||
|
||||
### 1. Configure Branch Protection
|
||||
|
||||
Add yourself to the whitelist in the release branch protection rule.
|
||||
|
||||

|
||||
|
||||
Don't forget to save your changes.
|
||||
|
||||

|
||||
|
||||
### 2. Create the Release Branch
|
||||
|
||||
Create a new branch named `release`.
|
||||
|
||||

|
||||
|
||||
The pipeline for release will start automatically but will fail on the first run. This is expected behavior.
|
||||
|
||||

|
||||
|
||||
### 3. Create the Initial Version Tag
|
||||
|
||||
Run the following commands to create and push the first version tag:
|
||||
|
||||
```bash
|
||||
git tag v0.1.0
|
||||
git push origin tag v0.1.0
|
||||
```
|
||||
|
||||
### 4. Configure Pull Request Settings
|
||||
|
||||
Set up your repository's pull request settings as shown:
|
||||
|
||||

|
||||
|
||||
### 5. Set Up Deploy Keys
|
||||
|
||||
1. Generate an SSH key pair (public and private)
|
||||
2. Add the public key to deploy keys named "release" with write access enabled
|
||||
|
||||

|
||||
|
||||
3. Add the private key to the runner secret as `DEPLOY_KEY`
|
||||
|
||||

|
||||
|
||||
## Release Process
|
||||
|
||||
This template uses semantic versioning through conventional commits. When changes are merged to the release branch, a new version is automatically:
|
||||
|
||||
1. Determined based on commit messages
|
||||
2. Tagged in Git
|
||||
3. Published as a release
|
||||
4. Added to the changelog
|
||||
|
||||
### Commit Message Format
|
||||
|
||||
Follow the [Conventional Commits](https://www.conventionalcommits.org/) specification:
|
||||
|
||||
- `feat: add new feature` (triggers MINOR version bump)
|
||||
- `fix: resolve bug` (triggers PATCH version bump)
|
||||
- `BREAKING CHANGE: redesign API` (triggers MAJOR version bump)
|
||||
|
||||
## Getting Started
|
||||
|
||||
After completing the setup:
|
||||
1. Remove the images directory and this README
|
||||
2. Create feature branches from `main` for your work
|
||||
3. Make changes and commit using conventional commit format
|
||||
4. Create pull requests to `main` (changes should be squashed when merged, although this is not required)
|
||||
5. When ready for a release, create a PR from `main` to `release`
|
||||
6. The PR to `release` will automatically:
|
||||
- Create a new version based on your commits
|
||||
- Generate a changelog
|
||||
- Merge changes back into `main`
|
||||
|
||||
## License
|
||||
|
||||
See the [LICENSE](LICENSE) file for details.
|
BIN
images/1.png
Normal file
After Width: | Height: | Size: 60 KiB |
BIN
images/2.png
Normal file
After Width: | Height: | Size: 19 KiB |
BIN
images/3.png
Normal file
After Width: | Height: | Size: 33 KiB |
BIN
images/4.png
Normal file
After Width: | Height: | Size: 44 KiB |
BIN
images/5.png
Normal file
After Width: | Height: | Size: 45 KiB |
BIN
images/6.png
Normal file
After Width: | Height: | Size: 53 KiB |
BIN
images/7.png
Normal file
After Width: | Height: | Size: 8.3 KiB |
16
release.config.cjs
Normal file
|
@ -0,0 +1,16 @@
|
|||
module.exports = {
|
||||
branches: ['release'],
|
||||
plugins: [
|
||||
'@semantic-release/commit-analyzer',
|
||||
'@semantic-release/release-notes-generator',
|
||||
[
|
||||
"@semantic-release/changelog",
|
||||
{
|
||||
"changelogFile": "docs/CHANGELOG.md"
|
||||
}
|
||||
],
|
||||
["@saithodev/semantic-release-gitea", {
|
||||
"giteaUrl": "https://git.kjan.de"
|
||||
}],
|
||||
],
|
||||
};
|