interim+500

interim+500

interim+500
pull/22385/head
mertalev 2025-10-02 15:15:32 +07:00
parent 2d6a2dc77b
commit 177c997d96
No known key found for this signature in database
GPG Key ID: DF6ABC77AAD98C95
2 changed files with 22 additions and 16 deletions

@ -223,7 +223,8 @@ describe('/upload', () => {
});
});
it('should reject attempt to start upload of existing incomplete asset', async () => {
// TODO: find a way to test interim responses
it('should return 500 if existing incomplete asset', async () => {
const content = randomBytes(1024);
const firstRequest = await request(app)
@ -252,8 +253,7 @@ describe('/upload', () => {
.set('Upload-Length', '1024')
.send();
expect(secondRequest.status).toBe(400);
expect(secondRequest.headers['location']).toEqual(firstRequest.headers['location']);
expect(secondRequest.status).toBe(500);
expect(secondRequest.text).toEqual('Incomplete asset already exists');
});

@ -57,22 +57,28 @@ export class AssetUploadService extends BaseService {
assetData.metadata,
);
} catch (error: any) {
if (isAssetChecksumConstraint(error)) {
const duplicate = await this.assetRepository.getUploadAssetIdByChecksum(req.auth.user.id, dto.checksum);
if (!duplicate) {
res.status(500).send('Error locating duplicate for checksum constraint');
return;
}
if (!isAssetChecksumConstraint(error)) {
this.logger.error(`Error creating upload asset record: ${error.message}`);
res.status(500).send('Error creating upload asset record');
return;
}
if (duplicate.status !== AssetStatus.Partial) {
return this.sendAlreadyCompletedProblem(res);
}
const location = `/api/upload/${duplicate.id}`;
res.status(400).setHeader('Location', location).send('Incomplete asset already exists');
const duplicate = await this.assetRepository.getUploadAssetIdByChecksum(req.auth.user.id, dto.checksum);
if (!duplicate) {
res.status(500).send('Error locating duplicate for checksum constraint');
return;
}
this.logger.error(`Error creating upload asset record: ${error.message}`);
res.status(500).send('Error creating upload asset record');
if (duplicate.status !== AssetStatus.Partial) {
return this.sendAlreadyCompletedProblem(res);
}
const location = `/api/upload/${duplicate.id}`;
if (version <= MAX_RUFH_INTEROP_VERSION) {
this.sendInterimResponse(res, location, version);
}
// this is a 5xx to indicate the client should do offset retrieval and resume
res.status(500).send('Incomplete asset already exists');
return;
}