chore: replace gopkg.in/yaml.v3 with go.yaml.in/yaml/v3 (#8956)
- gopkg.in/yaml.v3 is archived and unmaintained - go.yaml.in/yaml/v3 is a compatible fork under the umbrella of https://yaml.org/ ### Tests There is no need for more tests than already provided: it is like an upgrade to a minor version, only from a fork. I browsed the changes and there are some bug fixes. They all seem reasonably minimal. It is not one of those forks that went crazy with breaking changes 😁 And there is a non zero chance that [a bug that matters to Forgejo Actions](https://github.com/yaml/go-yaml/issues/76) is fixed there. It is rare and can wait but it did happen on Codeberg. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/8956 Reviewed-by: oliverpool <oliverpool@noreply.codeberg.org> Co-authored-by: Earl Warren <contact@earl-warren.org> Co-committed-by: Earl Warren <contact@earl-warren.org>
This commit is contained in:
		
					parent
					
						
							
								58c27fda89
							
						
					
				
			
			
				commit
				
					
						af5df243d4
					
				
			
		
					 26 changed files with 31 additions and 23 deletions
				
			
		
							
								
								
									
										5
									
								
								assets/go-licenses.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										5
									
								
								assets/go-licenses.json
									
										
									
										generated
									
									
									
								
							|  | @ -1064,6 +1064,11 @@ | ||||||
|     "path": "go.uber.org/zap/exp/zapslog/LICENSE", |     "path": "go.uber.org/zap/exp/zapslog/LICENSE", | ||||||
|     "licenseText": "Copyright (c) 2016-2024 Uber Technologies, Inc.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n" |     "licenseText": "Copyright (c) 2016-2024 Uber Technologies, Inc.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n" | ||||||
|   }, |   }, | ||||||
|  |   { | ||||||
|  |     "name": "go.yaml.in/yaml/v3", | ||||||
|  |     "path": "go.yaml.in/yaml/v3/LICENSE", | ||||||
|  |     "licenseText": "\nThis project is covered by two different licenses: MIT and Apache.\n\n#### MIT License ####\n\nThe following files were ported to Go from C files of libyaml, and thus\nare still covered by their original MIT license, with the additional\ncopyright staring in 2011 when the project was ported over:\n\n    apic.go emitterc.go parserc.go readerc.go scannerc.go\n    writerc.go yamlh.go yamlprivateh.go\n\nCopyright (c) 2006-2010 Kirill Simonov\nCopyright (c) 2006-2011 Kirill Simonov\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of\nthis software and associated documentation files (the \"Software\"), to deal in\nthe Software without restriction, including without limitation the rights to\nuse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies\nof the Software, and to permit persons to whom the Software is furnished to do\nso, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n### Apache License ###\n\nAll the remaining project files are covered by the Apache license:\n\nCopyright (c) 2011-2019 Canonical Ltd\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n" | ||||||
|  |   }, | ||||||
|   { |   { | ||||||
|     "name": "go4.org", |     "name": "go4.org", | ||||||
|     "path": "go4.org/LICENSE", |     "path": "go4.org/LICENSE", | ||||||
|  |  | ||||||
							
								
								
									
										1
									
								
								go.mod
									
										
									
									
									
								
							
							
						
						
									
										1
									
								
								go.mod
									
										
									
									
									
								
							|  | @ -98,6 +98,7 @@ require ( | ||||||
| 	github.com/yuin/goldmark-highlighting/v2 v2.0.0-20230729083705-37449abec8cc | 	github.com/yuin/goldmark-highlighting/v2 v2.0.0-20230729083705-37449abec8cc | ||||||
| 	gitlab.com/gitlab-org/api/client-go v0.130.1 | 	gitlab.com/gitlab-org/api/client-go v0.130.1 | ||||||
| 	go.uber.org/mock v0.6.0 | 	go.uber.org/mock v0.6.0 | ||||||
|  | 	go.yaml.in/yaml/v3 v3.0.4 | ||||||
| 	golang.org/x/crypto v0.41.0 | 	golang.org/x/crypto v0.41.0 | ||||||
| 	golang.org/x/image v0.30.0 | 	golang.org/x/image v0.30.0 | ||||||
| 	golang.org/x/net v0.43.0 | 	golang.org/x/net v0.43.0 | ||||||
|  |  | ||||||
							
								
								
									
										2
									
								
								go.sum
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								go.sum
									
										
									
									
									
								
							|  | @ -649,6 +649,8 @@ go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8= | ||||||
| go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E= | go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E= | ||||||
| go.uber.org/zap/exp v0.3.0 h1:6JYzdifzYkGmTdRR59oYH+Ng7k49H9qVpWwNSsGJj3U= | go.uber.org/zap/exp v0.3.0 h1:6JYzdifzYkGmTdRR59oYH+Ng7k49H9qVpWwNSsGJj3U= | ||||||
| go.uber.org/zap/exp v0.3.0/go.mod h1:5I384qq7XGxYyByIhHm6jg5CHkGY0nsTfbDLgDDlgJQ= | go.uber.org/zap/exp v0.3.0/go.mod h1:5I384qq7XGxYyByIhHm6jg5CHkGY0nsTfbDLgDDlgJQ= | ||||||
|  | go.yaml.in/yaml/v3 v3.0.4 h1:tfq32ie2Jv2UxXFdLJdh3jXuOzWiL1fo0bu/FbuKpbc= | ||||||
|  | go.yaml.in/yaml/v3 v3.0.4/go.mod h1:DhzuOOF2ATzADvBadXxruRBLzYTpT36CKvDb3+aBEFg= | ||||||
| go4.org v0.0.0-20230225012048-214862532bf5 h1:nifaUDeh+rPaBCMPMQHZmvJf+QdpLFnuQPwx+LxVmtc= | go4.org v0.0.0-20230225012048-214862532bf5 h1:nifaUDeh+rPaBCMPMQHZmvJf+QdpLFnuQPwx+LxVmtc= | ||||||
| go4.org v0.0.0-20230225012048-214862532bf5/go.mod h1:F57wTi5Lrj6WLyswp5EYV1ncrEbFGHD4hhz6S1ZYeaU= | go4.org v0.0.0-20230225012048-214862532bf5/go.mod h1:F57wTi5Lrj6WLyswp5EYV1ncrEbFGHD4hhz6S1ZYeaU= | ||||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"forgejo.org/modules/container" | 	"forgejo.org/modules/container" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type insertSQL struct { | type insertSQL struct { | ||||||
|  |  | ||||||
|  | @ -15,7 +15,7 @@ import ( | ||||||
| 	api "forgejo.org/modules/structs" | 	api "forgejo.org/modules/structs" | ||||||
| 	"forgejo.org/modules/util" | 	"forgejo.org/modules/util" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // CouldBe indicates a file with the filename could be a template, | // CouldBe indicates a file with the filename could be a template, | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"forgejo.org/modules/options" | 	"forgejo.org/modules/options" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type labelFile struct { | type labelFile struct { | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ package markdown | ||||||
| import ( | import ( | ||||||
| 	"github.com/yuin/goldmark/ast" | 	"github.com/yuin/goldmark/ast" | ||||||
| 	east "github.com/yuin/goldmark/extension/ast" | 	east "github.com/yuin/goldmark/extension/ast" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func nodeToTable(meta *yaml.Node) ast.Node { | func nodeToTable(meta *yaml.Node) ast.Node { | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ import ( | ||||||
| 	"unicode" | 	"unicode" | ||||||
| 	"unicode/utf8" | 	"unicode/utf8" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func isYAMLSeparator(line []byte) bool { | func isYAMLSeparator(line []byte) bool { | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ import ( | ||||||
| 	"forgejo.org/modules/markup" | 	"forgejo.org/modules/markup" | ||||||
| 
 | 
 | ||||||
| 	"github.com/yuin/goldmark/ast" | 	"github.com/yuin/goldmark/ast" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // RenderConfig represents rendering configuration for this file | // RenderConfig represents rendering configuration for this file | ||||||
|  |  | ||||||
|  | @ -7,7 +7,7 @@ import ( | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"testing" | 	"testing" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestRenderConfig_UnmarshalYAML(t *testing.T) { | func TestRenderConfig_UnmarshalYAML(t *testing.T) { | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ import ( | ||||||
| 	"forgejo.org/modules/log" | 	"forgejo.org/modules/log" | ||||||
| 
 | 
 | ||||||
| 	"github.com/santhosh-tekuri/jsonschema/v6" | 	"github.com/santhosh-tekuri/jsonschema/v6" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // Load project data from file, with optional validation | // Load project data from file, with optional validation | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ package optional | ||||||
| import ( | import ( | ||||||
| 	"forgejo.org/modules/json" | 	"forgejo.org/modules/json" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func (o *Option[T]) UnmarshalJSON(data []byte) error { | func (o *Option[T]) UnmarshalJSON(data []byte) error { | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type testSerializationStruct struct { | type testSerializationStruct struct { | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ import ( | ||||||
| 	"forgejo.org/modules/validation" | 	"forgejo.org/modules/validation" | ||||||
| 
 | 
 | ||||||
| 	"github.com/hashicorp/go-version" | 	"github.com/hashicorp/go-version" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var ( | var ( | ||||||
|  |  | ||||||
|  | @ -14,7 +14,7 @@ import ( | ||||||
| 	"forgejo.org/modules/validation" | 	"forgejo.org/modules/validation" | ||||||
| 
 | 
 | ||||||
| 	"github.com/hashicorp/go-version" | 	"github.com/hashicorp/go-version" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var ( | var ( | ||||||
|  |  | ||||||
|  | @ -13,7 +13,7 @@ import ( | ||||||
| 	"forgejo.org/modules/util" | 	"forgejo.org/modules/util" | ||||||
| 	"forgejo.org/modules/validation" | 	"forgejo.org/modules/validation" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var ( | var ( | ||||||
|  |  | ||||||
|  | @ -10,7 +10,7 @@ import ( | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // StateType issue state type | // StateType issue state type | ||||||
|  |  | ||||||
|  | @ -8,7 +8,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestIssueTemplate_Type(t *testing.T) { | func TestIssueTemplate_Type(t *testing.T) { | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ import ( | ||||||
| 	"forgejo.org/services/context" | 	"forgejo.org/services/context" | ||||||
| 	packages_service "forgejo.org/services/packages" | 	packages_service "forgejo.org/services/packages" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func apiError(ctx *context.Context, status int, obj any) { | func apiError(ctx *context.Context, status int, obj any) { | ||||||
|  |  | ||||||
|  | @ -16,7 +16,7 @@ import ( | ||||||
| 	"forgejo.org/modules/log" | 	"forgejo.org/modules/log" | ||||||
| 	api "forgejo.org/modules/structs" | 	api "forgejo.org/modules/structs" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // templateDirCandidates issue templates directory | // templateDirCandidates issue templates directory | ||||||
|  |  | ||||||
|  | @ -25,7 +25,7 @@ import ( | ||||||
| 	"forgejo.org/modules/structs" | 	"forgejo.org/modules/structs" | ||||||
| 
 | 
 | ||||||
| 	"github.com/google/uuid" | 	"github.com/google/uuid" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| var _ base.Uploader = &RepositoryDumper{} | var _ base.Uploader = &RepositoryDumper{} | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	base "forgejo.org/modules/migration" | 	base "forgejo.org/modules/migration" | ||||||
| 
 | 
 | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // RepositoryRestorer implements an Downloader from the local directory | // RepositoryRestorer implements an Downloader from the local directory | ||||||
|  |  | ||||||
|  | @ -26,7 +26,7 @@ import ( | ||||||
| 	"forgejo.org/services/webhook/shared" | 	"forgejo.org/services/webhook/shared" | ||||||
| 
 | 
 | ||||||
| 	"code.forgejo.org/go-chi/binding" | 	"code.forgejo.org/go-chi/binding" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type BuildsHandler struct{} | type BuildsHandler struct{} | ||||||
|  |  | ||||||
|  | @ -17,7 +17,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func createIssueConfigInDirectory(t *testing.T, user *user_model.User, repo *repo_model.Repository, dir string, issueConfig map[string]any) { | func createIssueConfigInDirectory(t *testing.T, user *user_model.User, repo *repo_model.Repository, dir string, issueConfig map[string]any) { | ||||||
|  |  | ||||||
|  | @ -22,7 +22,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestPackageHelm(t *testing.T) { | func TestPackageHelm(t *testing.T) { | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ import ( | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| 	"gopkg.in/yaml.v3" | 	"go.yaml.in/yaml/v3" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestDumpRestore(t *testing.T) { | func TestDumpRestore(t *testing.T) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Earl Warren
				Earl Warren