Rasagar/Library/PackageCache/com.unity.test-framework/UnityEngine.TestRunner/NUnitExtensions/Attributes/UnitySetUpAttribute.cs
2024-08-26 23:07:20 +03:00

234 lines
5.7 KiB
C#

using System;
using NUnit.Framework;
namespace UnityEngine.TestTools
{
/// <summary>
/// The `UnitySetUp` and <see cref="UnityTearDownAttribute"/> attributes are identical to the standard `SetUp` and `TearDown` attributes, with the exception that they allow for <see cref="IEditModeTestYieldInstruction"/>. The `UnitySetUp` and `UnityTearDown` attributes expect a return type of [IEnumerator](https://docs.microsoft.com/en-us/dotnet/api/system.collections.ienumerator?view=netframework-4.8).
/// </summary>
/// <example>
/// <code>
/// <![CDATA[
/// public class SetUpTearDownExample
/// {
/// [UnitySetUp]
/// public IEnumerator SetUp()
/// {
/// yield return new EnterPlayMode();
/// }
///
/// [Test]
/// public void MyTest()
/// {
/// Debug.Log("This runs inside playmode");
/// }
///
/// [UnityTearDown]
/// public IEnumerator TearDown()
/// {
/// yield return new ExitPlayMode();
/// }
/// }
/// ]]>
/// </code>
/// </example>
/// <example>
/// ## Base and Derived class example
/// <code>
/// <![CDATA[
/// public class BaseClass
/// {
/// [OneTimeSetUp]
/// public void OneTimeSetUp()
/// {
/// Debug.Log("OneTimeSetUp Base");
/// }
///
/// [SetUp]
/// public void SetUp()
/// {
/// Debug.Log("SetUp Base");
/// }
///
/// [UnitySetUp]
/// public IEnumerator UnitySetUp()
/// {
/// Debug.Log("UnitySetup Base");
/// yield return null;
/// }
///
/// [TearDown]
/// public void TearDown()
/// {
/// Debug.Log("TearDown Base");
/// }
///
/// [UnityTearDown]
/// public IEnumerator UnityTearDown()
/// {
/// Debug.Log("UnityTearDown Base");
/// yield return null;
/// }
/// }
///
/// public class DerivedClass : BaseClass
/// {
/// [OneTimeSetUp]
/// public new void OneTimeSetUp()
/// {
/// Debug.Log("OneTimeSetUp");
/// }
///
/// [SetUp]
/// public new void SetUp()
/// {
/// Debug.Log("SetUp");
/// }
///
/// [UnitySetUp]
/// public new IEnumerator UnitySetUp()
/// {
/// Debug.Log("UnitySetup");
/// yield return null;
/// }
///
/// [Test]
/// public void UnitTest()
/// {
/// Debug.Log("Test");
/// }
///
/// [UnityTest]
/// public IEnumerator UnityTest()
/// {
/// Debug.Log("UnityTest before yield");
/// yield return null;
/// Debug.Log("UnityTest after yield");
/// }
///
/// [TearDown]
/// public new void TearDown()
/// {
/// Debug.Log("TearDown");
/// }
///
/// [UnityTearDown]
/// public new IEnumerator UnityTearDown()
/// {
/// Debug.Log("UnityTearDown");
/// yield return null;
/// }
///
/// [OneTimeTearDown]
/// public void OneTimeTearDown()
/// {
/// Debug.Log("OneTimeTearDown");
/// }
/// }
/// ]]>
/// </code>
/// </example>
/// <example>
/// ## Domain reload example
/// <code>
/// <![CDATA[
/// public class BaseClass
/// {
/// [OneTimeSetUp]
/// public void OneTimeSetUp()
/// {
/// Debug.Log("OneTimeSetUp Base");
/// }
///
/// [SetUp]
/// public void SetUp()
/// {
/// Debug.Log("SetUp Base");
/// }
///
/// [UnitySetUp]
/// public IEnumerator UnitySetUp()
/// {
/// Debug.Log("UnitySetup Base");
/// yield return null;
/// }
///
/// [TearDown]
/// public void TearDown()
/// {
/// Debug.Log("TearDown Base");
/// }
///
/// [UnityTearDown]
/// public IEnumerator UnityTearDown()
/// {
/// Debug.Log("UnityTearDown Base");
/// yield return null;
/// }
/// }
///
/// public class DerivedClass : BaseClass
/// {
/// [OneTimeSetUp]
/// public new void OneTimeSetUp()
/// {
/// Debug.Log("OneTimeSetUp");
/// }
///
/// [SetUp]
/// public new void SetUp()
/// {
/// Debug.Log("SetUp");
/// }
///
/// [UnitySetUp]
/// public new IEnumerator UnitySetUp()
/// {
/// Debug.Log("UnitySetup");
/// yield return null;
/// }
///
/// [Test]
/// public void UnitTest()
/// {
/// Debug.Log("Test");
/// }
///
/// [UnityTest]
/// public IEnumerator UnityTest()
/// {
/// Debug.Log("UnityTest before yield");
/// yield return new EnterPlayMode();
/// //Domain reload happening
/// yield return new ExitPlayMode();
/// Debug.Log("UnityTest after yield");
/// }
///
/// [TearDown]
/// public new void TearDown()
/// {
/// Debug.Log("TearDown");
/// }
///
/// [UnityTearDown]
/// public new IEnumerator UnityTearDown()
/// {
/// Debug.Log("UnityTearDown");
/// yield return null;
/// }
///
/// [OneTimeTearDown]
/// public void OneTimeTearDown()
/// {
/// Debug.Log("OneTimeTearDown");
/// }
/// }
/// ]]>
/// </code>
/// </example>
[AttributeUsage(AttributeTargets.Method)]
public class UnitySetUpAttribute : NUnitAttribute
{
}
}