123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429 |
- import utils from './Utils'
- const sampleImageDataURI =
- ''
- describe('core/utils', () => {
- describe('generateFileID', () => {
- it('should take the filename object and produce a lowercase file id made up of uppy- prefix, file name (cleaned up to be lowercase, letters and numbers only), type, size and lastModified date', () => {
- const fileObj = {
- name: 'fOo0Fi@£$.jpg',
- type: 'image/jpeg',
- data: {
- lastModified: 1498510508000,
- size: 2271173
- }
- }
- expect(utils.generateFileID(fileObj)).toEqual(
- 'uppy-foo0fijpg-image/jpeg-2271173-1498510508000'
- )
- })
- })
- describe('toArray', () => {
- it('should convert a array-like object into an array', () => {
- const obj = {
- '0': 'zero',
- '1': 'one',
- '2': 'two',
- '3': 'three',
- '4': 'four',
- length: 5
- }
- expect(utils.toArray(obj)).toEqual([
- 'zero',
- 'one',
- 'two',
- 'three',
- 'four'
- ])
- })
- })
- describe('runPromiseSequence', () => {
- it('should run an array of promise-returning functions in sequence', () => {
- const promiseFn1 = jest.fn().mockReturnValue(Promise.resolve)
- const promiseFn2 = jest.fn().mockReturnValue(Promise.resolve)
- const promiseFn3 = jest.fn().mockReturnValue(Promise.resolve)
- return utils
- .runPromiseSequence([promiseFn1, promiseFn2, promiseFn3])
- .then(() => {
- expect(promiseFn1.mock.calls.length).toEqual(1)
- expect(promiseFn2.mock.calls.length).toEqual(1)
- expect(promiseFn3.mock.calls.length).toEqual(1)
- })
- })
- })
- describe('isTouchDevice', () => {
- const RealTouchStart = global.window.ontouchstart
- const RealMaxTouchPoints = global.navigator.maxTouchPoints
- beforeEach(() => {
- global.window.ontouchstart = true
- global.navigator.maxTouchPoints = 1
- })
- afterEach(() => {
- global.navigator.maxTouchPoints = RealMaxTouchPoints
- global.window.ontouchstart = RealTouchStart
- })
- xit("should return true if it's a touch device", () => {
- expect(utils.isTouchDevice()).toEqual(true)
- delete global.window.ontouchstart
- global.navigator.maxTouchPoints = false
- expect(utils.isTouchDevice()).toEqual(false)
- })
- })
- describe('getFileNameAndExtension', () => {
- it('should return the filename and extension as an array', () => {
- expect(utils.getFileNameAndExtension('fsdfjodsuf23rfw.jpg')).toEqual({
- name: 'fsdfjodsuf23rfw',
- extension: 'jpg'
- })
- })
- it('should handle invalid filenames', () => {
- expect(utils.getFileNameAndExtension('fsdfjodsuf23rfw')).toEqual({
- name: 'fsdfjodsuf23rfw',
- extension: undefined
- })
- })
- })
- describe('truncateString', () => {
- it('should truncate the string by the specified amount', () => {
- expect(utils.truncateString('abcdefghijkl', 10)).toEqual('abcde...jkl')
- expect(utils.truncateString('abcdefghijkl', 9)).toEqual('abcd...jkl')
- expect(utils.truncateString('abcdefghijkl', 8)).toEqual('abcd...kl')
- expect(utils.truncateString('abcdefghijkl', 7)).toEqual('abc...kl')
- expect(utils.truncateString('abcdefghijkl', 6)).toEqual('abc...kl')
- expect(utils.truncateString('abcdefghijkl', 5)).toEqual('ab...kl')
- expect(utils.truncateString('abcdefghijkl', 4)).toEqual('ab...l')
- expect(utils.truncateString('abcdefghijkl', 3)).toEqual('a...l')
- expect(utils.truncateString('abcdefghijkl', 2)).toEqual('a...l')
- expect(utils.truncateString('abcdefghijkl', 1)).toEqual('...l')
- })
- })
- describe('secondsToTime', () => {
- expect(utils.secondsToTime(60)).toEqual({
- hours: 0,
- minutes: 1,
- seconds: 0
- })
- expect(utils.secondsToTime(123)).toEqual({
- hours: 0,
- minutes: 2,
- seconds: 3
- })
- expect(utils.secondsToTime(1060)).toEqual({
- hours: 0,
- minutes: 17,
- seconds: 40
- })
- expect(utils.secondsToTime(123453460)).toEqual({
- hours: 20,
- minutes: 37,
- seconds: 40
- })
- })
- describe('getFileTypeExtension', () => {
- it('should return the filetype based on the specified mime type', () => {
- expect(utils.getFileTypeExtension('video/ogg')).toEqual('ogv')
- expect(utils.getFileTypeExtension('audio/ogg')).toEqual('ogg')
- expect(utils.getFileTypeExtension('video/webm')).toEqual('webm')
- expect(utils.getFileTypeExtension('audio/webm')).toEqual('webm')
- expect(utils.getFileTypeExtension('video/mp4')).toEqual('mp4')
- expect(utils.getFileTypeExtension('audio/mp3')).toEqual('mp3')
- expect(utils.getFileTypeExtension('foo/bar')).toEqual(null)
- })
- })
- describe('getFileType', () => {
- beforeEach(() => {
- global.FileReader = class FileReader {
- addEventListener (e, cb) {
- if (e === 'load') {
- this.loadCb = cb
- }
- if (e === 'error') {
- this.errorCb = cb
- }
- }
- readAsArrayBuffer (chunk) {
- this.loadCb({ target: { result: new ArrayBuffer(8) } })
- }
- }
- })
- afterEach(() => {
- global.FileReader = undefined
- })
- it('should trust the filetype if the file comes from a remote source', () => {
- const file = {
- isRemote: true,
- type: 'audio/webm',
- name: 'foo.webm'
- }
- return utils.getFileType(file).then(r => {
- expect(r).toEqual('audio/webm')
- })
- })
- it('should determine the filetype from the mimetype', () => {
- const file = {
- type: 'audio/webm',
- name: 'foo.webm',
- data: 'sdfsdfhq9efbicw'
- }
- return utils.getFileType(file).then(r => {
- expect(r).toEqual('audio/webm')
- })
- })
- it('should determine the filetype from the extension', () => {
- const file = {
- name: 'foo.mp3',
- data: 'sdfsfhfh329fhwihs'
- }
- return utils.getFileType(file).then(r => {
- expect(r).toEqual('audio/mp3')
- })
- })
- it('should fail gracefully if unable to detect', () => {
- const file = {
- name: 'foobar',
- data: 'sdfsfhfh329fhwihs'
- }
- return utils.getFileType(file).then(r => {
- expect(r).toEqual(null)
- })
- })
- })
- describe('getArrayBuffer', () => {
- beforeEach(() => {
- global.FileReader = class FileReader {
- addEventListener (e, cb) {
- if (e === 'load') {
- this.loadCb = cb
- }
- if (e === 'error') {
- this.errorCb = cb
- }
- }
- readAsArrayBuffer (chunk) {
- this.loadCb({ target: { result: new ArrayBuffer(8) } })
- }
- }
- })
- afterEach(() => {
- global.FileReader = undefined
- })
- it('should return a promise that resolves with the specified chunk', () => {
- return utils.getArrayBuffer('abcde').then(buffer => {
- expect(typeof buffer).toEqual('object')
- expect(buffer.byteLength).toEqual(8)
- })
- })
- })
- describe('isPreviewSupported', () => {
- it('should return true for any filetypes that browsers can preview', () => {
- const supported = ['image/jpeg', 'image/gif', 'image/png', 'image/svg', 'image/svg+xml', 'image/bmp']
- supported.forEach(ext => {
- expect(utils.isPreviewSupported(ext)).toEqual(true)
- })
- expect(utils.isPreviewSupported('foo')).toEqual(false)
- })
- })
- describe('isObjectURL', () => {
- it('should return true if the specified url is an object url', () => {
- expect(utils.isObjectURL('blob:abc123')).toEqual(true)
- expect(utils.isObjectURL('kblob:abc123')).toEqual(false)
- expect(utils.isObjectURL('blob-abc123')).toEqual(false)
- expect(utils.isObjectURL('abc123')).toEqual(false)
- })
- })
- describe('createThumbnail', () => {
- const RealCreateObjectUrl = global.URL.createObjectURL
- beforeEach(() => {
- global.URL.createObjectURL = jest.fn().mockReturnValue('newUrl')
- })
- afterEach(() => {
- global.URL.createObjectURL = RealCreateObjectUrl
- })
- xit(
- 'should create a thumbnail of the specified image at the specified width',
- () => {}
- )
- })
- describe('dataURItoBlob', () => {
- it('should convert a data uri to a blob', () => {
- const blob = utils.dataURItoBlob(sampleImageDataURI, {})
- expect(blob instanceof Blob).toEqual(true)
- expect(blob.size).toEqual(9348)
- expect(blob.type).toEqual('image/jpeg')
- })
- })
- describe('dataURItoFile', () => {
- it('should convert a data uri to a file', () => {
- const file = utils.dataURItoFile(sampleImageDataURI, { name: 'foo.jpg' })
- expect(file instanceof File).toEqual(true)
- expect(file.size).toEqual(9348)
- expect(file.type).toEqual('image/jpeg')
- expect(file.name).toEqual('foo.jpg')
- })
- })
- describe('getSpeed', () => {
- it('should calculate the speed given a fileProgress object', () => {
- const dateNow = new Date()
- const date5SecondsAgo = new Date(dateNow.getTime() - 5 * 1000)
- const fileProgress = {
- bytesUploaded: 1024,
- uploadStarted: date5SecondsAgo
- }
- expect(Math.round(utils.getSpeed(fileProgress))).toEqual(Math.round(205))
- })
- })
- describe('getBytesRemaining', () => {
- it('should calculate the bytes remaining given a fileProgress object', () => {
- const fileProgress = {
- bytesUploaded: 1024,
- bytesTotal: 3096
- }
- expect(utils.getBytesRemaining(fileProgress)).toEqual(2072)
- })
- })
- describe('getETA', () => {
- it('should get the ETA remaining based on a fileProgress object', () => {
- const dateNow = new Date()
- const date5SecondsAgo = new Date(dateNow.getTime() - 5 * 1000)
- const fileProgress = {
- bytesUploaded: 1024,
- bytesTotal: 3096,
- uploadStarted: date5SecondsAgo
- }
- expect(utils.getETA(fileProgress)).toEqual(10.1)
- })
- })
- describe('prettyETA', () => {
- it('should convert the specified number of seconds to a pretty ETA', () => {
- expect(utils.prettyETA(0)).toEqual('0s')
- expect(utils.prettyETA(1.2)).toEqual('1s')
- expect(utils.prettyETA(1)).toEqual('1s')
- expect(utils.prettyETA(103)).toEqual('1m 43s')
- expect(utils.prettyETA(1034.9)).toEqual('17m 14s')
- expect(utils.prettyETA(103984.1)).toEqual('4h 53m 04s')
- })
- })
- describe('copyToClipboard', () => {
- xit('should copy the specified text to the clipboard', () => {})
- })
- describe('getSocketHost', () => {
- it('should get the host from the specified url', () => {
- expect(
- utils.getSocketHost('https://foo.bar/a/b/cd?e=fghi&l=k&m=n')
- ).toEqual('ws://foo.bar/a/b/cd?e=fghi&l=k&m=n')
- })
- })
- describe('settle', () => {
- it('should resolve even if all input promises reject', () => {
- return expect(
- utils.settle([
- Promise.reject(new Error('oops')),
- Promise.reject(new Error('this went wrong'))
- ])
- ).resolves.toMatchObject({
- successful: [],
- failed: [{ message: 'oops' }, { message: 'this went wrong' }]
- })
- })
- it('should resolve with an object if some input promises resolve', () => {
- return expect(
- utils.settle([
- Promise.reject(new Error('rejected')),
- Promise.resolve('resolved'),
- Promise.resolve('also-resolved')
- ])
- ).resolves.toMatchObject({
- successful: ['resolved', 'also-resolved'],
- failed: [{ message: 'rejected' }]
- })
- })
- })
- describe('limitPromises', () => {
- let pending = 0
- function fn () {
- pending++
- return new Promise((resolve) => setTimeout(resolve, 10))
- .then(() => pending--)
- }
- it('should run at most N promises at the same time', () => {
- const limit = utils.limitPromises(4)
- const fn2 = limit(fn)
- const result = Promise.all([
- fn2(), fn2(), fn2(), fn2(),
- fn2(), fn2(), fn2(), fn2(),
- fn2(), fn2()
- ])
- expect(pending).toBe(4)
- setTimeout(() => {
- expect(pending).toBe(4)
- }, 10)
- return result.then(() => {
- expect(pending).toBe(0)
- })
- })
- it('should accept Infinity as limit', () => {
- const limit = utils.limitPromises(Infinity)
- const fn2 = limit(fn)
- const result = Promise.all([
- fn2(), fn2(), fn2(), fn2(),
- fn2(), fn2(), fn2(), fn2(),
- fn2(), fn2()
- ])
- expect(pending).toBe(10)
- return result.then(() => {
- expect(pending).toBe(0)
- })
- })
- })
- })
|