| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 | === The Quick Guide to OpenSim Unit Testing === == Running Tests ==On Linux:       > nant testThis will print out to the console the test state.On Windows: ??Also, every checkin will run tests that are kicked off by bamboo.Results are posted here: http://www.opensimulator.org:8085/ as well asto #opensim-dev IRC channel.== Writing Tests ==Tests are written to run under NUnit.  For more information on NUnitplease see: http://www.nunit.org/index.php== Adding Tests ==Tests should not be added to production assemblies.  They shouldinstead be added to assemblies of the nameMy.Production.Assembly.Tests.dll.  This lets them easily be removedfrom production environments that don't want the bloat.Tests should be as close to the code as possible.  It is recommendedthat if you are writing tests they end up in a "Tests" sub-directoryof the directory where the code you are testing resides.If you have added a new test assembly that hasn't existed before youmust list it in both ".nant/local.include" and ".nant/bamboo.build"for it to be accessible to Linux users and to the continuousintegration system.=== The Gory Details ===The following is the original document which started off thisdocument.  It should probably be better integrated with the new info.==UPDATE==The text immediately following is an update to the testing documentation. Theupdate is written on 2008.08.30 and is copied from an email to the opensim-devmailing list[1]. The information below the update, beginning with the sectiontitled TESTING, is still relevant, so please read this document in itsentirety.Mike Mazur[1] https://lists.berlios.de/pipermail/opensim-dev/2008-August/002695.html"""The tests are contained in certain DLLs. At the time of writing, these DLLshave tests in them:OpenSim.Region.ScriptEngine.Common.Tests.dllOpenSim.Region.ScriptEngine.Shared.CodeTools.Tests.dllOpenSim.Region.ScriptEngine.Shared.Tests.dllOpenSim.Framework.Tests.dll OpenSim.Region.Environment.dllOpenSim.Region.Physics.OdePlugin.dll[2]The console command used to run the tests is `nunit-console` (or`nunit-console2` on some systems). This command takes a listing of DLLs toinspect for tests.Currently Bamboo's[3] build file (.nant/bamboo.build) lists only those DLLsfor nunit-console to use. However it would be equally correct to simply passin all DLLs in bin/; those without tests are just skipped.The nunit-console command generates a file TestResults.txt by default. This isan XML file containing a listing of all DLLs inspected, tests executed,successes, failures, etc. If nunit-console is passed in all DLLs in bin/, thisfile bloats with lots of entries like this:    <test-suite name="/home/mike/source/workspace/bin/OpenSim.Grid.Communications.OGS1.dll" success="True" time="0.000" asserts="0">        <results />    </test-suite>    <test-suite name="/home/mike/source/workspace/bin/OpenSim.Region.ClientStack.dll" success="True" time="0.000" asserts="0">        <results />    </test-suite>Therefore it makes more sense to me to specify the DLLs when runningnunit-console.[2] Note that OpenSim.Region.Physics.OdePlugin.dll is in bin/Physics/ andneeds to be first copied to bin/ before nunit-console is executed.[3] http://opensimulator.org:8085/"""==TESTING==To use nunit testing on opensim code, you have a variety of methods.  Theeasiast methods involve using IDE capabilities to test code.  UsingVS2005/2008 I recommend using the testing capabilities of Resarper(commercial)or TestDriven.Net(free).  Both will recognize nunit tests within yourapplication and allow you to test them individually, or all at once, etc.  Youwill also be able to step into debug mode into a test through these add-insenabling a developer to jump right in and see how a specifictest-case/scenerio works.Additionally, it is my understanding that sharpdevelop and monodevelop havetheir own nunit testing plugins within their IDE.  Though I am not certain oftheir exact feature set or stability.== Using NUnit Directly ==The NUnit project is a very mature testing application.  It can be obtainedfrom www.nunit.org are via various package distrobutions for Linux.  Please besure to get a .Net 2.0 version of Nunit, as OpenSim makes use of .Net 2.0functionality.Nunit comes with 2 tools that will enable you to run tests from assemblyinputs.  Nunit-gui and nunit-console.  NUnit-gui is a console that will letyou view the execution of various tests within your assemblies and give visualindication of teir success or failure.  This is a useful tool for those wholack IDE addins ( or lack IDEs at all ).Nunit console allows you to execute the nunit tests of assemblies via console.Its output will show test failures and successes and a summary of whathappened.  This is very useful for a quick overview and/or automated testing.  WindowsWindows version of nunit-console is by default .Net 2.0 if you downloaded the.Net 2.0 version  of Nunit.  Be sure to setup your PATH environment variable.Linux & OSXOn these operating systems you will have to use the command "nunit-console2"Examplenunit-console2 OpenSim.Framework.Tests.dll (on linux)nunit-console OpenSim.Framework.Tests.dll (on windows)For more information on testing contact the autor of this testing readme: Daedius Moskvitch ( daedius @@@@ daedius com)
 |