Подтвердить что ты не робот

Параметрический тест с использованием общих методов

В NUnit 2.5 вы можете сделать это:

[TestCase(1,5,7)]
public void TestRowTest(int i, int j, int k)
{
  Assert.AreEqual(13, i+j+k);
}

Вы можете выполнить параметрический тест.

Но мне интересно, можете ли вы это сделать или нет, параметрический тест с помощью универсального метода тестирования? То есть:.

[TestCase <int>("Message")]
public void TestRowTestGeneric<T>(string msg)
{
  Assert.AreEqual(5, ConvertStrToGenericParameter<T>(msg));
}

Или что-то подобное.

4b9b3361

Ответ 1

Вот цитата из примечания к выпуску NUnit 2.5 текст ссылки

Параметрированные методы тестирования могут быть родовой. NUnit выведет правильные реализации на основе типы предоставленных параметров. Общие методы тестирования поддерживаются в как общие, так и не общие понятия.

В соответствии с этим возможно иметь общий метод тестирования в неэквивалентном классе. Как?

Я не совсем понимаю комментарий Джеффа. В .net generics есть время компиляции и время выполнения. Мы можем использовать отражение, чтобы узнать атрибут тестового случая, связанный с методом, узнать общий параметр и снова использовать отражение, чтобы вызвать общий метод. Он будет работать, нет?

Обновление: Хорошо, теперь я знаю, как и надеюсь, что еще не слишком поздно. Вам нужно, чтобы общий тип отображался в списке параметров. Например:

[TestCase((int)5, "5")]
[TestCase((double)2.3, "2.3")]
public void TestRowTestGeneric<T>(T value, string msg)
{
  Assert.AreEqual(value, ConvertStrToGenericParameter<T>(msg));
}

Ответ 2

Вы можете создать собственный GenericTestCaseAttribute

    [Test]
    [GenericTestCase(typeof(MyClass) ,"Some response", TestName = "Test1")]
    [GenericTestCase(typeof(MyClass1) ,"Some response", TestName = "Test2")]
    public void MapWithInitTest<T>(string expectedResponse)
    {
        // Arrange

        // Act
        var response = MyClassUnderTest.MyMethod<T>();

        // Assert
        Assert.AreEqual(expectedResponse, response);
    }

Вот реализация GenericTestCaseAttribute

[AttributeUsage(AttributeTargets.Method, AllowMultiple = true)]
public class GenericTestCaseAttribute : TestCaseAttribute, ITestBuilder
{
    private readonly Type _type;
    public GenericTestCaseAttribute(Type type, params object[] arguments) : base(arguments)
    {
        _type = type;
    }

    IEnumerable<TestMethod> ITestBuilder.BuildFrom(IMethodInfo method, Test suite)
    {
        if (method.IsGenericMethodDefinition && _type != null)
        {
            var gm = method.MakeGenericMethod(_type);
            return BuildFrom(gm, suite);
        }
        return BuildFrom(method, suite);
    }
}

Ответ 3

Создайте закрытый метод и вызовите это:

    [Test]
    public void TypeATest()
    {
        MyTest<TypeA>();
    }

    [Test]
    public void TypeBTest()
    {
        MyTest<TypeB>();
    }

    private void MyTest<T>()
    {
        // do test.
    }