mirror of
https://github.com/S2-/gitlit
synced 2025-08-04 13:10:09 +02:00
packager
This commit is contained in:
225
app/node_modules/tmp/test/dir-test.js
generated
vendored
Normal file
225
app/node_modules/tmp/test/dir-test.js
generated
vendored
Normal file
@@ -0,0 +1,225 @@
|
||||
var
|
||||
vows = require('vows'),
|
||||
assert = require('assert'),
|
||||
|
||||
path = require('path'),
|
||||
fs = require('fs'),
|
||||
existsSync = fs.existsSync || path.existsSync,
|
||||
|
||||
tmp = require('../lib/tmp.js'),
|
||||
Test = require('./base.js');
|
||||
|
||||
|
||||
function _testDir(mode) {
|
||||
return function _testDirGenerated(err, name) {
|
||||
assert.ok(existsSync(name), 'should exist');
|
||||
|
||||
var stat = fs.statSync(name);
|
||||
assert.ok(stat.isDirectory(), 'should be a directory');
|
||||
|
||||
Test.testStat(stat, mode);
|
||||
};
|
||||
}
|
||||
|
||||
vows.describe('Directory creation').addBatch({
|
||||
'when using without parameters': {
|
||||
topic: function () {
|
||||
tmp.dir(this.callback);
|
||||
},
|
||||
|
||||
'should be a directory': _testDir(040700),
|
||||
'should have the default prefix': Test.testPrefix('tmp-')
|
||||
},
|
||||
|
||||
'when using with prefix': {
|
||||
topic: function () {
|
||||
tmp.dir({ prefix: 'something' }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040700),
|
||||
'should have the provided prefix': Test.testPrefix('something')
|
||||
},
|
||||
|
||||
'when using with postfix': {
|
||||
topic: function () {
|
||||
tmp.dir({ postfix: '.txt' }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040700),
|
||||
'should have the provided postfix': Test.testPostfix('.txt')
|
||||
},
|
||||
|
||||
'when using template': {
|
||||
topic: function () {
|
||||
tmp.dir({ template: path.join(tmp.tmpdir, 'clike-XXXXXX-postfix') }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040700),
|
||||
'should have the provided prefix': Test.testPrefix('clike-'),
|
||||
'should have the provided postfix': Test.testPostfix('-postfix')
|
||||
},
|
||||
|
||||
'when using name': {
|
||||
topic: function () {
|
||||
tmp.dir({ name: 'using-name' }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040700),
|
||||
'should have the provided name': Test.testName(path.join(tmp.tmpdir, 'using-name'))
|
||||
},
|
||||
|
||||
'when using multiple options': {
|
||||
topic: function () {
|
||||
tmp.dir({ prefix: 'foo', postfix: 'bar', mode: 0750 }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040750),
|
||||
'should have the provided prefix': Test.testPrefix('foo'),
|
||||
'should have the provided postfix': Test.testPostfix('bar')
|
||||
},
|
||||
|
||||
'when using multiple options and mode': {
|
||||
topic: function () {
|
||||
tmp.dir({ prefix: 'complicated', postfix: 'options', mode: 0755 }, this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': _testDir(040755),
|
||||
'should have the provided prefix': Test.testPrefix('complicated'),
|
||||
'should have the provided postfix': Test.testPostfix('options')
|
||||
},
|
||||
|
||||
'no tries': {
|
||||
topic: function () {
|
||||
tmp.dir({ tries: -1 }, this.callback);
|
||||
},
|
||||
|
||||
'should return with an error': assert.isObject
|
||||
},
|
||||
|
||||
'keep testing': {
|
||||
topic: function () {
|
||||
Test.testKeep('dir', '1', this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a dir': function (err, name) {
|
||||
_testDir(040700)(err, name);
|
||||
fs.rmdirSync(name);
|
||||
}
|
||||
},
|
||||
|
||||
'unlink testing': {
|
||||
topic: function () {
|
||||
Test.testKeep('dir', '0', this.callback);
|
||||
},
|
||||
|
||||
'should not return with error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should not exist': function (err, name) {
|
||||
assert.ok(!existsSync(name), 'Directory should be removed');
|
||||
}
|
||||
},
|
||||
|
||||
'non graceful testing': {
|
||||
topic: function () {
|
||||
Test.testGraceful('dir', '0', this.callback);
|
||||
},
|
||||
|
||||
'should not return with error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a dir': function (err, name) {
|
||||
_testDir(040700)(err, name);
|
||||
fs.rmdirSync(name);
|
||||
}
|
||||
},
|
||||
|
||||
'graceful testing': {
|
||||
topic: function () {
|
||||
Test.testGraceful('dir', '1', this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should not exist': function (err, name) {
|
||||
assert.ok(!existsSync(name), 'Directory should be removed');
|
||||
}
|
||||
},
|
||||
|
||||
'unsafeCleanup === true': {
|
||||
topic: function () {
|
||||
Test.testUnsafeCleanup('1', this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should not exist': function (err, name) {
|
||||
assert.ok(!existsSync(name), 'Directory should be removed');
|
||||
},
|
||||
'should remove symlinked dir': function(err, name) {
|
||||
assert.ok(
|
||||
!existsSync(name + '/symlinkme-target'),
|
||||
'should remove target'
|
||||
);
|
||||
},
|
||||
'should not remove contents of symlink dir': function(err, name) {
|
||||
assert.ok(
|
||||
existsSync(__dirname + '/symlinkme/file.js'),
|
||||
'should not remove symlinked directory\'s content'
|
||||
);
|
||||
}
|
||||
},
|
||||
|
||||
'unsafeCleanup === true with issue62 structure': {
|
||||
topic: function () {
|
||||
Test.testIssue62(this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should not exist': function (err, name) {
|
||||
assert.ok(!existsSync(name), 'Directory should be removed');
|
||||
}
|
||||
},
|
||||
|
||||
'unsafeCleanup === false': {
|
||||
topic: function () {
|
||||
Test.testUnsafeCleanup('0', this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'should be a directory': function (err, name) {
|
||||
_testDir(040700)(err, name);
|
||||
// make sure that everything gets cleaned up
|
||||
fs.unlinkSync(path.join(name, 'should-be-removed.file'));
|
||||
fs.unlinkSync(path.join(name, 'symlinkme-target'));
|
||||
fs.rmdirSync(name);
|
||||
}
|
||||
},
|
||||
|
||||
'remove callback': {
|
||||
topic: function () {
|
||||
tmp.dir(this.callback);
|
||||
},
|
||||
|
||||
'should not return with an error': assert.isNull,
|
||||
'should return with a name': Test.assertName,
|
||||
'removeCallback should remove directory': function (_err, name, removeCallback) {
|
||||
removeCallback();
|
||||
assert.ok(!existsSync(name), 'Directory should be removed');
|
||||
}
|
||||
}
|
||||
}).exportTo(module);
|
Reference in New Issue
Block a user