Sha256: f2d07ebd138efa3d7d425ffa9f64ba1ae2b80d15e264357a126ebda8e82438ed
Contents?: true
Size: 1.18 KB
Versions: 2
Compression:
Stored size: 1.18 KB
Contents
# QED Demonstrandum ## Steps QED demos are light-weight specification documents, highly suitable to interface-driven design. The documents are divided up into steps separated by blank lines. Steps that are flush to the left margin are always explanatory comments. Indented steps are either executable code or plain text samples. Each step is executed in order of appearance within a rescue wrapper that captures any failures or errors. If neither a failure or error occur then the step gets a "pass". For example, the following passes. (2 + 2).assert == 4 While the following would "fail", as indicated by the raising of an Assertion error. expect Assertion do (2 + 2).assert == 5 end And this would have raised a NameError. expect NameError do nobody_knows_method end ## Defining Custom Assertions The context in which the QED code is run is a self-extended module, thus reusable macros can be created simply by defining a method. def assert_integer(x) x.assert.is_a? Integer end Now lets try out our new macro definition. assert_integer(4) Let's prove that it can also fail. expect Assertion do assert_integer("IV") end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
qed-2.9.2 | demo/01_demos.md |
qed-2.9.1 | demo/01_demos.md |