Sha256: bd4254de9e09072fea02d2961435a226bef38833614d59b93a0d2b7b2d44c14d

Contents?: true

Size: 1.45 KB

Versions: 70

Compression:

Stored size: 1.45 KB

Contents

// In these tests, we do the following:
// try for 200ms (rt=2)
// wait for 300ms
// try for 200ms (rt=1)
// wait for 300ms
// try for 200ms (rt=0)
// fail after 1200
// Actual time will be more like 1220-ish for setTimeout irregularity
// But it should NOT be as slow as 2000.

var lockFile = require('../')
var touch = require('touch')
var test = require('tap').test
var fs = require('fs')

var RETRYWAIT = 100
var WAIT = 100
var RETRIES = 2
var EXPECTTIME = (RETRYWAIT * RETRIES) + (WAIT * (RETRIES + 1))
var TOOLONG = EXPECTTIME * 1.1

test('setup', function (t) {
  touch.sync('file.lock')
  t.end()
})

var pollPeriods = [10, 100, 10000]
pollPeriods.forEach(function (pp) {
  test('retry+wait, poll=' + pp, function (t) {
    var ended = false
    var timer = setTimeout(function() {
      t.fail('taking too long!')
      ended = true
      t.end()
    }, 2000)
    timer.unref()

    var start = Date.now()
    lockFile.lock('file.lock', {
      wait: WAIT,
      retries: RETRIES,
      retryWait: RETRYWAIT,
      pollPeriod: pp
    }, function (er) {
      if (ended) return
      var time = Date.now() - start
      console.error('t=%d', time)
      t.ok(time >= EXPECTTIME, 'should take at least ' + EXPECTTIME)
      t.ok(time < TOOLONG, 'should take less than ' + TOOLONG)
      clearTimeout(timer)
      t.end()
    })
  })
})

test('cleanup', function (t) {
  fs.unlinkSync('file.lock')
  t.end()
  setTimeout(function() {
    process.exit(1)
  }, 500).unref()
})

Version data entries

70 entries across 70 versions & 3 rubygems

Version Path
trusty-festivity-extension-2.6.3 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.6.2 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.6.1 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.6 node_modules/bower/node_modules/lockfile/test/retry-time.js
node-compiler-0.7.0 vendor/node-v6.9.1/deps/npm/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.19 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.18 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.17 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.16 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.15 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.14 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.13 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.12 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.11 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.10 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.9 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.8 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.7 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.6 node_modules/bower/node_modules/lockfile/test/retry-time.js
trusty-festivity-extension-2.5.5 node_modules/bower/node_modules/lockfile/test/retry-time.js