-
Notifications
You must be signed in to change notification settings - Fork 32
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Шестопалов Андрей #18
base: master
Are you sure you want to change the base?
Changes from 2 commits
8a9c996
f62673c
47755b4
7877e6d
b22b0ac
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,25 +7,266 @@ namespace HomeExercise.Tasks.NumberValidator; | |
[TestFixture] | ||
public class NumberValidatorTests | ||
{ | ||
[Test] | ||
public void Test() | ||
{ | ||
Assert.Throws<ArgumentException>(() => new NumberValidator(-1, 2, true)); | ||
Assert.DoesNotThrow(() => new NumberValidator(1, 0, true)); | ||
Assert.Throws<ArgumentException>(() => new NumberValidator(-1, 2, false)); | ||
Assert.DoesNotThrow(() => new NumberValidator(1, 0, true)); | ||
|
||
ClassicAssert.IsTrue(new NumberValidator(17, 2, true).IsValidNumber("0.0")); | ||
ClassicAssert.IsTrue(new NumberValidator(17, 2, true).IsValidNumber("0")); | ||
ClassicAssert.IsTrue(new NumberValidator(17, 2, true).IsValidNumber("0.0")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("00.00")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("-0.00")); | ||
ClassicAssert.IsTrue(new NumberValidator(17, 2, true).IsValidNumber("0.0")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("+0.00")); | ||
ClassicAssert.IsTrue(new NumberValidator(4, 2, true).IsValidNumber("+1.23")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("+1.23")); | ||
ClassicAssert.IsFalse(new NumberValidator(17, 2, true).IsValidNumber("0.000")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("-1.23")); | ||
ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("a.sd")); | ||
#region InitializationTests | ||
[TestCase(0)] | ||
[TestCase(-1)] | ||
[TestCase(-100)] | ||
[TestCase(-9999)] | ||
[Category("InitializationTests")] | ||
public void Constructor_PrecisionIsNotPositive_ThrowArgumentException(int precision) | ||
{ | ||
TestDelegate action = () => new NumberValidator(precision); | ||
|
||
var ex = Assert.Throws<ArgumentException>(action, | ||
$"Failed: Expected ArgumentException for precision = {precision}"); | ||
|
||
Assert.That(ex.Message, Is.EqualTo("precision must be a positive number"), | ||
This comment was marked as resolved.
Sorry, something went wrong. |
||
"Failed: Expected specific message for precision is not positive"); | ||
} | ||
|
||
[TestCase(-1)] | ||
[TestCase(-100)] | ||
[TestCase(-9999)] | ||
[Category("InitializationTests")] | ||
public void Constructor_ScaleIsNegative_ThrowArgumentException(int scale) | ||
This comment was marked as resolved.
Sorry, something went wrong. |
||
{ | ||
TestDelegate action = () => new NumberValidator(1, scale); | ||
|
||
var ex = Assert.Throws<ArgumentException>(action, | ||
$"Failed: Expected ArgumentException for scale = {scale}"); | ||
|
||
Assert.That(ex.Message, Is.EqualTo("precision must be a non-negative number less or equal than precision"), | ||
"Failed: Expected specific message for scale is negative"); | ||
} | ||
|
||
[TestCase(5, 5)] | ||
[TestCase(1, 2)] | ||
[TestCase(5, 10)] | ||
[Category("InitializationTests")] | ||
public void Constructor_ScaleNotLessThanPrecision_ThrowArgumentException(int precision, int scale) | ||
{ | ||
TestDelegate action = () => new NumberValidator(precision, scale); | ||
|
||
var ex = Assert.Throws<ArgumentException>(action, | ||
$"Failed: Expected ArgumentException for scale >= precision (precision = {precision}, scale = {scale})"); | ||
|
||
Assert.That(ex.Message, Is.EqualTo("precision must be a non-negative number less or equal than precision"), | ||
"Failed: Expected specific message for scale >= precision"); | ||
} | ||
|
||
[TestCase(1, 0)] | ||
[TestCase(2, 1)] | ||
[TestCase(10, 5)] | ||
[Category("InitializationTests")] | ||
public void Constructor_PrecisionAndScaleAreValid_NotThrowException(int precision, int scale) | ||
{ | ||
TestDelegate action = () => new NumberValidator(precision, scale); | ||
|
||
Assert.DoesNotThrow(action, | ||
$"Failed: Unexpected ArgumentException for precision = {precision}, scale = {scale}"); | ||
} | ||
#endregion | ||
|
||
#region IntegersTests | ||
[TestCase(1, "0")] | ||
[TestCase(2, "21")] | ||
[TestCase(5, "40")] | ||
[Category("IntegersTests")] | ||
public void IsValidNumber_IntegerWithoutSignWithinPrecision_ReturnTrue(int precision, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, 0, true); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = {precision}, scale=0, onlyPositive=true"); | ||
} | ||
|
||
[TestCase(2, "+0")] | ||
[TestCase(2, "-0")] | ||
[TestCase(3, "+21")] | ||
[TestCase(5, "-40")] | ||
[Category("IntegersTests")] | ||
public void IsValidNumber_IntegerWithSignWithinPrecision_ReturnTrue(int precision, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, 0, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = {precision}, scale=0, onlyPositive=false"); | ||
} | ||
|
||
[TestCase(2, 1, "0")] | ||
[TestCase(3, 1, "5")] | ||
[TestCase(5, 2, "-1")] | ||
[TestCase(3, 2, "+21")] | ||
[Category("IntegersTests")] | ||
public void IsValidNumber_IntegerProvidedAndScaleIsGreaterThanZero_ReturnTrue(int precision, int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, scale, false); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. В текущей реализации излишне явно проставлять onlyPositive false. Оно и так определено как false по умолчанию в конструкторе |
||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = {precision}, scale={scale}, onlyPositive=false"); | ||
} | ||
#endregion | ||
|
||
#region DecimalsTests | ||
[TestCase(5, 2, "123.45")] | ||
[TestCase(5, 2, "123.45")] | ||
[TestCase(7, 2, "123.45")] | ||
[TestCase(5, 4, "123.45")] | ||
[TestCase(3, 2, "0.0")] | ||
[Category("DecimalsTests")] | ||
public void IsValidNumber_DecimalsWithoutSignWithinPrecisionAndScale_ReturnsTrue(int precision, int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, scale, true); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = {precision}, scale={scale}, onlyPositive=true"); | ||
} | ||
|
||
[TestCase(6, 2, "+123.45")] | ||
[TestCase(7, 2, "-123.45")] | ||
[TestCase(3, 2, "+0.0")] | ||
[TestCase(3, 2, "-0.0")] | ||
[Category("DecimalsTests")] | ||
public void IsValidNumber_DecimalsWithSignWithinPrecisionAndScale_ReturnsTrue(int precision, int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, scale, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = {precision}, scale={scale}, onlyPositive=false"); | ||
} | ||
|
||
[TestCase("123.45")] | ||
[TestCase("123,45")] | ||
[TestCase("+123,45")] | ||
[TestCase("-123,45")] | ||
[TestCase("+123.45")] | ||
[TestCase("-123.45")] | ||
[Category("DecimalsTests")] | ||
public void IsValidNumber_DecimalsWithCommaOrDotSeparator_ReturnTrue(string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(6, 3, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.True, | ||
$"Failed: Expected valid for '{numberToValidator}', precision = 6, scale=3, onlyPositive=false"); | ||
} | ||
#endregion | ||
|
||
#region InvalidConfigurationTests | ||
[TestCase(1, 0, "11")] | ||
[TestCase(3, 1, "112.3")] | ||
[TestCase(2, 0, "+42")] | ||
[TestCase(4, 2, "+42.75")] | ||
[Category("InvalidConfigurationTests")] | ||
public void IsValidNumber_NumberExceedsPrecision_ReturnFalse(int precision, int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, scale, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision = {precision}, scale={scale}, onlyPositive=false"); | ||
} | ||
|
||
[TestCase(2, "0.0")] | ||
[TestCase(3, "1.23")] | ||
[TestCase(5, "-12.34")] | ||
[TestCase(7, "+123.45")] | ||
[Category("InvalidConfigurationTests")] | ||
public void IsValidNumber_DecimalsProvidedAndScaleIsZero_ReturnFalse(int precision, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, 0, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision={precision}, scale=0, onlyPositive=false"); | ||
} | ||
|
||
[TestCase(3, 1, "1.23")] | ||
[TestCase(4, 1, "+1.32")] | ||
[TestCase(7, 2, "+1.321")] | ||
[Category("InvalidConfigurationTests")] | ||
public void IsValidNumber_DecimalExceedsScale_ReturnFalse(int precision, int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(precision, scale, false); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision={precision}, scale={scale}, onlyPositive=false"); | ||
} | ||
|
||
[TestCase("-0")] | ||
[TestCase("-10")] | ||
[TestCase("-1.23")] | ||
[Category("InvalidConfigurationTests")] | ||
public void IsValidNumber_NegativeNumberIsOnlyPositive_ReturnFalse(string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(7, 3, true); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision=7, scale=3, onlyPositive=false"); | ||
} | ||
#endregion | ||
|
||
#region InvalidInputsTests | ||
[TestCase(null)] | ||
[TestCase("")] | ||
[TestCase(" ")] | ||
[TestCase("\t")] | ||
[Category("InvalidInputsTests")] | ||
public void IsValidNumber_NumberNullOrEmpty_ReturnFalse(string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(5); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision = 5, scale=0, onlyPositive=false"); | ||
} | ||
|
||
[TestCase("a.sd")] | ||
[TestCase("10O")] | ||
[TestCase("12.34#")] | ||
[TestCase("$12.34")] | ||
[Category("InvalidInputsTests")] | ||
public void IsValidNumber_InputContainsLetters_ReturnFalse(string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(5, 3); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision = 5, scale=3, onlyPositive=false"); | ||
} | ||
|
||
[TestCase("12_34")] | ||
[TestCase("12/34")] | ||
[TestCase("$12;34")] | ||
[Category("InvalidInputsTests")] | ||
public void IsValidNumber_DecimalsContainsIncorrectSeparator_ReturnFalse(string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(7, 3); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision = 5, scale=3, onlyPositive=false"); | ||
} | ||
|
||
[TestCase(0, "123.")] | ||
[TestCase(1, "123.")] | ||
[TestCase(0, "12,")] | ||
[TestCase(2, "123,")] | ||
[Category("InvalidInputsTests")] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Расскажешь для чего используется атрибут Category? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Как написано в интернете, через него можно запускать отдельные группы тестов There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Все верно, можно запускать прогон тестов по отдельным категориям. Не нашел кода который бы это как-то использовал и для чего тебе это тут понадобилось, если, скорее всего, нужно прогнать все тесты разом? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Согласен, в данном случае это не использую. |
||
public void IsValidNumber_DecimalsMissingFractionalPart_ReturnFalse(int scale, string numberToValidator) | ||
{ | ||
var validator = new NumberValidator(5, scale); | ||
var isValid = validator.IsValidNumber(numberToValidator); | ||
|
||
Assert.That(isValid, Is.False, | ||
$"Failed: Expected invalid for '{numberToValidator}', precision = 5, scale={scale}, onlyPositive=false"); | ||
} | ||
#endregion | ||
} |
This comment was marked as resolved.
Sorry, something went wrong.