1More(3)               User Contributed Perl Documentation              More(3)
2
3
4

NAME

6       Carp::Assert::More - Convenience assertions for common situations
7

VERSION

9       Version 2.0.1
10

SYNOPSIS

12       A set of convenience functions for common assertions.
13
14           use Carp::Assert::More;
15
16           my $obj = My::Object;
17           assert_isa( $obj, 'My::Object', 'Got back a correct object' );
18

DESCRIPTION

20       Carp::Assert::More is a convenient set of assertions to make the habit
21       of writing assertions even easier.
22
23       Everything in here is effectively syntactic sugar.  There's no
24       technical difference between calling one of these functions:
25
26           assert_datetime( $foo );
27           assert_isa( $foo, 'DateTime' );
28
29       that are provided by Carp::Assert::More and calling these assertions
30       from Carp::Assert
31
32           assert( defined $foo );
33           assert( ref($foo) eq 'DateTime' );
34
35       My intent here is to make common assertions easy so that we as
36       programmers have no excuse to not use them.
37

SIMPLE ASSERTIONS

39   assert_is( $string, $match [,$name] )
40       Asserts that $string matches $match.
41
42   assert_isnt( $string, $unmatch [,$name] )
43       Asserts that $string does NOT match $unmatch.
44
45   assert_like( $string, qr/regex/ [,$name] )
46       Asserts that $string matches qr/regex/.
47
48       The assertion fails either the string or the regex are undef.
49
50   assert_unlike( $string, qr/regex/ [,$name] )
51       Asserts that $string matches qr/regex/.
52
53       The assertion fails if the regex is undef.
54
55   assert_defined( $this [, $name] )
56       Asserts that $this is defined.
57
58   assert_undefined( $this [, $name] )
59       Asserts that $this is not defined.
60
61   assert_nonblank( $this [, $name] )
62       Asserts that $this is not a reference and is not an empty string.
63

NUMERIC ASSERTIONS

65   assert_numeric( $n [, $name] )
66       Asserts that $n looks like a number, according to
67       "Scalar::Util::looks_like_number".  "undef" will always fail.
68
69   assert_integer( $this [, $name ] )
70       Asserts that $this is an integer, which may be zero or negative.
71
72           assert_integer( 0 );      # pass
73           assert_integer( 14 );     # pass
74           assert_integer( -14 );    # pass
75           assert_integer( '14.' );  # FAIL
76
77   assert_nonzero( $this [, $name ] )
78       Asserts that the numeric value of $this is defined and is not zero.
79
80           assert_nonzero( 0 );    # FAIL
81           assert_nonzero( -14 );  # pass
82           assert_nonzero( '14.' );  # pass
83
84   assert_positive( $this [, $name ] )
85       Asserts that $this is defined, numeric and greater than zero.
86
87           assert_positive( 0 );    # FAIL
88           assert_positive( -14 );  # FAIL
89           assert_positive( '14.' );  # pass
90
91   assert_nonnegative( $this [, $name ] )
92       Asserts that $this is defined, numeric and greater than or equal to
93       zero.
94
95           assert_nonnegative( 0 );      # pass
96           assert_nonnegative( -14 );    # FAIL
97           assert_nonnegative( '14.' );  # pass
98           assert_nonnegative( 'dog' );  # pass
99
100   assert_negative( $this [, $name ] )
101       Asserts that the numeric value of $this is defined and less than zero.
102
103           assert_negative( 0 );       # FAIL
104           assert_negative( -14 );     # pass
105           assert_negative( '14.' );   # FAIL
106
107   assert_nonzero_integer( $this [, $name ] )
108       Asserts that the numeric value of $this is defined, an integer, and not
109       zero.
110
111           assert_nonzero_integer( 0 );      # FAIL
112           assert_nonzero_integer( -14 );    # pass
113           assert_nonzero_integer( '14.' );  # FAIL
114
115   assert_positive_integer( $this [, $name ] )
116       Asserts that the numeric value of $this is defined, an integer and
117       greater than zero.
118
119           assert_positive_integer( 0 );     # FAIL
120           assert_positive_integer( -14 );   # FAIL
121           assert_positive_integer( '14.' ); # FAIL
122           assert_positive_integer( '14' );  # pass
123
124   assert_nonnegative_integer( $this [, $name ] )
125       Asserts that the numeric value of $this is defined, an integer, and not
126       less than zero.
127
128           assert_nonnegative_integer( 0 );      # pass
129           assert_nonnegative_integer( -14 );    # FAIL
130           assert_nonnegative_integer( '14.' );  # FAIL
131
132   assert_negative_integer( $this [, $name ] )
133       Asserts that the numeric value of $this is defined, an integer, and
134       less than zero.
135
136           assert_negative_integer( 0 );      # FAIL
137           assert_negative_integer( -14 );    # pass
138           assert_negative_integer( '14.' );  # FAIL
139

REFERENCE ASSERTIONS

141   assert_isa( $this, $type [, $name ] )
142       Asserts that $this is an object of type $type.
143
144   assert_isa_in( $obj, \@types [, $description] )
145       Assert that the blessed $obj isa one of the types in "\@types".
146
147           assert_isa_in( $obj, [ 'My::Foo', 'My::Bar' ], 'Must pass either a Foo or Bar object' );
148
149   assert_empty( $this [, $name ] )
150       $this must be a ref to either a hash or an array.  Asserts that that
151       collection contains no elements.  Will assert (with its own message,
152       not $name) unless given a hash or array ref.   It is OK if $this has
153       been blessed into objecthood, but the semantics of checking an object
154       to see if it does not have keys (for a hashref) or returns 0 in scalar
155       context (for an array ref) may not be what you want.
156
157           assert_empty( 0 );       # FAIL
158           assert_empty( 'foo' );   # FAIL
159           assert_empty( undef );   # FAIL
160           assert_empty( {} );      # pass
161           assert_empty( [] );      # pass
162           assert_empty( {foo=>1} );# FAIL
163           assert_empty( [1,2,3] ); # FAIL
164
165   assert_nonempty( $this [, $name ] )
166       $this must be a ref to either a hash or an array.  Asserts that that
167       collection contains at least 1 element.  Will assert (with its own
168       message, not $name) unless given a hash or array ref.   It is OK if
169       $this has been blessed into objecthood, but the semantics of checking
170       an object to see if it has keys (for a hashref) or returns >0 in scalar
171       context (for an array ref) may not be what you want.
172
173           assert_nonempty( 0 );       # FAIL
174           assert_nonempty( 'foo' );   # FAIL
175           assert_nonempty( undef );   # FAIL
176           assert_nonempty( {} );      # FAIL
177           assert_nonempty( [] );      # FAIL
178           assert_nonempty( {foo=>1} );# pass
179           assert_nonempty( [1,2,3] ); # pass
180
181   assert_nonref( $this [, $name ] )
182       Asserts that $this is not undef and not a reference.
183
184   assert_hashref( $ref [,$name] )
185       Asserts that $ref is defined, and is a reference to a (possibly empty)
186       hash.
187
188       NB: This method returns false for objects, even those whose underlying
189       data is a hashref. This is as it should be, under the assumptions that:
190
191       (a) you shouldn't rely on the underlying data structure of a particular
192           class, and
193
194       (b) you should use "assert_isa" instead.
195
196   assert_hashref_nonempty( $ref [,$name] )
197       Asserts that $ref is defined and is a reference to a hash with at least
198       one key/value pair.
199
200   assert_arrayref( $ref [, $name] )
201   assert_listref( $ref [,$name] )
202       Asserts that $ref is defined, and is a reference to an array, which may
203       or may not be empty.
204
205       NB: The same caveat about objects whose underlying structure is a hash
206       (see "assert_hashref") applies here; this method returns false even for
207       objects whose underlying structure is an array.
208
209       "assert_listref" is an alias for "assert_arrayref" and may go away in
210       the future.  Use "assert_arrayref" instead.
211
212   assert_arrayref_nonempty( $ref [, $name] )
213       Asserts that $ref is reference to an array that has at least one
214       element in it.
215
216   assert_aoh( $ref [, $name ] )
217       Verifies that $array is an arrayref, and that every element is a
218       hashref.
219
220       The array $array can be an empty arraref and the assertion will pass.
221
222   assert_coderef( $ref [,$name] )
223       Asserts that $ref is defined, and is a reference to a closure.
224

TYPE-SPECIFIC ASSERTIONS

226   assert_datetime( $date )
227       Asserts that $date is a DateTime object.
228

SET AND HASH MEMBERSHIP

230   assert_in( $string, \@inlist [,$name] );
231       Asserts that $string matches one of the elements of \@inlist.  $string
232       may be undef.
233
234       \@inlist must be an array reference of non-ref strings.  If any element
235       is a reference, the assertion fails.
236
237   assert_exists( \%hash, $key [,$name] )
238   assert_exists( \%hash, \@keylist [,$name] )
239       Asserts that %hash is indeed a hash, and that $key exists in %hash, or
240       that all of the keys in @keylist exist in %hash.
241
242           assert_exists( \%custinfo, 'name', 'Customer has a name field' );
243
244           assert_exists( \%custinfo, [qw( name addr phone )],
245                                   'Customer has name, address and phone' );
246
247   assert_lacks( \%hash, $key [,$name] )
248   assert_lacks( \%hash, \@keylist [,$name] )
249       Asserts that %hash is indeed a hash, and that $key does NOT exist in
250       %hash, or that none of the keys in @keylist exist in %hash.  The list
251       @keylist cannot be empty.
252
253           assert_lacks( \%users, 'root', 'Root is not in the user table' );
254
255           assert_lacks( \%users, [qw( root admin nobody )], 'No bad usernames found' );
256
257   assert_all_keys_in( \%hash, \@names [, $name ] )
258       Asserts that each key in %hash is in the list of @names.
259
260       This is used to ensure that there are no extra keys in a given hash.
261
262           assert_all_keys_in( $obj, [qw( height width depth )], '$obj can only contain height, width and depth keys' );
263
264       You can pass an empty list of @names.
265
266   assert_keys_are( \%hash, \@keys [, $name ] )
267       Asserts that the keys for %hash are exactly @keys, no more and no less.
268

CONTEXT ASSERTIONS

270   assert_context_nonvoid( [$name] )
271       Verifies that the function currently being executed has not been called
272       in void context.  This is to ensure the calling function is not
273       ignoring the return value of the executing function.
274
275       Given this function:
276
277           sub something {
278               ...
279
280               assert_context_scalar();
281
282               return $important_value;
283           }
284
285       These calls to "something" will pass:
286
287           my $val = something();
288           my @things = something();
289
290       but this will fail:
291
292           something();
293
294   assert_context_scalar( [$name] )
295       Verifies that the function currently being executed has been called in
296       scalar context.  This is to ensure the calling function is not ignoring
297       the return value of the executing function.
298
299       Given this function:
300
301           sub something {
302               ...
303
304               assert_context_scalar();
305
306               return $important_value;
307           }
308
309       This call to "something" will pass:
310
311           my $val = something();
312
313       but these will fail:
314
315           something();
316           my @things = something();
317

UTILITY ASSERTIONS

319   assert_fail( [$name] )
320       Assertion that always fails.  "assert_fail($msg)" is exactly the same
321       as calling "assert(0,$msg)", but it eliminates that case where you
322       accidentally use "assert($msg)", which of course never fires.
323
325       Copyright 2005-2021 Andy Lester.
326
327       This program is free software; you can redistribute it and/or modify it
328       under the terms of the Artistic License version 2.0.
329

ACKNOWLEDGEMENTS

331       Thanks to Eric A. Zarko, Bob Diss, Pete Krawczyk, David Storrs, Dan
332       Friedman, Allard Hoeve, Thomas L. Shinnick, and Leland Johnson for code
333       and fixes.
334
335
336
337perl v5.34.0                      2022-01-20                           More(3)
Impressum