Add fallback for windows platforms without osversion
The background for this change: 1. Windows host-process containers do not have an OS version set 2. Buildx v0.10 started pushing manifest lists by default, but it never has the OSVersion in the platform data (not that there is any way to specify what particular OS version you want). The change means that containerd cannot run images created with the new buildx on Windows because there is no matching OSVersion in the list of manifests. Signed-off-by: Brian Goff <cpuguy83@gmail.com>
This commit is contained in:
		| @@ -50,7 +50,10 @@ func (m windowsmatcher) Match(p specs.Platform) bool { | |||||||
| 	match := m.defaultMatcher.Match(p) | 	match := m.defaultMatcher.Match(p) | ||||||
|  |  | ||||||
| 	if match && m.OS == "windows" { | 	if match && m.OS == "windows" { | ||||||
| 		return strings.HasPrefix(p.OSVersion, m.osVersionPrefix) && m.defaultMatcher.Match(p) | 		if strings.HasPrefix(p.OSVersion, m.osVersionPrefix) { | ||||||
|  | 			return true | ||||||
|  | 		} | ||||||
|  | 		return p.OSVersion == "" | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	return match | 	return match | ||||||
|   | |||||||
| @@ -128,7 +128,7 @@ func TestMatchComparerMatch_WCOW(t *testing.T) { | |||||||
| 				Architecture: "amd64", | 				Architecture: "amd64", | ||||||
| 				OS:           "windows", | 				OS:           "windows", | ||||||
| 			}, | 			}, | ||||||
| 			match: false, | 			match: true, | ||||||
| 		}, | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			platform: imagespec.Platform{ | 			platform: imagespec.Platform{ | ||||||
| @@ -251,11 +251,11 @@ func TestMatchComparerLess(t *testing.T) { | |||||||
| 		{ | 		{ | ||||||
| 			Architecture: "amd64", | 			Architecture: "amd64", | ||||||
| 			OS:           "windows", | 			OS:           "windows", | ||||||
| 			OSVersion:    "10.0.17764.1", |  | ||||||
| 		}, | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			Architecture: "amd64", | 			Architecture: "amd64", | ||||||
| 			OS:           "windows", | 			OS:           "windows", | ||||||
|  | 			OSVersion:    "10.0.17764.1", | ||||||
| 		}, | 		}, | ||||||
| 		{ | 		{ | ||||||
| 			Architecture: "amd64", | 			Architecture: "amd64", | ||||||
|   | |||||||
| @@ -19,9 +19,23 @@ package platforms | |||||||
| import ( | import ( | ||||||
| 	"testing" | 	"testing" | ||||||
|  |  | ||||||
|  | 	specs "github.com/opencontainers/image-spec/specs-go/v1" | ||||||
| 	"github.com/stretchr/testify/require" | 	"github.com/stretchr/testify/require" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func TestNormalize(t *testing.T) { | func TestNormalize(t *testing.T) { | ||||||
| 	require.Equal(t, DefaultSpec(), Normalize(DefaultSpec())) | 	require.Equal(t, DefaultSpec(), Normalize(DefaultSpec())) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func TestFallbackOnOSVersion(t *testing.T) { | ||||||
|  | 	p := specs.Platform{ | ||||||
|  | 		OS:           "windows", | ||||||
|  | 		Architecture: "amd64", | ||||||
|  | 		OSVersion:    "99.99.99.99", | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	other := specs.Platform{OS: p.OS, Architecture: p.Architecture} | ||||||
|  |  | ||||||
|  | 	m := NewMatcher(p) | ||||||
|  | 	require.True(t, m.Match(other)) | ||||||
|  | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Brian Goff
					Brian Goff