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