From 64ee88c1b9a94408b4f45906f1d0ee702cae7ee1 Mon Sep 17 00:00:00 2001 From: Alex Anderson <191496+alxndrsn@users.noreply.github.com> Date: Wed, 16 Oct 2024 08:35:34 +0300 Subject: [PATCH] test/blobs: add explicit test for de-duplication (#1220) Adds a passing test for de-duplication of two blobs with identical content & mime type, but different filenames. --- test/integration/other/blobs.js | 52 +++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) diff --git a/test/integration/other/blobs.js b/test/integration/other/blobs.js index e17e1695f..c9f81b680 100644 --- a/test/integration/other/blobs.js +++ b/test/integration/other/blobs.js @@ -15,6 +15,58 @@ describe('blob query module', () => { .then(() => container.oneFirst(sql`select count(*) from blobs`)) .then((count) => count.should.equal(1))))); + it('should handle blob collisions with different filenames', testService((service, container) => + // One one instance of the form, two files are uploaded + // On another instance of the form (different id), one file is uploaded + // and it creates another reference to one of the blobs with a different + // filename. + service.login('alice', (asAlice) => + asAlice.post('/v1/projects/1/forms?publish=true') + .set('Content-Type', 'application/xml') + .send(testData.forms.binaryType) + .expect(200) + .then(() => container.oneFirst(sql`select count(*) from blobs`)) + .then((count) => count.should.equal(0)) + .then(() => asAlice.post('/v1/projects/1/submission') + .set('X-OpenRosa-Version', '1.0') + .attach('xml_submission_file', Buffer.from(testData.instances.binaryType.both), { filename: 'data.xml' }) + .attach('here_is_file2.jpg', Buffer.from('this is test file two'), { filename: 'here_is_file2.jpg' }) + .attach('my_file1.mp4', Buffer.from('this is test file one'), { filename: 'my_file1.mp4' }) + .expect(201)) + .then(() => container.oneFirst(sql`select count(*) from blobs`)) + .then((count) => count.should.equal(2)) + .then(() => asAlice.post('/v1/projects/1/forms?publish=true') + .set('Content-Type', 'application/xml') + .send(testData.forms.binaryType.replace('id="binaryType"', 'id="binaryType2"')) + .expect(200)) + .then(() => asAlice.post('/v1/projects/1/submission') + .set('X-OpenRosa-Version', '1.0') + .attach( + 'xml_submission_file', + Buffer.from(testData.instances.binaryType.one + .replace('id="binaryType"', 'id="binaryType2"') + .replace('my_file1.mp4', 'my_file2.mp4')), + { filename: 'data.xml' }, + ) + .attach('my_file2.mp4', Buffer.from('this is test file one'), { filename: 'my_file2.mp4' }) + .expect(201)) + .then(() => container.oneFirst(sql`select count(*) from blobs`)) + .then((count) => count.should.equal(2)) + .then(() => asAlice.get('/v1/projects/1/forms/binaryType/submissions/both/attachments/my_file1.mp4') + .expect(200) + .then(({ headers, body }) => { + headers['content-type'].should.equal('video/mp4'); + headers['content-disposition'].should.equal('attachment; filename="my_file1.mp4"; filename*=UTF-8\'\'my_file1.mp4'); + body.toString('utf8').should.equal('this is test file one'); + })) + .then(() => asAlice.get('/v1/projects/1/forms/binaryType2/submissions/bone/attachments/my_file2.mp4') + .expect(200) + .then(({ headers, body }) => { + headers['content-type'].should.equal('video/mp4'); + headers['content-disposition'].should.equal('attachment; filename="my_file2.mp4"; filename*=UTF-8\'\'my_file2.mp4'); + body.toString('utf8').should.equal('this is test file one'); + }))))); + it('should handle blob collisions and not purge still attached blobs', testService((service, container) => // One one instance of the form, two files are uploaded // On another instance of the form (different id), one file is uploaded