public void GetReadData_CannotHandleNonNumericStrings_ThrowsException(string inputData) { // Arrange var cut = new CsvConverterDefaultFloat(); cut.Initialize(null, new DefaultTypeConverterFactory()); // Act float actual = (float)cut.GetReadData(typeof(float), inputData, "Column1", 1, 1); // Assert Assert.Fail("Exception should be thrown when invalid values are passed into the parser!"); }
public void GetReadData_CanConvertNonNullableFloatsWithoutAnAttribute_ValuesConverted(string inputData, string expectedAsString) { // Arrange float expected = float.Parse(expectedAsString); var cut = new CsvConverterDefaultFloat(); cut.Initialize(null, new DefaultTypeConverterFactory()); // Act float actual = (float)cut.GetReadData(typeof(float), inputData, "Column1", 1, 1); // Assert Assert.AreEqual(expected, actual); }
public void GetReadData_CanRoundToGivenPrecision_NumberRoundedProperly( string inputData, string expectedAsString, int numberOfDecimalPlaces, bool allowRounding) { // Arrange float expected = float.Parse(expectedAsString); var cut = new CsvConverterDefaultFloat(); cut.AllowRounding = allowRounding; cut.Initialize(null, new DefaultTypeConverterFactory()); cut.NumberOfDecimalPlaces = numberOfDecimalPlaces; // Act float actual = (float)cut.GetReadData(typeof(float), inputData, "Column1", 1, 1); // Assert Assert.AreEqual(expected, actual); }
[DataRow(.20f, "20%", "P0")] // Differs between windows 10 (20%) & windows 7 (20 %) public void GetWriteData_CanConvertNullableFloat_FloatConverted(float?inputData, string expectedData, string formatData) { // Arrange var cut = new CsvConverterDefaultFloat(); cut.StringFormat = formatData; // Act string actualData = cut.GetWriteData(typeof(float?), inputData, "Column1", 1, 1); // Windows 10 (2,000%) & Windows 7 (2,000 %) format percentages slightly differently // So remove spaces before comparing if (formatData != null && formatData.StartsWith("P")) { actualData = actualData.Replace(" ", ""); } // Assert Assert.AreEqual(expectedData, actualData); }