Получить имя запуска теста в Xunit

Использование Xunit, как я могу получить имя текущего запуска?

  public class TestWithCommonSetupAndTearDown : IDisposable
  {
    public TestWithCommonSetupAndTearDown ()
    {
      var nameOfRunningTest = "TODO";
      Console.WriteLine ("Setup for test '{0}.'", nameOfRunningTest);
    }

    [Fact]
    public void Blub ()
    {
    }

    public void Dispose ()
    {
      var nameOfRunningTest = "TODO";
      Console.WriteLine ("TearDown for test '{0}.'", nameOfRunningTest);
    }
  }

Edit:
В частности, я ищу замену свойства NUnits TestContext.CurrentContext.Test.Name.

Ответ 1

Вы можете использовать BeforeAfterTestAttribute для разрешения вашего дела. Есть несколько способов решения вашей проблемы с помощью Xunit, который должен был сделать подкласс класса TestClassCommand, или FactAttribute и TestCommand, но я думаю, что BeforeAfterTestAttribute является самым простым способом. Ознакомьтесь с приведенным ниже кодом.

public class TestWithCommonSetupAndTearDown
{
    [Fact]
    [DisplayTestMethodName]
    public void Blub()
    {
    }

    private class DisplayTestMethodNameAttribute : BeforeAfterTestAttribute
    {
        public override void Before(MethodInfo methodUnderTest)
        {
            var nameOfRunningTest = "TODO";
            Console.WriteLine("Setup for test '{0}.'", methodUnderTest.Name);
        }

        public override void After(MethodInfo methodUnderTest)
        {
            var nameOfRunningTest = "TODO";
            Console.WriteLine("TearDown for test '{0}.'", methodUnderTest.Name);
        }
    }
}

Ответ 2

Я не могу говорить с xUnit... но это работало для меня в VS Testing. может стоить того.

Ссылка: Как получить имя текущего метода из кода

Пример:

[TestMethod]
public void TestGetMethod()
{
    StackTrace st = new StackTrace();
    StackFrame sf = st.GetFrame(0);
    MethodBase currentMethodName = sf.GetMethod();
    Assert.IsTrue(currentMethodName.ToString().Contains("TestGetMethod"));
 }

Ответ 3

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

public class Tests
  {
  public Tests(ITestOutputHelper output)
    {
    var type = output.GetType();
    var testMember = type.GetField("test", BindingFlags.Instance | BindingFlags.NonPublic);
    var test = (ITest)testMember.GetValue(output);
    }
<...>
  }