summaryrefslogtreecommitdiffstats
path: root/node_modules/reusify/test.js
diff options
context:
space:
mode:
authorGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
committerGravatar Piotr Russ <mail@pruss.it> 2020-11-16 00:10:28 +0100
commite06ec920f7a5d784e674c4c4b4e6d1da3dc7391d (patch)
tree55713f725f77b44ebfec86e4eec3ce33e71458ca /node_modules/reusify/test.js
downloadwebsite_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.gz
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.tar.bz2
website_creator-e06ec920f7a5d784e674c4c4b4e6d1da3dc7391d.zip
api, login, auth
Diffstat (limited to 'node_modules/reusify/test.js')
-rw-r--r--node_modules/reusify/test.js66
1 files changed, 66 insertions, 0 deletions
diff --git a/node_modules/reusify/test.js b/node_modules/reusify/test.js
new file mode 100644
index 0000000..929cfd7
--- /dev/null
+++ b/node_modules/reusify/test.js
@@ -0,0 +1,66 @@
+'use strict'
+
+var test = require('tape')
+var reusify = require('./')
+
+test('reuse objects', function (t) {
+ t.plan(6)
+
+ function MyObject () {
+ t.pass('constructor called')
+ this.next = null
+ }
+
+ var instance = reusify(MyObject)
+ var obj = instance.get()
+
+ t.notEqual(obj, instance.get(), 'two instance created')
+ t.notOk(obj.next, 'next must be null')
+
+ instance.release(obj)
+
+ // the internals keeps a hot copy ready for reuse
+ // putting this one back in the queue
+ instance.release(instance.get())
+
+ // comparing the old one with the one we got
+ // never do this in real code, after release you
+ // should never reuse that instance
+ t.equal(obj, instance.get(), 'instance must be reused')
+})
+
+test('reuse more than 2 objects', function (t) {
+ function MyObject () {
+ t.pass('constructor called')
+ this.next = null
+ }
+
+ var instance = reusify(MyObject)
+ var obj = instance.get()
+ var obj2 = instance.get()
+ var obj3 = instance.get()
+
+ t.notOk(obj.next, 'next must be null')
+ t.notOk(obj2.next, 'next must be null')
+ t.notOk(obj3.next, 'next must be null')
+
+ t.notEqual(obj, obj2)
+ t.notEqual(obj, obj3)
+ t.notEqual(obj3, obj2)
+
+ instance.release(obj)
+ instance.release(obj2)
+ instance.release(obj3)
+
+ // skip one
+ instance.get()
+
+ var obj4 = instance.get()
+ var obj5 = instance.get()
+ var obj6 = instance.get()
+
+ t.equal(obj4, obj)
+ t.equal(obj5, obj2)
+ t.equal(obj6, obj3)
+ t.end()
+})