mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	Merge branch 'main' into feature/bots
This commit is contained in:
		| @@ -5,8 +5,10 @@ package nuget | ||||
|  | ||||
| import ( | ||||
| 	"archive/zip" | ||||
| 	"bytes" | ||||
| 	"encoding/xml" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"io" | ||||
| 	"path/filepath" | ||||
| 	"regexp" | ||||
| @@ -182,7 +184,23 @@ func ParseNuspecMetaData(r io.Reader) (*Package, error) { | ||||
| 	return &Package{ | ||||
| 		PackageType: packageType, | ||||
| 		ID:          p.Metadata.ID, | ||||
| 		Version:     v.String(), | ||||
| 		Version:     toNormalizedVersion(v), | ||||
| 		Metadata:    m, | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
| // https://learn.microsoft.com/en-us/nuget/concepts/package-versioning#normalized-version-numbers | ||||
| // https://github.com/NuGet/NuGet.Client/blob/dccbd304b11103e08b97abf4cf4bcc1499d9235a/src/NuGet.Core/NuGet.Versioning/VersionFormatter.cs#L121 | ||||
| func toNormalizedVersion(v *version.Version) string { | ||||
| 	var buf bytes.Buffer | ||||
| 	segments := v.Segments64() | ||||
| 	fmt.Fprintf(&buf, "%d.%d.%d", segments[0], segments[1], segments[2]) | ||||
| 	if len(segments) > 3 && segments[3] > 0 { | ||||
| 		fmt.Fprintf(&buf, ".%d", segments[3]) | ||||
| 	} | ||||
| 	pre := v.Prerelease() | ||||
| 	if pre != "" { | ||||
| 		fmt.Fprint(&buf, "-", pre) | ||||
| 	} | ||||
| 	return buf.String() | ||||
| } | ||||
|   | ||||
| @@ -146,6 +146,19 @@ func TestParseNuspecMetaData(t *testing.T) { | ||||
| 		assert.Len(t, deps, 1) | ||||
| 		assert.Equal(t, dependencyID, deps[0].ID) | ||||
| 		assert.Equal(t, dependencyVersion, deps[0].Version) | ||||
|  | ||||
| 		t.Run("NormalizedVersion", func(t *testing.T) { | ||||
| 			np, err := ParseNuspecMetaData(strings.NewReader(`<?xml version="1.0" encoding="utf-8"?> | ||||
| <package xmlns="http://schemas.microsoft.com/packaging/2013/05/nuspec.xsd"> | ||||
|   <metadata> | ||||
| 	<id>test</id> | ||||
| 	<version>1.04.5.2.5-rc.1+metadata</version> | ||||
|   </metadata> | ||||
| </package>`)) | ||||
| 			assert.NoError(t, err) | ||||
| 			assert.NotNil(t, np) | ||||
| 			assert.Equal(t, "1.4.5.2-rc.1", np.Version) | ||||
| 		}) | ||||
| 	}) | ||||
|  | ||||
| 	t.Run("Symbols Package", func(t *testing.T) { | ||||
|   | ||||
| @@ -82,6 +82,7 @@ var ( | ||||
| 			DefaultMergeMessageOfficialApproversOnly bool | ||||
| 			PopulateSquashCommentWithCommitMessages  bool | ||||
| 			AddCoCommitterTrailers                   bool | ||||
| 			TestConflictingPatchesWithGitApply       bool | ||||
| 		} `ini:"repository.pull-request"` | ||||
|  | ||||
| 		// Issue Setting | ||||
| @@ -204,6 +205,7 @@ var ( | ||||
| 			DefaultMergeMessageOfficialApproversOnly bool | ||||
| 			PopulateSquashCommentWithCommitMessages  bool | ||||
| 			AddCoCommitterTrailers                   bool | ||||
| 			TestConflictingPatchesWithGitApply       bool | ||||
| 		}{ | ||||
| 			WorkInProgressPrefixes: []string{"WIP:", "[WIP]"}, | ||||
| 			// Same as GitHub. See | ||||
|   | ||||
| @@ -12,8 +12,13 @@ import ( | ||||
| // TimeStamp defines a timestamp | ||||
| type TimeStamp int64 | ||||
|  | ||||
| // mock is NOT concurrency-safe!! | ||||
| var mock time.Time | ||||
| var ( | ||||
| 	// mock is NOT concurrency-safe!! | ||||
| 	mock time.Time | ||||
|  | ||||
| 	// Used for IsZero, to check if timestamp is the zero time instant. | ||||
| 	timeZeroUnix = time.Time{}.Unix() | ||||
| ) | ||||
|  | ||||
| // Set sets the time to a mocked time.Time | ||||
| func Set(now time.Time) { | ||||
| @@ -102,5 +107,5 @@ func (ts TimeStamp) FormatDate() string { | ||||
|  | ||||
| // IsZero is zero time | ||||
| func (ts TimeStamp) IsZero() bool { | ||||
| 	return int64(ts) == 0 | ||||
| 	return int64(ts) == 0 || int64(ts) == timeZeroUnix | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user