JavaScript objects and arrays for testing purposes.
npm install --save-dev test-constructs
const tc = require('test-constructs')
console.log(tc.rndObject()) // <= A random object
console.log(tc.rndString()) // <= A random string
console.log(tc.rndJson()) // <= A random JSON string
console.log(tc.arrays.strings) // <= An array of strings
console.log(tc.arrays.types) // <= An array of JavaScript types
console.log(tc.objects.asArray) // <= An array of objects
console.log(tc.objects.byName.foo) // <= The foo object
console.log(tc.objects.bySize.small) // <= A small object
console.log(tc.objects.special.circular) // <= A special object
console.log(tc.json.asArray) // <= An array of JSON strings
console.log(tc.json.byName.foo) // <= The foo object as a JSON string
console.log(tc.json.bySize.small) // <= A small JSON string
console.log(tc.objects.special.deep) // <= A special object as a JSON string
After writing test data for console-probe and perj I decided to modularise it.
The best option to understand what you get from test-constructs
is to look through the source code.
Returns randomly one of the objects available under objects.asArray
.
Does not include the special objects.
Returns randomly one of the strings available under arrays.strings
.
Returns randomly one of the JSON strings available under json.asArray
.
Returns an object with the following properties:
strings
- Returns an array of strings.types
- Returns an array containing a large number of different JavaScript types.
Returns an object with the following properties:
asArray
- Returns an array of objects not including the special objects.bySize
- Returns an object by a size name such asobjects.bySize.large
.byName
- Returns an object by a name such asobjects.byName.tardis
.special
- Returns special objects such asobjects.special.circular
.
Returns an object with the following properties:
asArray
- Returns an array of stringified object strings.bySize
- Returns a JSON string by a size name such asjson.bySize.small
.byName
- Returns a JSON string by the object name such asjson.byName.deathStar
.special
- Returns a JSON string by the special object name such asjson.special.deep
.
Note: The circular object is not available under special
because JSON.stringify
will not convert circular objects.
I, Grant Carthew, am a technologist, trainer, and Dad from Queensland, Australia. I work on code in a number of personal projects and when the need arises I build my own packages.
This project exists because I needed testing data.
Everything I do in open source is done in my own time and as a contribution to the open source community.
If you are using my projects and would like to thank me or support me, please click the Patreon link below.
See my other projects on NPM.
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -am 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request :D
- v1.0.0 [2018-07-06]: Initial release.