diff options
author | Jacques Erasmus <jerasmus@gitlab.com> | 2018-10-22 08:28:36 +0000 |
---|---|---|
committer | Phil Hughes <me@iamphill.com> | 2018-10-22 08:28:36 +0000 |
commit | d1fb29e57318d8a20f3deb95496f4b7102de3f97 (patch) | |
tree | 06bd73c3e34bc38ddfcefb3e8d45d198a29a53f9 /spec/javascripts/ide/components | |
parent | 114b0a3dcbef98dc9a0fadaae51d199787cbf572 (diff) | |
download | gitlab-ce-d1fb29e57318d8a20f3deb95496f4b7102de3f97.tar.gz |
Remove base64 encoding from files that contain plain text
Diffstat (limited to 'spec/javascripts/ide/components')
-rw-r--r-- | spec/javascripts/ide/components/new_dropdown/upload_spec.js | 40 |
1 files changed, 17 insertions, 23 deletions
diff --git a/spec/javascripts/ide/components/new_dropdown/upload_spec.js b/spec/javascripts/ide/components/new_dropdown/upload_spec.js index 70b885ede26..878e17ac805 100644 --- a/spec/javascripts/ide/components/new_dropdown/upload_spec.js +++ b/spec/javascripts/ide/components/new_dropdown/upload_spec.js @@ -40,21 +40,10 @@ describe('new dropdown upload', () => { describe('readFile', () => { beforeEach(() => { - spyOn(FileReader.prototype, 'readAsText'); spyOn(FileReader.prototype, 'readAsDataURL'); }); - it('calls readAsText for text files', () => { - const file = { - type: 'text/html', - }; - - vm.readFile(file); - - expect(FileReader.prototype.readAsText).toHaveBeenCalledWith(file); - }); - - it('calls readAsDataURL for non-text files', () => { + it('calls readAsDataURL for all files', () => { const file = { type: 'images/png', }; @@ -66,32 +55,37 @@ describe('new dropdown upload', () => { }); describe('createFile', () => { - const target = { - result: 'content', + const textTarget = { + result: 'base64,cGxhaW4gdGV4dA==', }; const binaryTarget = { - result: 'base64,base64content', + result: 'base64,w4I=', + }; + const textFile = { + name: 'textFile', + type: 'text/plain', }; - const file = { - name: 'file', + const binaryFile = { + name: 'binaryFile', + type: 'image/png', }; - it('creates new file', () => { - vm.createFile(target, file, true); + it('creates file in plain text (without encoding) if the file content is plain text', () => { + vm.createFile(textTarget, textFile); expect(vm.$emit).toHaveBeenCalledWith('create', { - name: file.name, + name: textFile.name, type: 'blob', - content: target.result, + content: 'plain text', base64: false, }); }); it('splits content on base64 if binary', () => { - vm.createFile(binaryTarget, file, false); + vm.createFile(binaryTarget, binaryFile); expect(vm.$emit).toHaveBeenCalledWith('create', { - name: file.name, + name: binaryFile.name, type: 'blob', content: binaryTarget.result.split('base64,')[1], base64: true, |