diff --git a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/ref/System.Runtime.InteropServices.RuntimeInformation.cs b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/ref/System.Runtime.InteropServices.RuntimeInformation.cs index aae34f0b6a70e..92264d9fe8332 100644 --- a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/ref/System.Runtime.InteropServices.RuntimeInformation.cs +++ b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/ref/System.Runtime.InteropServices.RuntimeInformation.cs @@ -18,10 +18,14 @@ public enum Architecture { private readonly object _dummy; private readonly int _dummyPrimitive; + public static System.Runtime.InteropServices.OSPlatform Android { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform Browser { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform FreeBSD { get { throw null; } } + public static System.Runtime.InteropServices.OSPlatform iOS { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform Linux { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform OSX { get { throw null; } } + public static System.Runtime.InteropServices.OSPlatform tvOS { get { throw null; } } + public static System.Runtime.InteropServices.OSPlatform watchOS { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform Windows { get { throw null; } } public static System.Runtime.InteropServices.OSPlatform Create(string osPlatform) { throw null; } public override bool Equals(object? obj) { throw null; } @@ -33,11 +37,11 @@ public enum Architecture } public static partial class RuntimeInformation { - public static string RuntimeIdentifier { get { throw null; } } public static string FrameworkDescription { get { throw null; } } public static System.Runtime.InteropServices.Architecture OSArchitecture { get { throw null; } } public static string OSDescription { get { throw null; } } public static System.Runtime.InteropServices.Architecture ProcessArchitecture { get { throw null; } } + public static string RuntimeIdentifier { get { throw null; } } public static bool IsOSPlatform(System.Runtime.InteropServices.OSPlatform osPlatform) { throw null; } } } diff --git a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/src/System/Runtime/InteropServices/RuntimeInformation/OSPlatform.cs b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/src/System/Runtime/InteropServices/RuntimeInformation/OSPlatform.cs index b4e860dd0a8c5..39f956e164bd0 100644 --- a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/src/System/Runtime/InteropServices/RuntimeInformation/OSPlatform.cs +++ b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/src/System/Runtime/InteropServices/RuntimeInformation/OSPlatform.cs @@ -7,6 +7,8 @@ namespace System.Runtime.InteropServices { private readonly string _osPlatform; + public static OSPlatform Android { get; } = new OSPlatform("ANDROID"); + public static OSPlatform Browser { get; } = new OSPlatform("BROWSER"); public static OSPlatform FreeBSD { get; } = new OSPlatform("FREEBSD"); @@ -15,6 +17,12 @@ namespace System.Runtime.InteropServices public static OSPlatform OSX { get; } = new OSPlatform("OSX"); + public static OSPlatform iOS { get; } = new OSPlatform("IOS"); + + public static OSPlatform tvOS { get; } = new OSPlatform("TVOS"); + + public static OSPlatform watchOS { get; } = new OSPlatform("WATCHOS"); + public static OSPlatform Windows { get; } = new OSPlatform("WINDOWS"); private OSPlatform(string osPlatform) diff --git a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/tests/CheckPlatformTests.cs b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/tests/CheckPlatformTests.cs index 936b58e612e07..1264c5c0d850a 100644 --- a/src/libraries/System.Runtime.InteropServices.RuntimeInformation/tests/CheckPlatformTests.cs +++ b/src/libraries/System.Runtime.InteropServices.RuntimeInformation/tests/CheckPlatformTests.cs @@ -65,6 +65,82 @@ public void CheckOSX() Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.FreeBSD)); } + [Fact, PlatformSpecific(TestPlatforms.iOS)] // Tests RuntimeInformation OS platform + public void CheckiOS() + { + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.iOS)); + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Create("IOS"))); + + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("FREEBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NETBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NetBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("netbsd"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("osx"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("mac"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("DARWIN"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("MACOSX"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Linux)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Windows)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.FreeBSD)); + } + + [Fact, PlatformSpecific(TestPlatforms.tvOS)] // Tests RuntimeInformation OS platform + public void ChecktvOS() + { + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.tvOS)); + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Create("TVOS"))); + + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("FREEBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NETBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NetBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("netbsd"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("osx"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("mac"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("DARWIN"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("MACOSX"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Linux)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Windows)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.FreeBSD)); + } + + [Fact, PlatformSpecific(TestPlatforms.Android)] // Tests RuntimeInformation OS platform + public void CheckAndroid() + { + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Android)); + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Create("ANDROID"))); + + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("FREEBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NETBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NetBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("netbsd"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("osx"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("mac"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("DARWIN"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("MACOSX"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Linux)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Windows)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.FreeBSD)); + } + + [Fact, PlatformSpecific(TestPlatforms.Browser)] // Tests RuntimeInformation OS platform + public void CheckBrowser() + { + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Browser)); + Assert.True(RuntimeInformation.IsOSPlatform(OSPlatform.Create("BROWSER"))); + + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("FREEBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NETBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("NetBSD"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("netbsd"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("osx"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("mac"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("DARWIN"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Create("MACOSX"))); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Linux)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.Windows)); + Assert.False(RuntimeInformation.IsOSPlatform(OSPlatform.FreeBSD)); + } + [Fact, PlatformSpecific(TestPlatforms.Windows)] // Tests RuntimeInformation OS platform public void CheckWindows() {