Jamoma API
0.6.0.a19
|
Integration tests in the Cycling'74 Max hosting environment make use of the testpackage developed by Cycling'74. The testpackage should be installed in the Max/Packages
in your Documents folder (Mac). Make sure that the misc/testpackage-config.json
file has been properly configurated, you find details on how to do so in the ReadMe.html file in testpackage.
When you build the Jamoma externals for Max using the build.rb
script in the Implementation/Max
folder, integration testing is done by default at the end of the script. You can disable integration testing by providing a notest
argument to the script, but we recommend that integration tests are done on a regular basis. "Test Early. Test Often. Test Automatically" (Hunt & Thomas 1999).
Provided that the Implementations/Max/Jamoma
folder is registered as a package in Max, automated integration tests can be done at any time using the test.rb
script found in testpackage/ruby
. Please refer to the ReadMe.html file in testpackage for further details.
Additionally each individual integration test can be run manually at any time simply by opening it in Max as a regular patch.
Integration tests are located in Implementations/Max/Jamoma/patchers/integrationTests
. Depending on whether an external or functionality is an integration in Max of Foundation, DSP, Graph, AudioGraph or Modular, the test is located in the respective subfolder. The Modular folder contains quite a few tests, and they are further organised into separate subfolders for each external.
Each test need to end with *.maxtest-maxpat
. This is a requirement for it to be included in automated testing. If a integration test crash Max or stalls automated testing, it should be renamed so that it do not prevent other tests from being performed. Tests that lead to crashes are renamed *.maxtest-CRASH.maxpat
. Tests that stall automated testing are renamed *.maxtest-STALL.maxpat
. The issue that cause the crash or stall should be logged in the issue tracker, and once fixed the test shoudl be renamed back to the regular *.maxtest-maxpat
ending.
Each integration test need to have a unique name within the Max search path. In order to ensure this, the file name starts with the name of the object being tested. If more than one integration test exists for an object, the middle section of the filename can be used to distinguish and provide further details on what each file is testing for.
For a general introduction to developing integration tests, please refer to the documentation provided with 'testpackage'. All of the regular guidelines for testpackage are to be observed. When developing integration tests for JamomaMax, some additional guidelines must be followed:
Jamoma/Modular/name_of_external/furter_details_on_what_is_being_asserted
. This makes it easier to survey assertions in the database and sort them alphabetically, when reviewing the outcome of automated integration tests.