2014-11-07 12:42:02 -04:00
|
|
|
expect = require('chai').expect
|
|
|
|
_ = require('lodash')
|
2014-11-17 15:32:35 -04:00
|
|
|
async = require('async')
|
|
|
|
fs = require('fs')
|
2014-11-26 14:22:01 -04:00
|
|
|
fsUtils = require('./fs-utils/fs-utils')
|
2014-11-17 15:32:35 -04:00
|
|
|
rimraf = require('rimraf')
|
2014-11-07 12:42:02 -04:00
|
|
|
dataPrefix = require('./data-prefix')
|
2014-12-03 12:03:54 -04:00
|
|
|
settings = require('../settings')
|
2014-11-26 12:56:52 -04:00
|
|
|
mock = require('../../../tests/utils/mock')
|
2014-11-07 12:42:02 -04:00
|
|
|
|
2014-11-07 12:43:10 -04:00
|
|
|
describe 'DataPrefix:', ->
|
2014-11-07 12:42:02 -04:00
|
|
|
|
2014-11-17 15:32:35 -04:00
|
|
|
beforeEach ->
|
2014-12-05 12:52:31 -04:00
|
|
|
@prefix = settings.get('dataPrefix')
|
2014-11-17 15:32:35 -04:00
|
|
|
mock.fs.init()
|
|
|
|
|
|
|
|
afterEach ->
|
|
|
|
mock.fs.restore()
|
|
|
|
|
2014-11-07 12:42:02 -04:00
|
|
|
describe 'given no prefix', ->
|
|
|
|
|
|
|
|
beforeEach ->
|
|
|
|
dataPrefix.clear()
|
|
|
|
|
|
|
|
describe '#get()', ->
|
|
|
|
|
|
|
|
it 'should return nothing', ->
|
|
|
|
expect(dataPrefix.get()).to.not.exist
|
|
|
|
|
|
|
|
describe '#set()', ->
|
|
|
|
|
2014-11-17 15:32:35 -04:00
|
|
|
beforeEach (done) ->
|
2014-12-05 12:52:31 -04:00
|
|
|
rimraf(@prefix, done)
|
2014-11-17 15:32:35 -04:00
|
|
|
|
2014-11-17 15:20:19 -04:00
|
|
|
it 'should be able to set a prefix', (done) ->
|
2014-11-07 12:42:02 -04:00
|
|
|
expect(dataPrefix.get()).to.not.exist
|
2014-12-05 12:52:31 -04:00
|
|
|
dataPrefix.set @prefix, (error) =>
|
2014-11-17 15:20:19 -04:00
|
|
|
expect(error).to.not.exist
|
2014-12-05 12:52:31 -04:00
|
|
|
expect(dataPrefix.get()).to.equal(@prefix)
|
2014-11-17 15:20:19 -04:00
|
|
|
done()
|
2014-11-07 12:42:02 -04:00
|
|
|
|
2014-11-17 15:20:19 -04:00
|
|
|
it 'should throw an error if passing an invalid path', (done) ->
|
2014-12-05 12:52:31 -04:00
|
|
|
dataPrefix.set { path: '/abc' }, (error) ->
|
2014-11-17 15:20:19 -04:00
|
|
|
expect(error).to.be.an.instanceof(Error)
|
|
|
|
done()
|
2014-11-07 12:42:02 -04:00
|
|
|
|
2014-11-17 15:32:35 -04:00
|
|
|
it 'should create the directory if it doesn\'t exist', (done) ->
|
|
|
|
|
|
|
|
async.waterfall [
|
|
|
|
|
|
|
|
(callback) ->
|
2014-12-05 12:52:31 -04:00
|
|
|
fs.exists @prefix, (exists) ->
|
2014-11-17 15:32:35 -04:00
|
|
|
return callback(null, exists)
|
|
|
|
|
2014-12-05 12:52:31 -04:00
|
|
|
(exists, callback) =>
|
2014-11-17 15:32:35 -04:00
|
|
|
expect(exists).to.be.false
|
2014-12-05 12:52:31 -04:00
|
|
|
dataPrefix.set(@prefix, callback)
|
2014-11-17 15:32:35 -04:00
|
|
|
|
2014-12-05 12:52:31 -04:00
|
|
|
(callback) =>
|
|
|
|
fsUtils.isDirectory(@prefix, callback)
|
2014-11-17 15:32:35 -04:00
|
|
|
|
|
|
|
(isDirectory, callback) ->
|
|
|
|
expect(isDirectory).to.be.true
|
|
|
|
return callback()
|
|
|
|
|
|
|
|
], (error) ->
|
|
|
|
expect(error).to.not.exist
|
|
|
|
done()
|
|
|
|
|
2014-11-07 12:42:02 -04:00
|
|
|
describe 'given a prefix', ->
|
|
|
|
|
2014-11-17 15:20:19 -04:00
|
|
|
beforeEach (done) ->
|
2014-12-05 12:52:31 -04:00
|
|
|
dataPrefix.set(@prefix, done)
|
2014-11-07 12:42:02 -04:00
|
|
|
|
|
|
|
describe '#get()', ->
|
|
|
|
|
|
|
|
it 'should return the saved prefix', ->
|
2014-12-05 12:52:31 -04:00
|
|
|
expect(dataPrefix.get()).to.equal(@prefix)
|
2014-11-07 12:42:02 -04:00
|
|
|
|
|
|
|
describe '#set()', ->
|
|
|
|
|
2014-11-17 15:20:19 -04:00
|
|
|
it 'should be able to override the prefix', (done) ->
|
2014-12-05 12:52:31 -04:00
|
|
|
newPrefix = "#{settings.get('dataPrefix')}-new"
|
|
|
|
expect(dataPrefix.get()).to.equal(@prefix)
|
|
|
|
dataPrefix.set newPrefix, (error) ->
|
2014-11-17 15:20:19 -04:00
|
|
|
expect(error).to.not.exist
|
2014-12-05 12:52:31 -04:00
|
|
|
expect(dataPrefix.get()).to.equal(newPrefix)
|
2014-11-17 15:20:19 -04:00
|
|
|
done()
|
2014-11-07 12:42:02 -04:00
|
|
|
|
|
|
|
describe '#clear()', ->
|
|
|
|
|
|
|
|
it 'should clear the prefix', ->
|
2014-12-05 12:52:31 -04:00
|
|
|
expect(dataPrefix.get()).to.equal(@prefix)
|
2014-11-07 12:42:02 -04:00
|
|
|
dataPrefix.clear()
|
|
|
|
expect(dataPrefix.get()).to.not.exist
|