380 lines
9.1 KiB
C#
380 lines
9.1 KiB
C#
|
//#define ENABLE_TEST_SROPTIONS
|
|||
|
|
|||
|
using System;
|
|||
|
using System.ComponentModel;
|
|||
|
using System.Diagnostics;
|
|||
|
#if !DISABLE_SRDEBUGGER
|
|||
|
using SRDebugger;
|
|||
|
using SRDebugger.Services;
|
|||
|
#endif
|
|||
|
using SRF;
|
|||
|
using SRF.Service;
|
|||
|
using Debug = UnityEngine.Debug;
|
|||
|
using Random = UnityEngine.Random;
|
|||
|
|
|||
|
public partial class SROptions
|
|||
|
{
|
|||
|
// Uncomment the #define at the top of file to enable test options
|
|||
|
|
|||
|
#if ENABLE_TEST_SROPTIONS
|
|||
|
|
|||
|
public enum TestValues
|
|||
|
{
|
|||
|
TestValue1,
|
|||
|
TestValue2,
|
|||
|
TestValue3LongerThisTime
|
|||
|
}
|
|||
|
|
|||
|
private bool _testBoolean = true;
|
|||
|
private string _testString = "Test String Value";
|
|||
|
private short _testShort = -10;
|
|||
|
private byte _testByte = 2;
|
|||
|
private int _testInt = 30000;
|
|||
|
private double _testDouble = 406002020d;
|
|||
|
private float _testFloat = 0.1f;
|
|||
|
private sbyte _testSByte = -10;
|
|||
|
private uint _testUInt = 32450;
|
|||
|
private TestValues _testEnum;
|
|||
|
private float _test01Range;
|
|||
|
private float _testFractionIncrement;
|
|||
|
private int _testLargeIncrement;
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public float TestFloat
|
|||
|
{
|
|||
|
get { return _testFloat; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testFloat = value;
|
|||
|
OnValueChanged("TestFloat", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public double TestDouble
|
|||
|
{
|
|||
|
get { return _testDouble; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testDouble = value;
|
|||
|
OnValueChanged("TestDouble", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public int TestInt
|
|||
|
{
|
|||
|
get { return _testInt; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testInt = value;
|
|||
|
OnValueChanged("TestInt", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public byte TestByte
|
|||
|
{
|
|||
|
get { return _testByte; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testByte = value;
|
|||
|
OnValueChanged("TestByte", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public short TestShort
|
|||
|
{
|
|||
|
get { return _testShort; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testShort = value;
|
|||
|
OnValueChanged("TestShort", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public string TestString
|
|||
|
{
|
|||
|
get { return _testString; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testString = value;
|
|||
|
OnValueChanged("TestString", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public bool TestBoolean
|
|||
|
{
|
|||
|
get { return _testBoolean; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testBoolean = value;
|
|||
|
OnValueChanged("TestBoolean", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public TestValues TestEnum
|
|||
|
{
|
|||
|
get { return _testEnum; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testEnum = value;
|
|||
|
OnValueChanged("TestEnum", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public sbyte TestSByte
|
|||
|
{
|
|||
|
get { return _testSByte; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testSByte = value;
|
|||
|
OnValueChanged("TestSByte", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public uint TestUInt
|
|||
|
{
|
|||
|
get { return _testUInt; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testUInt = value;
|
|||
|
OnValueChanged("TestUInt", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
[NumberRange(0, 1)]
|
|||
|
public float Test01Range
|
|||
|
{
|
|||
|
get { return _test01Range; }
|
|||
|
set
|
|||
|
{
|
|||
|
_test01Range = value;
|
|||
|
OnValueChanged("Test01Range", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
[Increment(0.2)]
|
|||
|
public float TestFractionIncrement
|
|||
|
{
|
|||
|
get { return _testFractionIncrement; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testFractionIncrement = value;
|
|||
|
OnValueChanged("TestFractionIncrement", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
[Increment(25)]
|
|||
|
public int TestLargeIncrement
|
|||
|
{
|
|||
|
get { return _testLargeIncrement; }
|
|||
|
set
|
|||
|
{
|
|||
|
_testLargeIncrement = value;
|
|||
|
OnValueChanged("TestLargeIncrement", value);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test")]
|
|||
|
public void TestAction()
|
|||
|
{
|
|||
|
Debug.Log("[SRDebug] TestAction() invoked");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Test"), DisplayName("Test Action Renamed")]
|
|||
|
public void TestRenamedAction()
|
|||
|
{
|
|||
|
Debug.Log("[SRDebug] TestRenamedAction() invoked");
|
|||
|
}
|
|||
|
|
|||
|
private void OnValueChanged(string n, object newValue)
|
|||
|
{
|
|||
|
Debug.LogFormat("[SRDebug] {0} value changed to {1}", n, newValue);
|
|||
|
OnPropertyChanged(n);
|
|||
|
}
|
|||
|
|
|||
|
#if !DISABLE_SRDEBUGGER
|
|||
|
[Category("SRDebugger")]
|
|||
|
public PinAlignment TriggerPosition
|
|||
|
{
|
|||
|
get { return SRServiceManager.GetService<IDebugTriggerService>().Position; }
|
|||
|
set { SRServiceManager.GetService<IDebugTriggerService>().Position = value; }
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
private static readonly string[] SampleLogs =
|
|||
|
{
|
|||
|
"Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
|
|||
|
"Mauris id mauris interdum tellus luctus posuere.",
|
|||
|
"Donec eget velit nec risus bibendum condimentum ut in velit.",
|
|||
|
"Aenean et augue non eros interdum fringilla.",
|
|||
|
"Nam vulputate justo quis nulla ultricies placerat.",
|
|||
|
"Etiam id libero sed quam elementum suscipit.",
|
|||
|
"Nulla sollicitudin purus nec mauris congue tincidunt.",
|
|||
|
"Nam sit amet neque vestibulum, vehicula lorem sed, ultricies dui.",
|
|||
|
"Aenean a eros fringilla, luctus est et, bibendum lorem.",
|
|||
|
"Integer bibendum metus in lectus finibus sagittis.",
|
|||
|
"Quisque a lacus ac massa interdum sagittis nec id sapien.",
|
|||
|
"Phasellus a ipsum volutpat, lobortis velit eu, consectetur nunc.",
|
|||
|
"Nulla elementum justo malesuada lacus mollis lobortis.",
|
|||
|
"Nullam sodales nisi vitae tortor lacinia, in pulvinar mauris accumsan.",
|
|||
|
"Nullam maximus dolor suscipit magna lobortis, eu finibus felis ornare.",
|
|||
|
"Sed eget nisl ac lorem eleifend fermentum ac quis nunc.",
|
|||
|
"Fusce vitae sapien quis turpis faucibus aliquet sit amet et risus.",
|
|||
|
"Nunc faucibus arcu ut purus fringilla bibendum.",
|
|||
|
"Phasellus pretium justo vel eros facilisis varius.",
|
|||
|
"In efficitur quam dapibus nulla commodo, in aliquam nulla bibendum."
|
|||
|
};
|
|||
|
|
|||
|
private int _consoleTestQuantity = 190;
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public int ConsoleTestQuantity
|
|||
|
{
|
|||
|
get { return _consoleTestQuantity; }
|
|||
|
set { _consoleTestQuantity = value; }
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void ConsoleTest()
|
|||
|
{
|
|||
|
var sw = new Stopwatch();
|
|||
|
sw.Start();
|
|||
|
for (var i = 0; i < ConsoleTestQuantity; i++)
|
|||
|
{
|
|||
|
var sample = SampleLogs[Random.Range(0, SampleLogs.Length)];
|
|||
|
|
|||
|
var mode = Random.Range(0, 3);
|
|||
|
|
|||
|
switch (mode)
|
|||
|
{
|
|||
|
case 0:
|
|||
|
Debug.Log(sample);
|
|||
|
break;
|
|||
|
case 1:
|
|||
|
Debug.LogWarning(sample);
|
|||
|
break;
|
|||
|
case 2:
|
|||
|
Debug.LogError(sample);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
sw.Stop();
|
|||
|
|
|||
|
Debug.LogFormat("Posted {0} log messages in {1}s", ConsoleTestQuantity, sw.Elapsed.TotalSeconds);
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestThrowException()
|
|||
|
{
|
|||
|
throw new Exception("This is certainly a test.");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestLogError()
|
|||
|
{
|
|||
|
Debug.LogError("Test Error");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestLogWarning()
|
|||
|
{
|
|||
|
Debug.LogWarning("Test Warning");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestLogInfo()
|
|||
|
{
|
|||
|
Debug.Log("Test Info");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestRichText()
|
|||
|
{
|
|||
|
Debug.Log(
|
|||
|
"<b>Rich text</b> is <i>supported</i> in the <b><i>console</i></b>. <color=#7fc97a>Color tags, too!</color>");
|
|||
|
}
|
|||
|
|
|||
|
[Category("Console Test")]
|
|||
|
public void TestLongMessage()
|
|||
|
{
|
|||
|
var m = SampleLogs[0];
|
|||
|
|
|||
|
for (var i = 0; i < 2; ++i)
|
|||
|
{
|
|||
|
m = m + m;
|
|||
|
}
|
|||
|
|
|||
|
var s = m;
|
|||
|
|
|||
|
for (var i = 0; i < 13; ++i)
|
|||
|
{
|
|||
|
s = s + "\n" + m;
|
|||
|
}
|
|||
|
|
|||
|
Debug.Log(s);
|
|||
|
}
|
|||
|
|
|||
|
[Category("Sorting Test"), Sort(2)]
|
|||
|
public float ShouldAppearLast { get; set; }
|
|||
|
|
|||
|
[Category("Sorting Test"), Sort(-1)]
|
|||
|
public float ShouldAppearFirst { get; set; }
|
|||
|
|
|||
|
[Category("Sorting Test")]
|
|||
|
public float ShouldAppearMiddle { get; set; }
|
|||
|
|
|||
|
private float _updateTest;
|
|||
|
|
|||
|
public float UpdateTest
|
|||
|
{
|
|||
|
get { return _updateTest; }
|
|||
|
set
|
|||
|
{
|
|||
|
_updateTest = value;
|
|||
|
OnPropertyChanged("UpdateTest");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
[DisplayName("Modified Name")]
|
|||
|
public float DisplayNameTest { get; set; }
|
|||
|
|
|||
|
[Category("Read Only")]
|
|||
|
public bool ReadOnlyBool { get; private set; }
|
|||
|
|
|||
|
[Category("Read Only")]
|
|||
|
public float ReadOnlyNumber { get; private set; }
|
|||
|
|
|||
|
[Category("Read Only")]
|
|||
|
public string ReadOnlyString { get; private set; }
|
|||
|
|
|||
|
[Category("Read Only")]
|
|||
|
public TestValues ReadOnlyEnum { get; private set; }
|
|||
|
|
|||
|
[Category("Read Only")]
|
|||
|
public string TestLongReadOnlyString
|
|||
|
{
|
|||
|
get { return "This is a really long string with no reason other than to test long strings."; }
|
|||
|
}
|
|||
|
|
|||
|
[Browsable(false)]
|
|||
|
public bool ThisBooleanPropertyShouldBeHidden { get; set; }
|
|||
|
|
|||
|
[Browsable(false)]
|
|||
|
public void ThisMethodShouldBeHidden()
|
|||
|
{
|
|||
|
}
|
|||
|
|
|||
|
#endif
|
|||
|
}
|