Sha256: 06ed92659dc4690c02dc400dc052d5fd2db7bac0b1a2cbf91bb0179eed553345
Contents?: true
Size: 1.39 KB
Versions: 8
Compression:
Stored size: 1.39 KB
Contents
!3 Designing Tests with ColumnFixture Think of each row of a ColumnFixture as one or more function calls. The values of the named variables are set, and then the functions are called. For example, lets say you were writing an inventory system, and you wanted to test its ability to keep track of stocked items. You might write tables like this: |!-inventory.AddStockFixture-!| |partNumber|quantity|valid?| |324|28|true| |586|14|true| This test adds two stock items. The valid() function calls the parts of the system that cause a stock item to be added. The code for the !-AddStockFixture-! might look like this:{{{ package inventory; import fit.ColumnFixture; public class AddStockFixture extends ColumnFixture { public int partNumber; public int quantity; public boolean valid() { try { StockItem item = new StockItem(partNumber); Inventory.addStockItem(item,quantity); return true; } catch (Exception e) { return false; } } } }}}Next, we might write a table that simulates some purchases that reduce the stock of an item. |!-inventory.PurchaseItemFixture-!| |partNumber|quantity|valid?| |324|3|true| |586|2|true| It should be clear how this fixture would be written. Finally we'd write a table that checked to make sure that the inventory had been properly updated. |!-inventory.CheckInventoryFixture-!| |partNumber|quantity()| |324|25| |586|12| See how easy this is?
Version data entries
8 entries across 8 versions & 1 rubygems