// Licensed to the .NET Foundation under one or more agreements. // The .NET Foundation licenses this file to you under the MIT license. // See the LICENSE file in the project root for more information. using System; using System.Collections.Generic; using System.Text; /// /// UInt64.System.IConvertible.ToSingle /// public class UInt64IConvertibleToSingle { public static int Main() { UInt64IConvertibleToSingle ui64ictSingle = new UInt64IConvertibleToSingle(); TestLibrary.TestFramework.BeginTestCase("UInt64IConvertibleToSingle"); if (ui64ictSingle.RunTests()) { TestLibrary.TestFramework.EndTestCase(); TestLibrary.TestFramework.LogInformation("PASS"); return 100; } else { TestLibrary.TestFramework.EndTestCase(); TestLibrary.TestFramework.LogInformation("FAIL"); return 0; } } public bool RunTests() { bool retVal = true; TestLibrary.TestFramework.LogInformation("[Positive]"); retVal = PosTest1() && retVal; retVal = PosTest2() && retVal; retVal = PosTest3() && retVal; return retVal; } #region PositiveTest public bool PosTest1() { bool retVal = true; TestLibrary.TestFramework.BeginScenario("PosTest1:UInt64 MinValue to SByte"); try { UInt64 uintA = UInt64.MinValue; IConvertible iConvert = (IConvertible)(uintA); Single single = iConvert.ToSingle(null); if ((ulong)single != uintA) { TestLibrary.TestFramework.LogError("001", "the ActualResult is not the ExpectResult"); retVal = false; } } catch (Exception e) { TestLibrary.TestFramework.LogError("002", "Unexpected exception: " + e); retVal = false; } return retVal; } public bool PosTest2() { bool retVal = true; TestLibrary.TestFramework.BeginScenario("PosTest2:Convert a random Uint64 less than 10000000 to float"); try { UInt64 uintA = this.GetInt64(0, 10000000); IConvertible iConvert = (IConvertible)(uintA); Single single = iConvert.ToSingle(null); if (single != (float)uintA) { TestLibrary.TestFramework.LogError("003", "the ActualResult is not the ExpectResult"); retVal = false; } } catch (Exception e) { TestLibrary.TestFramework.LogError("004", "Unexpected exception: " + e); retVal = false; } return retVal; } public bool PosTest3() { bool retVal = true; TestLibrary.TestFramework.BeginScenario("PosTest3:Convert a random UInt64 between 10000000 UInt64.MaxValue to Single"); try { UInt64 uintA = this.GetInt64(10000000, UInt64.MaxValue); IConvertible iConvert = (IConvertible)(uintA); Single single = iConvert.ToSingle(null); } catch (Exception e) { TestLibrary.TestFramework.LogError("005", "Unexpected exception: " + e); retVal = false; } return retVal; } #endregion #region NegativeTest #endregion #region ForTestObject private UInt64 GetInt64(UInt64 minValue, UInt64 maxValue) { try { if (minValue == maxValue) { return minValue; } if (minValue < maxValue) { return minValue + (UInt64)TestLibrary.Generator.GetInt64(-55) % (maxValue - minValue); } } catch { throw; } return minValue; } #endregion }