Skip to content
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

Бабинцев Григорий #21

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

qreaqtor
Copy link

@qreaqtor qreaqtor commented Nov 5, 2024

No description provided.

Comment on lines 18 to 20
actualTsar.Should().BeEquivalentTo(expectedTsar,
options => options.Excluding(person => person.Id).
Excluding(person => person.Parent.Id));

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Давай попробуем выполнить сравнение для такого царя

new Person("Ivan IV The Terrible", 54, 170, 70,
            new Person("Vasili III of Russia", 28, 170, 60, 
                new Person("Ivan III", 65, 170, 80, null)))

Важно обращать внимание на рекурсивные вызовы, потому что в них часто кроются ошибки

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Сравнение с ID будет работать для всех, да. Но если в Person появятся какие-нибудь другие ID в будущем, которые будет нужно сравнивать, есть риск их пропустить. Попробуем сделать обработку конкретно этого свойства Id в person и его parent?


[Test]
[Test]

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Совет на будущее: хорошая привычка пересматривать изменения перед коммитом или пушем, чтобы ненужные изменения не попадали в общий репозиторий. Здесь сыграли злую шутку табы и пробелы, решается просто настройкой IDE


namespace HomeExercise.Tasks.NumberValidator
{
// для каждого теста может быть много тест кейсов, поэтому я вынес их в отдельные коллекции

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Хорошо что знаешь про возможность выделения тесткейсов в отдельные коллекции. Но здесь это не идёт на пользу

  1. На самом деле в тестах не должно быть много кейсов. Если значительно растёт их количество, значит что-то не так с тестом и нужно проверить, а сколько действий он проверяет
  2. Потерялась связь с тем, что вообще означают эти цифры. Если хочется выносить в отдельные коллекции, то нужно делать их generic. Например так. Тогда ещё на этапе компиляции IDE подскажет, если что-то не будет совпадать
public static IEnumerable<(int precision, int scale, bool onlyPositive, string value)> ValidTestCases


yield return new TestCaseData(17, 2, true, "0");

yield return new TestCaseData(4, 2, true, "+1.23");

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

В этом кейсе одновременно проверяются три сценария

  1. максимум по цифрам включая знак
  2. максимум по цифрам
  3. максимум по дробной части

Я бы предложил разбить его на три независимых

yield return new TestCaseData(4, 2, true, "+1.23");

yield return new TestCaseData(7, 3, false, "+1.00");
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Не нашёл тестов на запятую в качестве разделителя и отрицательное значение

Comment on lines 74 to 76
yield return new TestCaseData(1, 0, true);

yield return new TestCaseData(2, 1, true);

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Играет ли роль третий параметр в этих тестах?

ClassicAssert.IsFalse(new NumberValidator(3, 2, true).IsValidNumber("a.sd"));
}
[TestCaseSource(nameof(ValidTestCases))]
public void Should_Be_Valid(int precision, int scale, bool onlyPositive, string value)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Замечание по названию. Хорошо что указал глагол и не дублируешь класс. Но потерялся указатель на то, что проверяется. Валидность - понятие довольно растяжимое. Здесь тестируется конкретный метод. Я бы предлодил назвать IsValidNumber_Shoud_BeTrue_When... Дело в том, что подряд идущие Shoud_BeTrue и Shoud_BeFalse сбивают с толку

}

[TestCaseSource(nameof(NotValidTestCases))]
public void Should_Be_NotValid(int precision, int scale, bool onlyPositive, string value)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Тоже комментарий по названию метода. Что проверяется и чем должно быть

}
}

public static IEnumerable NotValidTestCases

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Идейно можно разбить проверки на крупные группы. Например переполнение, странные состояние строки, плохие разделители или формат, несовпадение знаков. Тогда будет проще читать тесты, а количество кейсов для одного теста не увеличится так сильно

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Не стал в итоге разделять?

}

[TestCaseSource(nameof(ThrowArgumentExceptionTestCases))]
public void Should_ThrowArgumentException(int precision, int scale, bool onlyPositive)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

А всё ещё IsValidNumber должен вызывать исключение или мы тестируем что-то другое?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Тут же вообще не используется IsValidNumber

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Да. Но кто-то же бросает исключения. Я бы назвал его с использованием слова Constructor. Например Constructor_Should_ThrowArgumentException

@qreaqtor
Copy link
Author

qreaqtor commented Nov 6, 2024

Переделал на тест кейсы, потому что при выделении в отдельный класс коллекций с кейсами тесты что-то не запускались и добавил названия тестам

Comment on lines 18 to 20
actualTsar.Should().BeEquivalentTo(expectedTsar,
options => options.Excluding(person => person.Id).
Excluding(person => person.Parent.Id));

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Сравнение с ID будет работать для всех, да. Но если в Person появятся какие-нибудь другие ID в будущем, которые будет нужно сравнивать, есть риск их пропустить. Попробуем сделать обработку конкретно этого свойства Id в person и его parent?

}
}

public static IEnumerable NotValidTestCases

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Не стал в итоге разделять?

}

[TestCaseSource(nameof(ThrowArgumentExceptionTestCases))]
public void Should_ThrowArgumentException(int precision, int scale, bool onlyPositive)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Да. Но кто-то же бросает исключения. Я бы назвал его с использованием слова Constructor. Например Constructor_Should_ThrowArgumentException

public void Should_Be_NotValid(int precision, int scale, bool onlyPositive, string value)

[TestCase(3, 2, true, "00.00", TestName = "Number length with fractionl part more than precision")]
[TestCase(3, 2, true, "-0.0", TestName = "Negative number length with fractionl part more than precision")]

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

А этот тест проверяет не то, что указано в описании. Но сам тест хороший

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants