Skip to content

Commit

Permalink
fix(taskAttachment): prevent NPE for deletion of attachments with emp…
Browse files Browse the repository at this point in the history
…ty or nonexisting taskId

related to #3545
  • Loading branch information
PHWaechtler committed Nov 27, 2024
1 parent 119cbf8 commit 997d9a0
Show file tree
Hide file tree
Showing 3 changed files with 61 additions and 20 deletions.
4 changes: 4 additions & 0 deletions engine/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -333,6 +333,10 @@
<version>${project.version}</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
</dependencies>


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

import java.io.Serializable;

import org.apache.commons.lang3.StringUtils;
import org.camunda.bpm.engine.history.UserOperationLogEntry;
import org.camunda.bpm.engine.impl.interceptor.Command;
import org.camunda.bpm.engine.impl.interceptor.CommandContext;
Expand Down Expand Up @@ -49,16 +50,16 @@ public DeleteAttachmentCmd(String taskId, String attachmentId) {

public Object execute(CommandContext commandContext) {
AttachmentEntity attachment = null;
if (taskId != null) {
if (StringUtils.isNotEmpty(taskId)) {
attachment = (AttachmentEntity) commandContext
.getAttachmentManager()
.findAttachmentByTaskIdAndAttachmentId(taskId, attachmentId);
ensureNotNull("No attachment exist for task id '" + taskId + " and attachmentId '" + attachmentId + "'.", "attachment", attachment);
ensureNotNull("No attachment exists for task id '" + taskId + " and attachmentId '" + attachmentId + "'.", "attachment", attachment);
} else {
attachment = commandContext
.getDbEntityManager()
.selectById(AttachmentEntity.class, attachmentId);
ensureNotNull("No attachment exist with attachmentId '" + attachmentId + "'.", "attachment", attachment);
ensureNotNull("No attachment exists with attachmentId '" + attachmentId + "'.", "attachment", attachment);
}

commandContext
Expand All @@ -71,17 +72,23 @@ public Object execute(CommandContext commandContext) {
.deleteByteArrayById(attachment.getContentId());
}

if (attachment.getTaskId()!=null) {
if (StringUtils.isNotEmpty(attachment.getTaskId())) {
TaskEntity task = commandContext
.getTaskManager()
.findTaskById(attachment.getTaskId());

PropertyChange propertyChange = new PropertyChange("name", null, attachment.getName());
if (task != null) {
PropertyChange propertyChange = new PropertyChange("name", null, attachment.getName());

commandContext.getOperationLogManager()
.logAttachmentOperation(UserOperationLogEntry.OPERATION_TYPE_DELETE_ATTACHMENT, task, propertyChange);
commandContext.getOperationLogManager()
.logAttachmentOperation(UserOperationLogEntry.OPERATION_TYPE_DELETE_ATTACHMENT, task, propertyChange);

task.triggerUpdateEvent();
task.triggerUpdateEvent();
} else {
ensureNotNull(
"No task exists for attachment '" + attachmentId + "' with taskId '" + attachment.getTaskId() + "'.",
"task", task);
}
}

return null;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -552,7 +552,6 @@ public void testTaskAssignee() {
taskService.deleteTask(task.getId(), true);
}


@Test
public void testSaveTaskNullTask() {
try {
Expand Down Expand Up @@ -773,7 +772,6 @@ public void testCompleteTaskWithParametersEmptyParameters() {
assertNull(task);
}


@Deployment(resources = TWO_TASKS_PROCESS)
@Test
public void testCompleteWithParametersTask() {
Expand Down Expand Up @@ -2228,14 +2226,47 @@ public void testDeleteTaskAttachmentWithNullParameters() {
}

@Test
public void testDeleteTaskAttachmentWithTaskIdNull() {
int historyLevel = processEngineConfiguration.getHistoryLevel().getId();
if (historyLevel> ProcessEngineConfigurationImpl.HISTORYLEVEL_NONE) {
try {
taskService.deleteTaskAttachment(null, "myAttachmentId");
fail("expected process engine exception");
} catch(ProcessEngineException e) {}
}
@RequiredHistoryLevel(ProcessEngineConfiguration.HISTORY_NONE)
public void testDeleteTaskAttachmentThatDoesNotExist() {
assertThatThrownBy(() -> taskService.deleteTaskAttachment(null, "attachmentDoesNotExist")).isInstanceOf(
NullValueException.class)
.hasMessageContaining("No attachment exists with attachmentId 'attachmentDoesNotExist'");
}

@Test
@Deployment(resources = { "org/camunda/bpm/engine/test/api/oneTaskProcess.bpmn20.xml" })
@RequiredHistoryLevel(ProcessEngineConfiguration.HISTORY_NONE)
public void testDeleteTaskAttachmentWithTaskIdEmpty() {
// given
runtimeService.startProcessInstanceByKey("oneTaskProcess");
Attachment attachment = taskService.createAttachment("web page", "", null, "weatherforcast",
"temperatures and more", new ByteArrayInputStream("someContent".getBytes()));
final String attachmentId = attachment.getId();
assertThat(taskService.getAttachment(attachmentId)).isNotNull();

// when
taskService.deleteTaskAttachment("", attachmentId);

// then
assertThat(taskService.getAttachment(attachmentId)).isNull();
}

@Test
@Deployment(resources = { "org/camunda/bpm/engine/test/api/oneTaskProcess.bpmn20.xml" })
@RequiredHistoryLevel(ProcessEngineConfiguration.HISTORY_AUDIT)
public void testDeleteTaskAttachmentWithTaskIdNoLongerExists() {
// given
runtimeService.startProcessInstanceByKey("oneTaskProcess");
final String taskId = taskService.createTaskQuery().singleResult().getId();
final Attachment attachment = taskService.createAttachment("web page", taskId, null, "weatherforcast",
"temperatures and more", "http://weather.com");
taskService.complete(taskId);
final String attachmentId = attachment.getId();

// when/then
assertThatThrownBy(() -> taskService.deleteTaskAttachment(taskId, attachmentId)).isInstanceOf(
NullValueException.class)
.hasMessageContaining("No task exists for attachment '" + attachmentId + "' with taskId '" + taskId + "'.");
}

@Test
Expand Down Expand Up @@ -2297,7 +2328,7 @@ public void testUpdateVariablesLocalForNonExistingTaskId() {
}

@Test
public void testUpdateVariablesLocaForNullTaskId() {
public void testUpdateVariablesLocalForNullTaskId() {
Map<String, Object> modifications = new HashMap<>();
modifications.put("variable1", "anotherValue1");
modifications.put("variable2", "anotherValue2");
Expand Down Expand Up @@ -2998,7 +3029,6 @@ public void testHandleEscalationInterruptInEventSubprocess() {
assertEquals("bar",runtimeService.createVariableInstanceQuery().variableName("foo").singleResult().getValue());
}


@Test
@Deployment(resources = { "org/camunda/bpm/engine/test/api/task/TaskServiceTest.handleUserTaskEscalation.bpmn20.xml" })
public void testHandleEscalationNonInterruptEmbeddedSubprocess() {
Expand Down

0 comments on commit 997d9a0

Please sign in to comment.