mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 18:23:21 +08:00
e6881573d9
Summary: Cancelling a file upload properly makes the task return Task.Status.Finished (previously it was broken and returning Task.Status.Retry) Dragging a directory now gives you a nice error message Aborting an upload now looks for the task with the given ID, not a task with the given filepath since there could be identical uploads happening in other windows Make it more explicit that the uploadId is not the task ID Add a few tests Test Plan: Run new tests Reviewers: evan Reviewed By: evan Differential Revision: https://phab.nylas.com/D1750
98 lines
3.3 KiB
CoffeeScript
98 lines
3.3 KiB
CoffeeScript
File = require '../../src/flux/models/file'
|
|
Actions = require '../../src/flux/actions'
|
|
FileUploadStore = require '../../src/flux/stores/file-upload-store'
|
|
fs = require 'fs'
|
|
|
|
msgId = "local-123"
|
|
fpath = "/foo/bar/test123.jpg"
|
|
|
|
describe 'FileUploadStore', ->
|
|
beforeEach ->
|
|
@file = new File
|
|
id: "id_123"
|
|
filename: "test123.jpg"
|
|
size: 12345
|
|
@uploadData =
|
|
uploadTaskId: 123
|
|
messageLocalId: msgId
|
|
filePath: fpath
|
|
fileSize: 12345
|
|
|
|
spyOn(atom, "showOpenDialog").andCallFake (props, callback) ->
|
|
callback(fpath)
|
|
|
|
spyOn(Actions, "queueTask")
|
|
|
|
describe 'attachFile', ->
|
|
it "throws if the message id is blank", ->
|
|
expect( -> Actions.attachFile()).toThrow()
|
|
|
|
it "throws if the message id is blank", ->
|
|
spyOn(Actions, "attachFilePath")
|
|
Actions.attachFile messageLocalId: msgId
|
|
expect(atom.showOpenDialog).toHaveBeenCalled()
|
|
expect(Actions.attachFilePath).toHaveBeenCalled()
|
|
args = Actions.attachFilePath.calls[0].args[0]
|
|
expect(args.messageLocalId).toBe msgId
|
|
expect(args.path).toBe fpath
|
|
|
|
describe 'attachFilePath', ->
|
|
it "throws if the message id is blank", ->
|
|
expect( -> Actions.attachFilePath()).toThrow()
|
|
|
|
it 'Creates a new file upload task', ->
|
|
spyOn(fs, 'stat').andCallFake (path, callback) ->
|
|
callback(null, {isDirectory: -> false})
|
|
Actions.attachFilePath
|
|
messageLocalId: msgId
|
|
path: fpath
|
|
expect(Actions.queueTask).toHaveBeenCalled()
|
|
t = Actions.queueTask.calls[0].args[0]
|
|
expect(t.filePath).toBe fpath
|
|
expect(t.messageLocalId).toBe msgId
|
|
|
|
it 'displays an error if the file path given is a directory', ->
|
|
spyOn(FileUploadStore, '_onAttachFileError')
|
|
spyOn(fs, 'stat').andCallFake (path, callback) ->
|
|
callback(null, {isDirectory: -> true})
|
|
Actions.attachFilePath
|
|
messageLocalId: msgId
|
|
path: fpath
|
|
expect(Actions.queueTask).not.toHaveBeenCalled()
|
|
expect(FileUploadStore._onAttachFileError).toHaveBeenCalled()
|
|
|
|
describe 'when an uploading file is aborted', ->
|
|
it "dequeues the matching task", ->
|
|
spyOn(Actions, "dequeueMatchingTask")
|
|
Actions.abortUpload(@uploadData)
|
|
expect(Actions.dequeueMatchingTask).toHaveBeenCalled()
|
|
arg = Actions.dequeueMatchingTask.calls[0].args[0]
|
|
expect(arg).toEqual
|
|
type: "FileUploadTask"
|
|
matching: id: @uploadData.uploadTaskId
|
|
|
|
describe 'when upload state changes', ->
|
|
it 'updates the uploadData', ->
|
|
Actions.uploadStateChanged(@uploadData)
|
|
expect(FileUploadStore._fileUploads[123]).toBe @uploadData
|
|
|
|
describe 'when a file has been uploaded', ->
|
|
it 'adds removes from uploads', ->
|
|
FileUploadStore._fileUploads[123] = @uploadData
|
|
Actions.fileUploaded
|
|
file: @file
|
|
uploadData: @uploadData
|
|
expect(FileUploadStore._fileUploads[123]).not.toBeDefined()
|
|
|
|
it 'adds to the linked files', ->
|
|
FileUploadStore._fileUploads[123] = @uploadData
|
|
Actions.linkFileToUpload
|
|
file: @file
|
|
uploadData: @uploadData
|
|
expect(FileUploadStore._linkedFiles["id_123"]).toBe @uploadData
|
|
|
|
describe 'when a file has been aborted', ->
|
|
it 'removes it from the uploads', ->
|
|
FileUploadStore._fileUploads[123] = @uploadData
|
|
Actions.fileAborted(@uploadData)
|
|
expect(FileUploadStore._fileUploads[123]).not.toBeDefined()
|