mirror of
				https://kkgithub.com/actions/setup-python.git
				synced 2025-11-04 04:31:51 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			163 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# assert-plus
 | 
						|
 | 
						|
This library is a super small wrapper over node's assert module that has two
 | 
						|
things: (1) the ability to disable assertions with the environment variable
 | 
						|
NODE\_NDEBUG, and (2) some API wrappers for argument testing.  Like
 | 
						|
`assert.string(myArg, 'myArg')`.  As a simple example, most of my code looks
 | 
						|
like this:
 | 
						|
 | 
						|
```javascript
 | 
						|
    var assert = require('assert-plus');
 | 
						|
 | 
						|
    function fooAccount(options, callback) {
 | 
						|
        assert.object(options, 'options');
 | 
						|
        assert.number(options.id, 'options.id');
 | 
						|
        assert.bool(options.isManager, 'options.isManager');
 | 
						|
        assert.string(options.name, 'options.name');
 | 
						|
        assert.arrayOfString(options.email, 'options.email');
 | 
						|
        assert.func(callback, 'callback');
 | 
						|
 | 
						|
        // Do stuff
 | 
						|
        callback(null, {});
 | 
						|
    }
 | 
						|
```
 | 
						|
 | 
						|
# API
 | 
						|
 | 
						|
All methods that *aren't* part of node's core assert API are simply assumed to
 | 
						|
take an argument, and then a string 'name' that's not a message; `AssertionError`
 | 
						|
will be thrown if the assertion fails with a message like:
 | 
						|
 | 
						|
    AssertionError: foo (string) is required
 | 
						|
    at test (/home/mark/work/foo/foo.js:3:9)
 | 
						|
    at Object.<anonymous> (/home/mark/work/foo/foo.js:15:1)
 | 
						|
    at Module._compile (module.js:446:26)
 | 
						|
    at Object..js (module.js:464:10)
 | 
						|
    at Module.load (module.js:353:31)
 | 
						|
    at Function._load (module.js:311:12)
 | 
						|
    at Array.0 (module.js:484:10)
 | 
						|
    at EventEmitter._tickCallback (node.js:190:38)
 | 
						|
 | 
						|
from:
 | 
						|
 | 
						|
```javascript
 | 
						|
    function test(foo) {
 | 
						|
        assert.string(foo, 'foo');
 | 
						|
    }
 | 
						|
```
 | 
						|
 | 
						|
There you go.  You can check that arrays are of a homogeneous type with `Arrayof$Type`:
 | 
						|
 | 
						|
```javascript
 | 
						|
    function test(foo) {
 | 
						|
        assert.arrayOfString(foo, 'foo');
 | 
						|
    }
 | 
						|
```
 | 
						|
 | 
						|
You can assert IFF an argument is not `undefined` (i.e., an optional arg):
 | 
						|
 | 
						|
```javascript
 | 
						|
    assert.optionalString(foo, 'foo');
 | 
						|
```
 | 
						|
 | 
						|
Lastly, you can opt-out of assertion checking altogether by setting the
 | 
						|
environment variable `NODE_NDEBUG=1`.  This is pseudo-useful if you have
 | 
						|
lots of assertions, and don't want to pay `typeof ()` taxes to v8 in
 | 
						|
production.  Be advised:  The standard functions re-exported from `assert` are
 | 
						|
also disabled in assert-plus if NDEBUG is specified.  Using them directly from
 | 
						|
the `assert` module avoids this behavior.
 | 
						|
 | 
						|
The complete list of APIs is:
 | 
						|
 | 
						|
* assert.array
 | 
						|
* assert.bool
 | 
						|
* assert.buffer
 | 
						|
* assert.func
 | 
						|
* assert.number
 | 
						|
* assert.finite
 | 
						|
* assert.object
 | 
						|
* assert.string
 | 
						|
* assert.stream
 | 
						|
* assert.date
 | 
						|
* assert.regexp
 | 
						|
* assert.uuid
 | 
						|
* assert.arrayOfArray
 | 
						|
* assert.arrayOfBool
 | 
						|
* assert.arrayOfBuffer
 | 
						|
* assert.arrayOfFunc
 | 
						|
* assert.arrayOfNumber
 | 
						|
* assert.arrayOfFinite
 | 
						|
* assert.arrayOfObject
 | 
						|
* assert.arrayOfString
 | 
						|
* assert.arrayOfStream
 | 
						|
* assert.arrayOfDate
 | 
						|
* assert.arrayOfRegexp
 | 
						|
* assert.arrayOfUuid
 | 
						|
* assert.optionalArray
 | 
						|
* assert.optionalBool
 | 
						|
* assert.optionalBuffer
 | 
						|
* assert.optionalFunc
 | 
						|
* assert.optionalNumber
 | 
						|
* assert.optionalFinite
 | 
						|
* assert.optionalObject
 | 
						|
* assert.optionalString
 | 
						|
* assert.optionalStream
 | 
						|
* assert.optionalDate
 | 
						|
* assert.optionalRegexp
 | 
						|
* assert.optionalUuid
 | 
						|
* assert.optionalArrayOfArray
 | 
						|
* assert.optionalArrayOfBool
 | 
						|
* assert.optionalArrayOfBuffer
 | 
						|
* assert.optionalArrayOfFunc
 | 
						|
* assert.optionalArrayOfNumber
 | 
						|
* assert.optionalArrayOfFinite
 | 
						|
* assert.optionalArrayOfObject
 | 
						|
* assert.optionalArrayOfString
 | 
						|
* assert.optionalArrayOfStream
 | 
						|
* assert.optionalArrayOfDate
 | 
						|
* assert.optionalArrayOfRegexp
 | 
						|
* assert.optionalArrayOfUuid
 | 
						|
* assert.AssertionError
 | 
						|
* assert.fail
 | 
						|
* assert.ok
 | 
						|
* assert.equal
 | 
						|
* assert.notEqual
 | 
						|
* assert.deepEqual
 | 
						|
* assert.notDeepEqual
 | 
						|
* assert.strictEqual
 | 
						|
* assert.notStrictEqual
 | 
						|
* assert.throws
 | 
						|
* assert.doesNotThrow
 | 
						|
* assert.ifError
 | 
						|
 | 
						|
# Installation
 | 
						|
 | 
						|
    npm install assert-plus
 | 
						|
 | 
						|
## License
 | 
						|
 | 
						|
The MIT License (MIT)
 | 
						|
Copyright (c) 2012 Mark Cavage
 | 
						|
 | 
						|
Permission is hereby granted, free of charge, to any person obtaining a copy of
 | 
						|
this software and associated documentation files (the "Software"), to deal in
 | 
						|
the Software without restriction, including without limitation the rights to
 | 
						|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
 | 
						|
the Software, and to permit persons to whom the Software is furnished to do so,
 | 
						|
subject to the following conditions:
 | 
						|
 | 
						|
The above copyright notice and this permission notice shall be included in all
 | 
						|
copies or substantial portions of the Software.
 | 
						|
 | 
						|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
						|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
						|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
						|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
						|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
						|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 | 
						|
SOFTWARE.
 | 
						|
 | 
						|
## Bugs
 | 
						|
 | 
						|
See <https://github.com/mcavage/node-assert-plus/issues>.
 |