Custom assertion
A test fails if Unity logs a message other than a regular log or warning message. Use LogAssert to check for an expected message in the log so that the test does not fail when Unity logs the message.
Use LogAssert.Expect
before running the code under test, as the check for expected logs runs at the end of each frame.
A test also reports a failure, if an expected message does not appear, or if Unity does not log any regular log or warning messages.
Example
[Test]
public void LogAssertExample()
{
// Expect a regular log message
LogAssert.Expect(LogType.Log, "Log message");
// The test fails without the following expected log message
Debug.Log("Log message");
// An error log
Debug.LogError("Error message");
// Without expecting an error log, the test would fail
LogAssert.Expect(LogType.Error, "Error message");
}
LogAssert
LogAssert
lets you expect Unity log messages that would otherwise cause the test to fail. It is available under the namespace UnityEngine.TestTools
, see the Scripting API for more details.
Static properties
Syntax | Description |
---|---|
bool ignoreFailingMessages |
Set this property to true to prevent unexpected error log messages from triggering an assertion. By default, it is false . |
Static Methods
Syntax | Description |
---|---|
void Expect(LogType type, string message); void Expect(LogType type, Regex message); |
Verifies that a log message of a specified type appears in the log. A test won’t fail from an expected error, assertion, or exception log message. It does fail if an expected message does not appear in the log. |
void NoUnexpectedReceived(); |
Triggers an assertion when receiving any log messages and fails the test if some are unexpected messages. If multiple tests need to check for no received unexpected logs, consider using the TestMustExpectAllLogs attribute instead. |
Expect string message
void Expect(LogType type, string message);
Parameters
Syntax | Description |
---|---|
LogType type |
A type of log to expect. It can take one of the LogType enum values. |
string message |
A string value that should equate to the expected message. |
Expect Regex message
void Expect(LogType type, Regex message);
Parameters
Syntax | Description |
---|---|
LogType type |
A type of log to expect. It can take one of the LogType enum values. |
Regex message |
A regular expression pattern to match the expected message. |