using System;
namespace UnityEngine.TestTools
{
///
/// The presence of this attribute makes the Test Runner expect every single log. By
/// default, the runner only fails automatically on any error logs, so this adds warnings and infos as well.
/// It is the same as calling `LogAssert.NoUnexpectedReceived()` at the bottom of every affected test.
///
/// This attribute can be applied to test assemblies (affects every test in the assembly), fixtures (affects every test in the fixture), or on individual test methods. It is also automatically inherited from base
/// fixtures.
///
/// The `MustExpect` property (on by default) lets you selectively enable or disable the higher level value. For
/// example when migrating an assembly to this more strict checking method, you might attach
/// `[assembly:TestMustExpectAllLogs]` to the assembly itself, but whitelist individual failing fixtures and test methods
/// by attaching `[TestMustExpectAllLogs(MustExpect=false)]` until they can be migrated. This also means new tests in that
/// assembly would be required to have the more strict checking.
///
[AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Class | AttributeTargets.Method)]
public class TestMustExpectAllLogsAttribute : Attribute
{
///
/// Initializes and returns an instance of TestMustExpectAllLogsAttribute.
///
///
/// A value indicating whether the test must expect all logs.
///
public TestMustExpectAllLogsAttribute(bool mustExpect = true)
=> MustExpect = mustExpect;
///
/// Returns the flag of whether the test must expect all logs.
///
public bool MustExpect { get; }
}
}