2016-09-20 17:56:49 +02:00
|
|
|
import * as smartfile from '../dist/index'
|
|
|
|
import path = require('path')
|
2017-01-21 00:47:48 +01:00
|
|
|
|
2017-04-27 16:48:08 +02:00
|
|
|
import { expect, tap } from 'tapbundle'
|
2017-01-21 00:47:48 +01:00
|
|
|
|
2017-01-01 02:45:53 +01:00
|
|
|
import * as vinyl from 'vinyl'
|
2016-03-14 03:50:14 +01:00
|
|
|
|
2017-04-29 16:50:06 +02:00
|
|
|
// ---------------------------
|
|
|
|
// smartfile.fs
|
|
|
|
// ---------------------------
|
|
|
|
|
2017-04-27 16:48:08 +02:00
|
|
|
tap.test('.fs.fileExistsSync -> should return an accurate boolean', async () => {
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/mytest.json')).to.be.true
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/notthere.json')).be.false
|
|
|
|
})
|
2016-04-14 20:33:58 +02:00
|
|
|
|
2017-04-27 16:48:08 +02:00
|
|
|
tap.test('.fs.fileExists should resolve or reject a promise', async () => {
|
|
|
|
expect(smartfile.fs.fileExists('./test/mytest.json')).to.be.instanceof(Promise)
|
|
|
|
await expect(smartfile.fs.fileExists('./test/mytest.json')).to.eventually.be.fulfilled
|
|
|
|
await expect(smartfile.fs.fileExists('./test/notthere.json')).to.eventually.be.rejected
|
|
|
|
})
|
2017-03-04 21:10:46 +01:00
|
|
|
|
2017-04-27 16:48:08 +02:00
|
|
|
tap.test('.fs.listFoldersSync() -> should get the file type from a string', async () => {
|
|
|
|
expect(smartfile.fs.listFoldersSync('./test/')).to.deep.include('testfolder')
|
|
|
|
expect(smartfile.fs.listFoldersSync('./test/')).to.not.deep.include('notExistentFolder')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fs.listFolders() -> should get the file type from a string', async () => {
|
|
|
|
let folderArrayArg = await smartfile.fs.listFolders('./test/')
|
|
|
|
expect(folderArrayArg).to.deep.include('testfolder')
|
|
|
|
expect(folderArrayArg).to.not.deep.include('notExistentFolder')
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
tap.test('.fs.listFilesSync() -> should get the file type from a string', async () => {
|
|
|
|
expect(smartfile.fs.listFilesSync('./test/')).to.deep.include('mytest.json')
|
|
|
|
expect(smartfile.fs.listFilesSync('./test/')).to.not.deep.include('notExistentFile')
|
|
|
|
expect(smartfile.fs.listFilesSync('./test/', /mytest\.json/)).to.deep.include('mytest.json')
|
|
|
|
expect(smartfile.fs.listFilesSync('./test/', /mytests.json/)).to.not.deep.include('mytest.json')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fs.listFiles() -> should get the file type from a string', async () => {
|
|
|
|
let folderArrayArg = await smartfile.fs.listFiles('./test/')
|
|
|
|
expect(folderArrayArg).to.deep.include('mytest.json')
|
|
|
|
expect(folderArrayArg).to.not.deep.include('notExistentFile')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fs.listFileTree() -> should get a file tree', async () => {
|
|
|
|
let folderArrayArg = await smartfile.fs.listFileTree(path.resolve('./test/'), '**/*.txt')
|
|
|
|
expect(folderArrayArg).to.deep.include('testfolder/testfile1.txt')
|
|
|
|
expect(folderArrayArg).to.not.deep.include('mytest.json')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fstoObjectFromFileTree -> should read a file tree into an Object', async () => {
|
|
|
|
let fileArrayArg = await smartfile.fs.fileTreeToObject(path.resolve('./test/'), '**/*.txt')
|
|
|
|
// expect(fileArrayArg[1]).to.be.instanceof(smartfile.Smartfile)
|
|
|
|
})
|
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('.fs.copy() -> should copy a directory', async () => {
|
|
|
|
smartfile.fs.copy('./test/testfolder/', './test/temp/')
|
|
|
|
})
|
2017-04-27 16:48:08 +02:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('.fs.copy() -> should copy a file', async () => {
|
|
|
|
smartfile.fs.copy('./test/mytest.yaml', './test/temp/')
|
2017-04-27 16:48:08 +02:00
|
|
|
})
|
2016-03-18 17:34:31 +01:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('.fs.copy() -> should copy a file and rename it', async () => {
|
|
|
|
smartfile.fs.copy('./test/mytest.yaml', './test/temp/mytestRenamed.yaml')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fs.remove() -> should remove an entire directory', async () => {
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('smartfile.fs.remove -> should remove single files', async () => {
|
|
|
|
await expect(smartfile.fs.remove('./test/temp/mytestRenamed.yaml')).to.eventually.be.fulfilled
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('smartfile.fs.removeSync -> should remove single files synchronouly', async () => {
|
|
|
|
smartfile.fs.removeSync('./test/temp/testfile1.txt')
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('smartfile.fs.removeMany -> should remove and array of files', async () => {
|
|
|
|
smartfile.fs.removeMany([ './test/temp/testfile1.txt', './test/temp/testfile2.txt' ]).then(() => {
|
2017-04-27 16:48:08 +02:00
|
|
|
expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/temp/testfile2.txt')).to.be.false
|
|
|
|
})
|
|
|
|
})
|
2016-03-18 17:34:31 +01:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('smartfile.fs.removeManySync -> should remove and array of single files synchronouly', async () => {
|
|
|
|
smartfile.fs.removeManySync([ './test/temp/testfile1.txt', './test/temp/testfile2.txt' ])
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/temp/testfile1.txt')).to.be.false
|
|
|
|
expect(smartfile.fs.fileExistsSync('./test/temp/testfile2.txt')).to.be.false
|
|
|
|
})
|
|
|
|
|
2017-04-27 16:48:08 +02:00
|
|
|
// ---------------------------
|
2017-04-29 16:50:06 +02:00
|
|
|
// smartfile.interpreter
|
2017-04-27 16:48:08 +02:00
|
|
|
// ---------------------------
|
2017-04-28 11:28:11 +02:00
|
|
|
|
|
|
|
tap.test('.interpreter.filetype() -> should get the file type from a string', async () => {
|
|
|
|
expect(smartfile.interpreter.filetype('./somefolder/data.json')).equal('json')
|
2017-04-27 16:48:08 +02:00
|
|
|
})
|
2017-03-04 21:10:46 +01:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('.fs.toObjectSync() -> should read an ' + '.yaml' + ' file to an object', async () => {
|
|
|
|
let testData = smartfile.fs.toObjectSync('./test/mytest.yaml')
|
|
|
|
expect(testData).have.property('key1', 'this works')
|
|
|
|
expect(testData).have.property('key2', 'this works too')
|
2017-03-04 21:10:46 +01:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
})
|
|
|
|
tap.test('.fs.toObjectSync() -> should state unknown file type for unknown file types', async () => {
|
|
|
|
let testData = smartfile.fs.toObjectSync('./test/mytest.txt')
|
|
|
|
})
|
2017-04-27 16:48:08 +02:00
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
tap.test('.fs.toObjectSync() -> should read an ' + '.json' + ' file to an object', async () => {
|
|
|
|
let testData = smartfile.fs.toObjectSync('./test/mytest.json')
|
|
|
|
expect(testData).have.property('key1', 'this works')
|
|
|
|
expect(testData).have.property('key2', 'this works too')
|
2017-04-27 16:48:08 +02:00
|
|
|
})
|
|
|
|
|
2017-04-28 11:28:11 +02:00
|
|
|
|
|
|
|
tap.test('.fs.toStringSync() -> should read a file to a string', async () => {
|
|
|
|
expect(smartfile.fs.toStringSync('./test/mytest.txt'))
|
|
|
|
.to.equal('Some TestString &&%$')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.fs.toVinylSync -> should read an ' + '.json OR .yaml' + ' file to an ' + 'vinyl file object', async () => {
|
|
|
|
let testData = smartfile.fs.toVinylSync('./test/mytest.json')
|
|
|
|
expect(vinyl.isVinyl(testData)).to.be.true
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.memory.toVinylFileSync() -> should produce a vinylFile', async () => {
|
|
|
|
let localString = 'myString'
|
|
|
|
let localOptions = { filename: 'vinylfile2', base: '/someDir' }
|
|
|
|
expect(smartfile.memory.toVinylFileSync(localString, localOptions) instanceof vinyl).to.be.true
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.memory.toVinylArraySync() -> should produce a an array of vinylfiles', async () => {
|
|
|
|
let localStringArray = [ 'string1', 'string2', 'string3' ]
|
|
|
|
let localOptions = { filename: 'vinylfile2', base: '/someDir' }
|
|
|
|
let testResult = smartfile.memory.toVinylArraySync(localStringArray, localOptions)
|
|
|
|
expect(testResult).to.be.a('array')
|
|
|
|
expect(testResult.length === 3).to.be.true
|
|
|
|
for (let myKey in testResult) {
|
|
|
|
expect(testResult[ myKey ] instanceof vinyl).to.be.true
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.memory.vinylToStringSync() -> should produce a String from vinyl file', async () => {
|
|
|
|
let localString = smartfile.memory.vinylToStringSync(new vinyl({
|
|
|
|
base: '/',
|
|
|
|
path: '/test.txt',
|
|
|
|
contents: new Buffer('myString')
|
|
|
|
}))
|
|
|
|
expect(localString).equal('myString')
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.memory.toFs() -> should write a file to disk and return a promise', async () => {
|
|
|
|
let localString = 'myString'
|
2017-04-28 11:32:05 +02:00
|
|
|
await smartfile.memory.toFs(
|
2017-04-28 11:28:11 +02:00
|
|
|
localString,
|
|
|
|
path.join(process.cwd(), './test/temp/testMemToFs.txt')
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.memory.toFsSync() -> should write a file to disk and return true if successfull', async () => {
|
|
|
|
let localString = 'myString'
|
|
|
|
smartfile.memory.toFsSync(
|
|
|
|
localString,
|
|
|
|
path.join(process.cwd(), './test/temp/testMemToFsSync.txt')
|
|
|
|
)
|
2017-04-27 16:48:08 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
tap.test('.remote.toString() -> should load a remote file to a variable', async () => {
|
|
|
|
let responseString = await smartfile.remote.toString(
|
|
|
|
'https://raw.githubusercontent.com/pushrocks/smartfile/master/test/mytest.txt'
|
|
|
|
)
|
|
|
|
expect(responseString).to.equal('Some TestString &&%$')
|
2016-09-20 17:56:49 +02:00
|
|
|
})
|
2017-04-27 16:48:08 +02:00
|
|
|
|
|
|
|
tap.test('.remote.toString() -> should reject a Promise when the link is false', async () => {
|
|
|
|
await expect(smartfile.remote.toString('https://push.rocks/doesnotexist.txt'))
|
|
|
|
.to.eventually.be.rejected
|
|
|
|
})
|
|
|
|
|
|
|
|
tap.start()
|