dshould ~master
D fluent asserts library
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
should
dshould is a library that implements fluent asserts using common keywords such as should
, not
, be
, equal
, greater
and so on.
Each sentence must begin with should
.
Note that these asserts are only examples; for instance, the word not
can be used in any sentence.
When in doubt, use English grammar. If an intuitive combination of words does not work, please file a bug report.
When a test fails, the message is always a variation of "Expected [right], but got [left]".
Basic use
value.should.equal(value);
value.should.be(value); // same thing
value.should.not.be(value);
value.should.be.greater(value);
value.should.be.less.equal(value);
value.should.approximately.equal(value, error=plusminus);
object.should.not.be.same.as(object2); // reference comparison
object.should.be(null); // null is always reference comparison
Arrays
array.should.not.be(null);
array.should.be.empty;
array.should.equal(array);
array.should.contain(value);
array.should.contain.all(values);
array.should.not.contain.any(values);
array.should.contain.only(values);
range.should.contain.exactly(values); // unordered comparison
Strings
string.should.not.be.empty;
string.should.equal(string);
For strings, equal
will use diff colors in its output - red indicates missing expected characters,
and green indicates unexpected characters.
For multiline strings, red indicates missing expected lines, and green indicates unexpected lines.
Exceptions
expression.should.throwAn!Exception;
expression.should.throwA!Throwable;
The words throwA
and throwAn
are identical; their only difference is grammatical.
The exception of the given type is caught and returned, and may be accessed with the property .where
.
expression.should.throwAn!Exception.where.msg.should.equal("Assertion failed!");
When negated with not
, throwA
returns void
.
Extensions
should
can be extended by defining further functions representing words.
This takes the form:
import dshould.ShouldType;
// for nonterminal words, such as 'not':
auto <word>(Should)(Should should)
if (isInstanceOf!(ShouldType, Should))
{
...
}
// for terminal words, such as 'equal':
void <word>(Should, T)(Should should, T expected,
Fence _ = Fence(), string file = __FILE__, size_t line = __LINE__)
if (isInstanceOf!(ShouldType, Should))
{
}
The Fence
parameter is used to fence off the file/line parameters from parameters provided by users.
It ensures that the file
parameter is never provided by accident, for instance if a user falsely believes that a
function takes a string argument.
The should
parameter has the following properties:
should.addWord!"word"
to add a word to the current sentence.should.hasWord!"word"
to check if a word appears in the current sentence.should.allowOnlyWords!("word", "word").before!"this word"
to limit the permissible words to appear before this word.should.requireWord!"word".before!"this word"
to require that a word appear before this one.should.got()
to evaluate the left-hand side of theshould
sentence, ie. the expression appearing before.should
.check(condition, expectedMessage, butGotMessage, file, line)
to actually check theshould
condition. When the condition is violated, a FluentException is thrown, whosemsg
has the form: "Test failed: expected {expectedMessage}, but got {butGotMessage}".
- ~master released 5 months ago
- funkwerk-mobility/dshould
- MIT
- Authors:
- Dependencies:
- none
- Versions:
-
1.7.2 2024-Aug-14 1.7.1 2022-Dec-05 1.7.0 2022-Jul-05 1.6.1 2022-Jul-05 1.6.0 2022-Jul-01 - Download Stats:
-
-
22 downloads today
-
362 downloads this week
-
1103 downloads this month
-
25757 downloads total
-
- Score:
- 2.9
- Short URL:
- dshould.dub.pm