mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	* Some refactors related repository model * Move more methods out of repository * Move repository into models/repo * Fix test * Fix test * some improvements * Remove unnecessary function
		
			
				
	
	
		
			273 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			273 lines
		
	
	
		
			7.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2021 The Gitea Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a MIT-style
 | 
						|
// license that can be found in the LICENSE file.
 | 
						|
 | 
						|
package doctor
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	repo_model "code.gitea.io/gitea/models/repo"
 | 
						|
 | 
						|
	"github.com/stretchr/testify/assert"
 | 
						|
)
 | 
						|
 | 
						|
func Test_fixUnitConfig_16961(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name      string
 | 
						|
		bs        string
 | 
						|
		wantFixed bool
 | 
						|
		wantErr   bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name:      "empty",
 | 
						|
			bs:        "",
 | 
						|
			wantFixed: true,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "normal: {}",
 | 
						|
			bs:        "{}",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken but fixable: &{}",
 | 
						|
			bs:        "&{}",
 | 
						|
			wantFixed: true,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken but unfixable: &{asdasd}",
 | 
						|
			bs:        "&{asdasd}",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			gotFixed, err := fixUnitConfig16961([]byte(tt.bs), &repo_model.UnitConfig{})
 | 
						|
			if (err != nil) != tt.wantErr {
 | 
						|
				t.Errorf("fixUnitConfig_16961() error = %v, wantErr %v", err, tt.wantErr)
 | 
						|
				return
 | 
						|
			}
 | 
						|
			if gotFixed != tt.wantFixed {
 | 
						|
				t.Errorf("fixUnitConfig_16961() = %v, want %v", gotFixed, tt.wantFixed)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_fixExternalWikiConfig_16961(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name      string
 | 
						|
		bs        string
 | 
						|
		expected  string
 | 
						|
		wantFixed bool
 | 
						|
		wantErr   bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name:      "normal: {\"ExternalWikiURL\":\"http://someurl\"}",
 | 
						|
			bs:        "{\"ExternalWikiURL\":\"http://someurl\"}",
 | 
						|
			expected:  "http://someurl",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken: &{http://someurl}",
 | 
						|
			bs:        "&{http://someurl}",
 | 
						|
			expected:  "http://someurl",
 | 
						|
			wantFixed: true,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken but unfixable: http://someurl",
 | 
						|
			bs:        "http://someurl",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			cfg := &repo_model.ExternalWikiConfig{}
 | 
						|
			gotFixed, err := fixExternalWikiConfig16961([]byte(tt.bs), cfg)
 | 
						|
			if (err != nil) != tt.wantErr {
 | 
						|
				t.Errorf("fixExternalWikiConfig_16961() error = %v, wantErr %v", err, tt.wantErr)
 | 
						|
				return
 | 
						|
			}
 | 
						|
			if gotFixed != tt.wantFixed {
 | 
						|
				t.Errorf("fixExternalWikiConfig_16961() = %v, want %v", gotFixed, tt.wantFixed)
 | 
						|
			}
 | 
						|
			if cfg.ExternalWikiURL != tt.expected {
 | 
						|
				t.Errorf("fixExternalWikiConfig_16961().ExternalWikiURL = %v, want %v", cfg.ExternalWikiURL, tt.expected)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_fixExternalTrackerConfig_16961(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name      string
 | 
						|
		bs        string
 | 
						|
		expected  repo_model.ExternalTrackerConfig
 | 
						|
		wantFixed bool
 | 
						|
		wantErr   bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "normal",
 | 
						|
			bs:   `{"ExternalTrackerURL":"a","ExternalTrackerFormat":"b","ExternalTrackerStyle":"c"}`,
 | 
						|
			expected: repo_model.ExternalTrackerConfig{
 | 
						|
				ExternalTrackerURL:    "a",
 | 
						|
				ExternalTrackerFormat: "b",
 | 
						|
				ExternalTrackerStyle:  "c",
 | 
						|
			},
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "broken",
 | 
						|
			bs:   "&{a b c}",
 | 
						|
			expected: repo_model.ExternalTrackerConfig{
 | 
						|
				ExternalTrackerURL:    "a",
 | 
						|
				ExternalTrackerFormat: "b",
 | 
						|
				ExternalTrackerStyle:  "c",
 | 
						|
			},
 | 
						|
			wantFixed: true,
 | 
						|
			wantErr:   false,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken - too many fields",
 | 
						|
			bs:        "&{a b c d}",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name:      "broken - wrong format",
 | 
						|
			bs:        "a b c d}",
 | 
						|
			wantFixed: false,
 | 
						|
			wantErr:   true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			cfg := &repo_model.ExternalTrackerConfig{}
 | 
						|
			gotFixed, err := fixExternalTrackerConfig16961([]byte(tt.bs), cfg)
 | 
						|
			if (err != nil) != tt.wantErr {
 | 
						|
				t.Errorf("fixExternalTrackerConfig_16961() error = %v, wantErr %v", err, tt.wantErr)
 | 
						|
				return
 | 
						|
			}
 | 
						|
			if gotFixed != tt.wantFixed {
 | 
						|
				t.Errorf("fixExternalTrackerConfig_16961() = %v, want %v", gotFixed, tt.wantFixed)
 | 
						|
			}
 | 
						|
			if cfg.ExternalTrackerFormat != tt.expected.ExternalTrackerFormat {
 | 
						|
				t.Errorf("fixExternalTrackerConfig_16961().ExternalTrackerFormat = %v, want %v", tt.expected.ExternalTrackerFormat, cfg.ExternalTrackerFormat)
 | 
						|
			}
 | 
						|
			if cfg.ExternalTrackerStyle != tt.expected.ExternalTrackerStyle {
 | 
						|
				t.Errorf("fixExternalTrackerConfig_16961().ExternalTrackerStyle = %v, want %v", tt.expected.ExternalTrackerStyle, cfg.ExternalTrackerStyle)
 | 
						|
			}
 | 
						|
			if cfg.ExternalTrackerURL != tt.expected.ExternalTrackerURL {
 | 
						|
				t.Errorf("fixExternalTrackerConfig_16961().ExternalTrackerURL = %v, want %v", tt.expected.ExternalTrackerURL, cfg.ExternalTrackerURL)
 | 
						|
			}
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_fixPullRequestsConfig_16961(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name      string
 | 
						|
		bs        string
 | 
						|
		expected  repo_model.PullRequestsConfig
 | 
						|
		wantFixed bool
 | 
						|
		wantErr   bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "normal",
 | 
						|
			bs:   `{"IgnoreWhitespaceConflicts":false,"AllowMerge":false,"AllowRebase":false,"AllowRebaseMerge":false,"AllowSquash":false,"AllowManualMerge":false,"AutodetectManualMerge":false,"DefaultDeleteBranchAfterMerge":false,"DefaultMergeStyle":""}`,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "broken - 1.14",
 | 
						|
			bs:   `&{%!s(bool=false) %!s(bool=true) %!s(bool=true) %!s(bool=true) %!s(bool=true) %!s(bool=false) %!s(bool=false)}`,
 | 
						|
			expected: repo_model.PullRequestsConfig{
 | 
						|
				IgnoreWhitespaceConflicts: false,
 | 
						|
				AllowMerge:                true,
 | 
						|
				AllowRebase:               true,
 | 
						|
				AllowRebaseMerge:          true,
 | 
						|
				AllowSquash:               true,
 | 
						|
				AllowManualMerge:          false,
 | 
						|
				AutodetectManualMerge:     false,
 | 
						|
			},
 | 
						|
			wantFixed: true,
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "broken - 1.15",
 | 
						|
			bs:   `&{%!s(bool=false) %!s(bool=true) %!s(bool=true) %!s(bool=true) %!s(bool=true) %!s(bool=false) %!s(bool=false) %!s(bool=false) merge}`,
 | 
						|
			expected: repo_model.PullRequestsConfig{
 | 
						|
				AllowMerge:        true,
 | 
						|
				AllowRebase:       true,
 | 
						|
				AllowRebaseMerge:  true,
 | 
						|
				AllowSquash:       true,
 | 
						|
				DefaultMergeStyle: repo_model.MergeStyleMerge,
 | 
						|
			},
 | 
						|
			wantFixed: true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			cfg := &repo_model.PullRequestsConfig{}
 | 
						|
			gotFixed, err := fixPullRequestsConfig16961([]byte(tt.bs), cfg)
 | 
						|
			if (err != nil) != tt.wantErr {
 | 
						|
				t.Errorf("fixPullRequestsConfig_16961() error = %v, wantErr %v", err, tt.wantErr)
 | 
						|
				return
 | 
						|
			}
 | 
						|
			if gotFixed != tt.wantFixed {
 | 
						|
				t.Errorf("fixPullRequestsConfig_16961() = %v, want %v", gotFixed, tt.wantFixed)
 | 
						|
			}
 | 
						|
			assert.EqualValues(t, &tt.expected, cfg)
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func Test_fixIssuesConfig_16961(t *testing.T) {
 | 
						|
	tests := []struct {
 | 
						|
		name      string
 | 
						|
		bs        string
 | 
						|
		expected  repo_model.IssuesConfig
 | 
						|
		wantFixed bool
 | 
						|
		wantErr   bool
 | 
						|
	}{
 | 
						|
		{
 | 
						|
			name: "normal",
 | 
						|
			bs:   `{"EnableTimetracker":true,"AllowOnlyContributorsToTrackTime":true,"EnableDependencies":true}`,
 | 
						|
			expected: repo_model.IssuesConfig{
 | 
						|
				EnableTimetracker:                true,
 | 
						|
				AllowOnlyContributorsToTrackTime: true,
 | 
						|
				EnableDependencies:               true,
 | 
						|
			},
 | 
						|
		},
 | 
						|
		{
 | 
						|
			name: "broken",
 | 
						|
			bs:   `&{%!s(bool=true) %!s(bool=true) %!s(bool=true)}`,
 | 
						|
			expected: repo_model.IssuesConfig{
 | 
						|
				EnableTimetracker:                true,
 | 
						|
				AllowOnlyContributorsToTrackTime: true,
 | 
						|
				EnableDependencies:               true,
 | 
						|
			},
 | 
						|
			wantFixed: true,
 | 
						|
		},
 | 
						|
	}
 | 
						|
	for _, tt := range tests {
 | 
						|
		t.Run(tt.name, func(t *testing.T) {
 | 
						|
			cfg := &repo_model.IssuesConfig{}
 | 
						|
			gotFixed, err := fixIssuesConfig16961([]byte(tt.bs), cfg)
 | 
						|
			if (err != nil) != tt.wantErr {
 | 
						|
				t.Errorf("fixIssuesConfig_16961() error = %v, wantErr %v", err, tt.wantErr)
 | 
						|
				return
 | 
						|
			}
 | 
						|
			if gotFixed != tt.wantFixed {
 | 
						|
				t.Errorf("fixIssuesConfig_16961() = %v, want %v", gotFixed, tt.wantFixed)
 | 
						|
			}
 | 
						|
			assert.EqualValues(t, &tt.expected, cfg)
 | 
						|
		})
 | 
						|
	}
 | 
						|
}
 |