Difference between revisions of "CddBranch"
|  (→Clean up/Delete) |  (→What is the CDD EiffelStudio?) | ||
| Line 7: | Line 7: | ||
| [[Image:cdd_logo.png|center]] | [[Image:cdd_logo.png|center]] | ||
| + | [http://se.ethz.ch/people/leitner/cdd/video/ CDD Video, click here] | ||
| CDD (short for Contract Driven Development) is a project developed at [http://se.ethz.ch ETH Zurich]. It adds advanced support for unit testing to EiffelStudio. With CDD EiffelStudio you can | CDD (short for Contract Driven Development) is a project developed at [http://se.ethz.ch ETH Zurich]. It adds advanced support for unit testing to EiffelStudio. With CDD EiffelStudio you can | ||
| Line 21: | Line 22: | ||
| [[Image:cdd_panel.png|center]] | [[Image:cdd_panel.png|center]] | ||
| − | |||
| == Download CDD == | == Download CDD == | ||
Revision as of 02:38, 19 March 2008
Contents
- 1 What is the CDD EiffelStudio?
- 2 Download CDD
- 3 Documentation
- 3.1 Manually Written Test Cases
- 3.2 Extracted Test Cases
- 3.3 Test outcomes
- 3.4 Debug Test Case
- 3.5 Enable/Disable Execution of Test Cases in Background
- 3.6 Enable/Disable automatic extraction of Test Cases
- 3.7 Clean up/Delete
- 3.8 Create new manual test class
- 3.9 Search for tags
- 3.10 Restrict execution of test cases
- 3.11 Change test case view
 
- 4 Further Documentation and Common Problems
- 5 Related Publications
- 6 Project Internal Stuff
What is the CDD EiffelStudio?
CDD (short for Contract Driven Development) is a project developed at ETH Zurich. It adds advanced support for unit testing to EiffelStudio. With CDD EiffelStudio you can
- Write test cases
- Manage test cases (using tags)
- Run test cases
- View test outcomes
- 'Automatically extract test cases'
If you have questions, feedback, or would like to report a bug please visit the CDD forum.
CDD EiffelStudio adds the following panel to regular EiffelStudio:
Download CDD
The following packages contain the full EiffelStudio 6.1 plus the CDD extension. You do not need to have EiffelStudio installed already in order to install below packages. On Windows you do have to have either the Platform SDK or Visual C++ installed. Do not use EiffelStudio with the gcc/mingw or the .Net backend.
Linux
- Full Linux version: http://se.ethz.ch/people/leitner/cdd/Eiffel61_cdd_final_5.tar.bz2
- Installation instructions: http://docs.eiffel.com/eiffelstudio/installation/studio/060_linux.html
Download the above file and install it just like you would install a EiffelStudio tar ball. Afterwards proceed to section "Using CDD". Make sure you set/update the environment variables PATH, ISE_EIFFEL, and ISE_PLATFORM according to the installation instructions.
Windows
- Full Windows version (with installer): http://n.ethz.ch/~moris/download/Eiffel61_cdd_final_5-windows.msi
- Note 1: Installation is independent of installations of official EiffelStudio 6.1 (neither overwrites nor invalidates nor is influenced by those)
- Note 2: If you have a previous installation of the CDD Edition of EiffelStudio installed, you need to uninstall it first. If you want to reuse the installation directory, you need to manually delete all EIFGENs in its subdirectories after the uninstall procedure.
- Note 3: Do not use the gcc/mingw or the .NET compiler backend. You will have to use the Microsoft C compiler. You can get it either by installing Visual C++, or via (the freely available) Microsoft Platform SDK.Have a look at http://eiffelsoftware.origo.ethz.ch/Installing_Microsoft_C_compiler to learn how to install either compiler.
Documentation
Manually Written Test Cases
CDD Eiffelstudio allows you to create a new “empty” test case. These test cases are similar to jUnit test cases. A manually written test class must start with the word “TEST” and all test routines also have to start with the word “test”. It also has to inherit from class CDD_TEST_CASE.
Extracted Test Cases
CDD EiffelStudio automatically extracts test cases whenever you run your program and an exception is triggered. This feature is novel and not yet part of any other testing environment. You will be the first to try it out.
Test outcomes
A test case checks whether your program contains a particular bug. A test cases can fail indicating that the bug is present in your program, or pass indicating your program does not contain this bug. Sometimes test cases will be unresolved, in which case the testing framework was unable to find out whether the test case passed or failed. A test case can be unresolved for several reasons.
Debug Test Case
Select a test case and press this button to run a test case in the debugger.
Enable/Disable Execution of Test Cases in Background
If enabled, all test cases are retested every time you press compile. If disabled no test cases are executed.
Enable/Disable automatic extraction of Test Cases
If enabled every time an exception is triggered a set of test cases that try to reproduce this exception is extracted. If disabled no test cases are extracted.
Clean up/Delete
You can use the “Clean Up/Delete” button in two different ways. By simply pressing it you will delete all unresolved test cases. By pick and dropping a test case to the “Clean up/Delete” button (right click on test case, move mouse to button and right click again) you can delete a test case. By the way, test cases are just regular classes. So you can use all existing tools that apply to classes in EiffelStudio too.
Update: To remove duplicate test cases (until the next cdd update), please use the command-line tool from the clean-cdd project.
Create new manual test class
Press this button to create a empty test class. You can then edit the class to add manually written test cases. This is how a manually written test case can look like:
class TEST_BANK_ACCOUNT inherit CDD_TEST_CASE feature test_deposit local ba: BANK_ACCOUNT do create ba.make_with_balance (0) ba.deposit (100) check money_depisited: ba.balance = 100 end end end
Search for tags
Enter keywords to search for paritcular test cases. Some tags are automatically set for you like the name of the test case. You can also easily add your own tags by adding an indexing item "tag" to your test class or routine:
indexing tag: "fixme" class TEST_BANK_ACCOUNT inherit CDD_TEST_CASE feature ... end
Tags can be adde to all test routines and classes. Whether they are extracted or manually written does not matter.
Restrict execution of test cases
Once you have many test cases, you will run into situation where you don't want to execute all of them. The restrict button will help you to achieve this. As long as the "Restrict" button is pushed test cases that don't show up in the test case view will not be tested. Execution is restricted to those test cases that do show up.
Change test case view
Select one of several predefined test case views. For example you can group test cases by their outcome to quickly see only failing test cases.
Further Documentation and Common Problems
Please visit Using CDD for further documentation or look at Common Problems if you run into problems.
Related Publications
- Leitner, A., Ciupa, I., Oriol, M., Meyer, B., Fiva, A., "Contract Driven Development = Test Driven Development - Writing Test Cases", Proceedings of ESEC/FSE'07: European Software Engineering Conference and the ACM SIGSOFT Symposium on the Foundations of Software Engineering 2007, (Dubrovnik, Croatia), September 2007 (pdf)
- Sunghun Kim, Shay Artzi, and Michael D. Ernst, "reCrash: Making Crash Reproducible" MIT Computer Science and Artificial Intelligence Laboratory technical report MIT-CSAIL-TR-2007-054, (Cambridge, MA), November 20, 2007. (pdf)






