test-suite
Folders and files
Name | Name | Last commit date | ||
---|---|---|---|---|
parent directory.. | ||||
Sweety SimpleTest Suite ----------------------- Sweety is a wrapper around SimpleTest's XML reporting capabilities which makes unit tests easier to manage and friendlier to run. Tests are run in a grouped fashion, but each individual test runs in its own environment and own memory space either via forking new PHP processes, or by making new HTTP requests. Sweety works with any vanilla version of SimpleTest since the XmlReporter was added. Tests can be run on command line, in an AJAX equipped web browser*, or in a web browser with javascript turned off. * Sweety has been tested with success in the following browsers: - Mozilla Firefox 2.0 - Safari 3-beta - Internet Explorer 7 - Opera 9 Configuring Sweety: -------------------- All Sweety configuration is contained inside the config.php file, defined as constants for the mostpart. Make sure you at least indicate a path to a directory containing SimpleTest, and also change the SWEETY_INCLUDE_PATH and SWEETY_TEST_PATH to fit your needs. Paths are provided using the directory separator for your OS. Use the PHP constant PATH_SEPARATOR if you need to run in different environments. If you have test cases in directories /webdev/tests/unit and /webdev/tests/integration your SWEETY_TEST_PATH should look like: define('SWEETY_TEST_PATH', '/webdev/tests/unit' . PATH_SEPARATOR . '/webdev/tests/integration'); If you want to run Sweety on the command line you'll need to specify the path to your PHP executable (typically /usr/bin/php). Sweety needs to be able to fork new processes using this executable. What to do if your naming scheme doesn't use PEAR conventions: -------------------------------------------------------------- By default Sweety looks for classes using PEAR naming conventions. If you use some other naming convention you need to tell Sweety how to find your test cases. This is a two step process: 1) Write a new Sweety_TestLocator -- don't worry, it's easy! Refer to the interface in lib/Sweety/TestLocator.php for guidance on what your TestLocator needs to include (just two methods for searching and including). 2) Add it to your config.php. Once you've written a new TestLocator which works for your naming scheme, change the config value SWEETY_TEST_LOCATOR to the name of your new class, then include the class file somewhere inside the config.php. If you use multiple class naming conventions, list your TestLocators as a comma separated string. Making tests appear in Sweety's interface: ------------------------------------------- No really, you just edit the configuration and they'll show up if a TestLocator can find them ;) Running sweety on the command line: ----------------------------------- Interacting with Sweety on the command line you'll get almost as much detail as you do in a web browser, although the formatting obviously isn't so pretty! All operations are handled by the file named run.php in the sweety installation directory. -bash$ php run.php #runs all tests -bash$ php run.php Name_Of_TestClass #runs a single test case -bash$ php run.php Name_Of_TestClass xml #runs a single test case in XML Runing Sweety with AJAX: ------------------------- Open up an AJAX equipped web browsers (preferably supporting DOM 3 XPath, but at least support basic DOM). Navigate to the index.php file at the installation directory of Sweety. You'll see the screen is divided into two sections, left and right. On the left there's a list of test cases which you can click to run. On the right you get all the verbose output from running the tests. Clicking the "Run Tests" button will run all tests you can currently see in the list. As each test runs, a request is sent to the web server to get SimpleTest to run your test case. If the test passes the test case will turn green, if it fails it will turn red. Tests go yellow until a final conclusion is drawn. If you need to stop the tests at any time just click the button again (it should say "Stop Tests" whilst the tests run). Whilst the tests run, the large bar to the right of the screen will tally up aggregated results and will eventually go either green or red indicating a pass or failure. Failed assertion messages will appear in the page just like they do with the HtmlReporter of SimpleTest. Clicking a single test case will run just that test in isolation. If you want (or need?) to run the test with SimpleTest's HtmlReporter just click the HTML Icon (little world image) next to the test case. Tests can also be run in XML if needed. Above the list of tests there's a filter box which can be directly typed into. Typing in here narrows down the list of testcases to show only the ones which match the search query. Refreshing the page with your browser's refresh button will reset the test suite. When you change your code, you DO NOT need to refesh your browser window. Just click the "Run Tests" button, or click the individual test to refresh the results. If you add a new test case you will need to refresh your browser window however. Running Sweety without JavaScript: ---------------------------------- If your web browser has JavaScript disabled you can still use the HTML version of the test suite. Open up the index.php file in your web browser. You'll see the screen is divided into two sections, left and right. On the left there's a list of test cases with checkboxes next to them which you can check to run. On the right you get all the verbose output from running the tests. Clicking the "Run Tests" button will run all the currently selected test cases. This could take a long time depending upon how many tests you have to run, but once complete you'll see the page again where the tests you selected will either be red or green indicating a pass or failure. The bar at the right of the screen will contain aggregate results for all the tests and will be either red or green to indicate an overall pass or failure. Assertion messages appear in the page just like with SimpleTest's HtmlReporter. If you want to run just a single test case, click the "Run" icon at the right of the test (little running man image). You can run tests with SimpleTest's HtmlReporter by clicking the HTML icon (little world image) next to the test case. Tests can be run in XML if needed too. Enjoy!