| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- // Copyright 2022 The Gitea Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package git
-
- import (
- "testing"
-
- "code.gitea.io/gitea/models/db"
- repo_model "code.gitea.io/gitea/models/repo"
- "code.gitea.io/gitea/models/unittest"
-
- "github.com/stretchr/testify/assert"
- )
-
- func TestBranchRuleMatch(t *testing.T) {
- kases := []struct {
- Rule string
- BranchName string
- ExpectedMatch bool
- }{
- {
- Rule: "release/*",
- BranchName: "release/v1.17",
- ExpectedMatch: true,
- },
- {
- Rule: "release/**/v1.17",
- BranchName: "release/test/v1.17",
- ExpectedMatch: true,
- },
- {
- Rule: "release/**/v1.17",
- BranchName: "release/test/1/v1.17",
- ExpectedMatch: true,
- },
- {
- Rule: "release/*/v1.17",
- BranchName: "release/test/1/v1.17",
- ExpectedMatch: false,
- },
- {
- Rule: "release/v*",
- BranchName: "release/v1.16",
- ExpectedMatch: true,
- },
- {
- Rule: "*",
- BranchName: "release/v1.16",
- ExpectedMatch: false,
- },
- {
- Rule: "**",
- BranchName: "release/v1.16",
- ExpectedMatch: true,
- },
- {
- Rule: "main",
- BranchName: "main",
- ExpectedMatch: true,
- },
- {
- Rule: "master",
- BranchName: "main",
- ExpectedMatch: false,
- },
- }
-
- for _, kase := range kases {
- pb := ProtectedBranch{RuleName: kase.Rule}
- var should, infact string
- if !kase.ExpectedMatch {
- should = " not"
- } else {
- infact = " not"
- }
- assert.Equal(t, kase.ExpectedMatch, pb.Match(kase.BranchName),
- "%s should%s match %s but it is%s", kase.BranchName, should, kase.Rule, infact,
- )
- }
- }
-
- func TestUpdateProtectBranchPriorities(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
-
- repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
-
- // Create some test protected branches with initial priorities
- protectedBranches := []*ProtectedBranch{
- {
- RepoID: repo.ID,
- RuleName: "master",
- Priority: 1,
- },
- {
- RepoID: repo.ID,
- RuleName: "develop",
- Priority: 2,
- },
- {
- RepoID: repo.ID,
- RuleName: "feature/*",
- Priority: 3,
- },
- }
-
- for _, pb := range protectedBranches {
- _, err := db.GetEngine(t.Context()).Insert(pb)
- assert.NoError(t, err)
- }
-
- // Test updating priorities
- newPriorities := []int64{protectedBranches[2].ID, protectedBranches[0].ID, protectedBranches[1].ID}
- err := UpdateProtectBranchPriorities(t.Context(), repo, newPriorities)
- assert.NoError(t, err)
-
- // Verify new priorities
- pbs, err := FindRepoProtectedBranchRules(t.Context(), repo.ID)
- assert.NoError(t, err)
-
- expectedPriorities := map[string]int64{
- "feature/*": 1,
- "master": 2,
- "develop": 3,
- }
-
- for _, pb := range pbs {
- assert.Equal(t, expectedPriorities[pb.RuleName], pb.Priority)
- }
- }
-
- func TestNewProtectBranchPriority(t *testing.T) {
- assert.NoError(t, unittest.PrepareTestDatabase())
- repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
-
- err := UpdateProtectBranch(t.Context(), repo, &ProtectedBranch{
- RepoID: repo.ID,
- RuleName: "branch-1",
- Priority: 1,
- }, WhitelistOptions{})
- assert.NoError(t, err)
-
- newPB := &ProtectedBranch{
- RepoID: repo.ID,
- RuleName: "branch-2",
- // Priority intentionally omitted
- }
-
- err = UpdateProtectBranch(t.Context(), repo, newPB, WhitelistOptions{})
- assert.NoError(t, err)
-
- savedPB2, err := GetFirstMatchProtectedBranchRule(t.Context(), repo.ID, "branch-2")
- assert.NoError(t, err)
- assert.Equal(t, int64(2), savedPB2.Priority)
- }
|