|
| 1 | +import { expect } from 'chai'; |
| 2 | +import { before, beforeEach, describe, it } from 'mocha'; |
| 3 | +import proxyquire from 'proxyquire'; |
| 4 | +import sinon from 'sinon'; |
| 5 | + |
| 6 | +import { createFakeMessageWithAttachment } from '../../../../tests/mocks/data'; |
| 7 | + |
| 8 | +const fakeStorageModel = { findOneById: sinon.stub(), deleteFile: sinon.stub() }; |
| 9 | +const settingsStub = { watch: sinon.stub(), get: sinon.stub() }; |
| 10 | +const settingsGetMap = new Map(); |
| 11 | +const messagesModelStub = { |
| 12 | + find: sinon.stub(), |
| 13 | +}; |
| 14 | + |
| 15 | +const { FileUpload, FileUploadClass } = proxyquire.noCallThru().load('./FileUpload', { |
| 16 | + '@rocket.chat/models': { |
| 17 | + Messages: messagesModelStub, |
| 18 | + }, |
| 19 | + 'meteor/check': sinon.stub(), |
| 20 | + 'meteor/meteor': sinon.stub(), |
| 21 | + 'meteor/ostrio:cookies': { Cookies: sinon.stub() }, |
| 22 | + 'sharp': sinon.stub(), |
| 23 | + 'stream-buffers': sinon.stub(), |
| 24 | + './streamToBuffer': sinon.stub(), |
| 25 | + '../../../../server/lib/i18n': sinon.stub(), |
| 26 | + '../../../../server/lib/logger/system': sinon.stub(), |
| 27 | + '../../../../server/lib/rooms/roomCoordinator': sinon.stub(), |
| 28 | + '../../../../server/ufs': sinon.stub(), |
| 29 | + '../../../../server/ufs/ufs-methods': sinon.stub(), |
| 30 | + '../../../settings/server': { settings: settingsStub }, |
| 31 | + '../../../utils/lib/mimeTypes': sinon.stub(), |
| 32 | + '../../../utils/server/lib/JWTHelper': sinon.stub(), |
| 33 | + '../../../utils/server/restrictions': sinon.stub(), |
| 34 | +}); |
| 35 | + |
| 36 | +describe('FileUpload', () => { |
| 37 | + before(() => { |
| 38 | + new FileUploadClass({ name: 'fakeStorage:Uploads', model: fakeStorageModel, store: {} }); |
| 39 | + settingsGetMap.set('FileUpload_Storage_Type', 'fakeStorage'); |
| 40 | + settingsStub.get.callsFake((settingName) => settingsGetMap.get(settingName)); |
| 41 | + }); |
| 42 | + |
| 43 | + beforeEach(() => { |
| 44 | + messagesModelStub.find.reset(); |
| 45 | + fakeStorageModel.findOneById.reset(); |
| 46 | + fakeStorageModel.deleteFile.reset(); |
| 47 | + }); |
| 48 | + |
| 49 | + it('should not remove any file if no room id is provided', async () => { |
| 50 | + expect(await FileUpload.removeFilesByRoomId()).to.be.undefined; |
| 51 | + |
| 52 | + expect(messagesModelStub.find.called).to.be.false; |
| 53 | + expect(fakeStorageModel.findOneById.called).to.be.false; |
| 54 | + }); |
| 55 | + |
| 56 | + it('should not remove any file if an empty room id is provided', async () => { |
| 57 | + expect(await FileUpload.removeFilesByRoomId('')).to.be.undefined; |
| 58 | + |
| 59 | + expect(messagesModelStub.find.called).to.be.false; |
| 60 | + expect(fakeStorageModel.findOneById.called).to.be.false; |
| 61 | + }); |
| 62 | + |
| 63 | + it('should not remove any file if an invalid room id is provided', async () => { |
| 64 | + messagesModelStub.find.returns([]); |
| 65 | + expect(await FileUpload.removeFilesByRoomId('invalid')).to.be.undefined; |
| 66 | + |
| 67 | + expect(messagesModelStub.find.called).to.be.true; |
| 68 | + expect(fakeStorageModel.findOneById.called).to.be.false; |
| 69 | + }); |
| 70 | + |
| 71 | + it('should delete file from storage if message contains a single file', async () => { |
| 72 | + fakeStorageModel.findOneById.resolves({ _id: 'file-id', store: 'fakeStorage:Uploads' }); |
| 73 | + |
| 74 | + const fakeMessage = createFakeMessageWithAttachment(); |
| 75 | + messagesModelStub.find.returns([fakeMessage]); |
| 76 | + expect(await FileUpload.removeFilesByRoomId('invalid')).to.be.undefined; |
| 77 | + |
| 78 | + expect(messagesModelStub.find.called).to.be.true; |
| 79 | + expect(fakeStorageModel.findOneById.calledOnceWith(fakeMessage.files?.[0]._id)).to.be.true; |
| 80 | + expect(fakeStorageModel.deleteFile.calledOnceWith('file-id')).to.be.true; |
| 81 | + }); |
| 82 | + |
| 83 | + it('should delete multiple files from storage if message contains many files (e.g. image and thumbnail)', async () => { |
| 84 | + fakeStorageModel.findOneById.callsFake((_id) => ({ _id, store: 'fakeStorage:Uploads' })); |
| 85 | + |
| 86 | + const fakeMessage = createFakeMessageWithAttachment({ |
| 87 | + files: [ |
| 88 | + { _id: 'file-id', name: 'image', size: 100, type: 'image/png', format: 'png' }, |
| 89 | + { _id: 'thumbnail-id', name: 'thumbnail-image', size: 25, type: 'image/png', format: 'png' }, |
| 90 | + ], |
| 91 | + }); |
| 92 | + messagesModelStub.find.returns([fakeMessage]); |
| 93 | + expect(await FileUpload.removeFilesByRoomId('invalid')).to.be.undefined; |
| 94 | + |
| 95 | + expect(messagesModelStub.find.called).to.be.true; |
| 96 | + expect(fakeStorageModel.findOneById.calledTwice).to.be.true; |
| 97 | + expect(fakeStorageModel.findOneById.calledWith('file-id')).to.be.true; |
| 98 | + expect(fakeStorageModel.findOneById.calledWith('thumbnail-id')).to.be.true; |
| 99 | + expect(fakeStorageModel.deleteFile.calledTwice).to.be.true; |
| 100 | + expect(fakeStorageModel.deleteFile.calledWith('file-id')).to.be.true; |
| 101 | + expect(fakeStorageModel.deleteFile.calledWith('thumbnail-id')).to.be.true; |
| 102 | + }); |
| 103 | +}); |
0 commit comments