Есть ли способ установить порядок тестового крючка NUnit [OneTimeTearDown], если этот крючок имеется более чем в одном м ⇐ C#
Есть ли способ установить порядок тестового крючка NUnit [OneTimeTearDown], если этот крючок имеется более чем в одном м
У меня есть проект автоматизации мобильных устройств, в котором используется .NET 6 со Specflow, NUnit и Xamarin.UITest. когда мой проект был на .NET Framework 4.8 и я использовал хук [OneTimeTearDown], я смог создать консольный метод, который может генерировать живой документ с помощью кода. См. здесь для справки: https://github.com/SpecFlowOSS/SpecFlow/issues/2701 в .NET 6 у меня возникла проблема: когда он генерирует живой документ, он использует TestExecution.json последнего запуска, а не только что выполненный. Я обнаружил, что это связано с тем, что TestExecution.json генерируется после метода [OneTimeTearDown], который я запустил. Это связано с тем, что Specflow NUnit использует тот же хук, см. ниже:
// #pragma предупреждение отключить использование System.CodeDom.Compiler; использование System.Diagnostics; используя global::NUnit.Framework; используя global::TechTalk.SpecFlow; использование global::System.Runtime.CompilerServices; [GeneratedCode("SpecFlow", "3.9.74")] [SetUpFixture] общедоступный класс HEBPharmacy_UITests_NUnitAssemblyHooks { [OneTimeSetUp] [MethodImpl(MethodImplOptions.NoInlining)] публичная недействительность AssemblyInitialize() { вар currentAssembly = typeof (HEBPharmacy_UITests_NUnitAssemblyHooks).Assembly; TestRunnerManager.OnTestRunStart(currentAssembly); } [OneTimeTearDown] [MethodImpl(MethodImplOptions.NoInlining)] публичная пустота AssemblyCleanup() { вар currentAssembly = typeof (HEBPharmacy_UITests_NUnitAssemblyHooks).Assembly; TestRunnerManager.OnTestRunEnd(currentAssembly); } } #pragma предупреждение восстановить И вот мой метод:
[AfterTestRun] [OneTimeTearDown] публичная статическая пустота AfterTestRun() { если (TestEnvironment.Platform.Equals(TestPlatform.Local)) { Thread.Sleep(1000); ГенерироватьЖивойДок(); } } Имейте в виду, что ловушка Specflow [AfterTestRun] не работает на Mac, поэтому это не решение. как вы можете видеть, он у меня есть в методе, но это не решает проблему. Есть ли способ установить перехватчик [OneTimeTearDown], чтобы мой метод запускался после того, который есть в Specflow? и как мне это сделать?
У меня есть проект автоматизации мобильных устройств, в котором используется .NET 6 со Specflow, NUnit и Xamarin.UITest. когда мой проект был на .NET Framework 4.8 и я использовал хук [OneTimeTearDown], я смог создать консольный метод, который может генерировать живой документ с помощью кода. См. здесь для справки: https://github.com/SpecFlowOSS/SpecFlow/issues/2701 в .NET 6 у меня возникла проблема: когда он генерирует живой документ, он использует TestExecution.json последнего запуска, а не только что выполненный. Я обнаружил, что это связано с тем, что TestExecution.json генерируется после метода [OneTimeTearDown], который я запустил. Это связано с тем, что Specflow NUnit использует тот же хук, см. ниже:
// #pragma предупреждение отключить использование System.CodeDom.Compiler; использование System.Diagnostics; используя global::NUnit.Framework; используя global::TechTalk.SpecFlow; использование global::System.Runtime.CompilerServices; [GeneratedCode("SpecFlow", "3.9.74")] [SetUpFixture] общедоступный класс HEBPharmacy_UITests_NUnitAssemblyHooks { [OneTimeSetUp] [MethodImpl(MethodImplOptions.NoInlining)] публичная недействительность AssemblyInitialize() { вар currentAssembly = typeof (HEBPharmacy_UITests_NUnitAssemblyHooks).Assembly; TestRunnerManager.OnTestRunStart(currentAssembly); } [OneTimeTearDown] [MethodImpl(MethodImplOptions.NoInlining)] публичная пустота AssemblyCleanup() { вар currentAssembly = typeof (HEBPharmacy_UITests_NUnitAssemblyHooks).Assembly; TestRunnerManager.OnTestRunEnd(currentAssembly); } } #pragma предупреждение восстановить И вот мой метод:
[AfterTestRun] [OneTimeTearDown] публичная статическая пустота AfterTestRun() { если (TestEnvironment.Platform.Equals(TestPlatform.Local)) { Thread.Sleep(1000); ГенерироватьЖивойДок(); } } Имейте в виду, что ловушка Specflow [AfterTestRun] не работает на Mac, поэтому это не решение. как вы можете видеть, он у меня есть в методе, но это не решает проблему. Есть ли способ установить перехватчик [OneTimeTearDown], чтобы мой метод запускался после того, который есть в Specflow? и как мне это сделать?
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Исключение, возникающее в OneTimeTearDown; Тесты не отмечены как неудачные
Anonymous » » в форуме C# - 0 Ответы
- 16 Просмотры
-
Последнее сообщение Anonymous
-