aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSébastien Lesaint <sebastien.lesaint@sonarsource.com>2016-05-10 18:06:36 +0200
committerSébastien Lesaint <sebastien.lesaint@sonarsource.com>2016-05-11 14:02:52 +0200
commit3677959b40e456df57b8aabfc2653a63a98fae6d (patch)
tree7546f625161921a474cfa5e8617460709ed20fee
parent8405142eb1e9ea19f518e4eb49e5f0078d1e4fb9 (diff)
downloadsonarqube-3677959b40e456df57b8aabfc2653a63a98fae6d.tar.gz
sonarqube-3677959b40e456df57b8aabfc2653a63a98fae6d.zip
SONAR-7532 do not log submitter when unset
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImpl.java25
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImplTest.java84
2 files changed, 84 insertions, 25 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImpl.java b/server/sonar-server/src/main/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImpl.java
index 9d76669a7e7..aed518e626a 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImpl.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImpl.java
@@ -97,24 +97,29 @@ public class CeWorkerCallableImpl implements CeWorkerCallable {
private static Profiler startProfiler(CeTask task) {
Profiler profiler = Profiler.create(LOG);
- return profiler.startInfo("Execute task | project={} | type={} | id={} | submitter='{}'",
- task.getComponentKey(), task.getType(), task.getUuid(), getSubmitterLoginForLog(task));
+ addContext(profiler, task);
+ return profiler.startInfo("Execute task");
}
private static void stopProfiler(Profiler profiler, CeTask task, CeActivityDto.Status status) {
+ addContext(profiler, task);
if (status == CeActivityDto.Status.FAILED) {
- profiler.stopError("Executed task | project={} | type={} | id={} | submitter='{}'",
- task.getComponentKey(), task.getType(), task.getUuid(), getSubmitterLoginForLog(task));
+ profiler.stopError("Executed task");
} else {
- profiler.stopInfo("Executed task | project={} | type={} | id={} | submitter='{}'",
- task.getComponentKey(), task.getType(), task.getUuid(), getSubmitterLoginForLog(task));
+ profiler.stopInfo("Executed task");
}
}
- private static String getSubmitterLoginForLog(CeTask task) {
- if (task.getSubmitterLogin() == null) {
- return "";
+ private static void addContext(Profiler profiler, CeTask task) {
+ profiler
+ .logTimeLast(true)
+ .addContext("project", task.getComponentKey())
+ .addContext("type", task.getType())
+ .addContext("id", task.getUuid());
+ String submitterLogin = task.getSubmitterLogin();
+ if (submitterLogin != null) {
+ profiler.addContext("submitter", submitterLogin);
}
- return task.getSubmitterLogin();
}
+
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImplTest.java b/server/sonar-server/src/test/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImplTest.java
index 520f4fc60d4..956de0a1585 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImplTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/computation/taskprocessor/CeWorkerCallableImplTest.java
@@ -21,6 +21,7 @@ package org.sonar.server.computation.taskprocessor;
import com.google.common.base.Optional;
import java.util.List;
+import javax.annotation.Nullable;
import org.junit.Rule;
import org.junit.Test;
import org.mockito.InOrder;
@@ -64,7 +65,7 @@ public class CeWorkerCallableImplTest {
@Test
public void fail_when_no_CeTaskProcessor_is_found_in_repository() throws Exception {
- CeTask task = new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin(null).build();
+ CeTask task = createCeTask(null);
taskProcessorRepository.setNoProcessorForTask(CeTaskTypes.REPORT);
when(queue.peek()).thenReturn(Optional.of(task));
@@ -77,7 +78,7 @@ public class CeWorkerCallableImplTest {
@Test
public void peek_and_process_task() throws Exception {
- CeTask task = new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin(null).build();
+ CeTask task = createCeTask(null);
taskProcessorRepository.setProcessorForTask(task.getType(), taskProcessor);
when(queue.peek()).thenReturn(Optional.of(task));
@@ -91,10 +92,10 @@ public class CeWorkerCallableImplTest {
@Test
public void fail_to_process_task() throws Exception {
- CeTask task = new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin(null).build();
+ CeTask task = createCeTask(null);
when(queue.peek()).thenReturn(Optional.of(task));
taskProcessorRepository.setProcessorForTask(task.getType(), taskProcessor);
- doThrow(new IllegalStateException("simulate exception thrown by TaskProcessor#process")).when(taskProcessor).process(task);
+ makeTaskProcessorFail(task);
assertThat(underTest.call()).isTrue();
@@ -104,33 +105,86 @@ public class CeWorkerCallableImplTest {
inOrder.verify(ceLogging).clearForTask();
}
+ private void makeTaskProcessorFail(CeTask task) {
+ doThrow(new IllegalStateException("simulate exception thrown by TaskProcessor#process")).when(taskProcessor).process(task);
+ }
+
@Test
- public void do_not_display_null_in_log_when_submitterLogin_is_not_set() throws Exception {
- CeTask task = new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin(null).build();
- when(queue.peek()).thenReturn(Optional.of(task));
- taskProcessorRepository.setProcessorForTask(task.getType(), taskProcessor);
+ public void do_not_display_submitter_param_in_log_when_submitterLogin_is_not_set_in_case_of_success() throws Exception {
+ when(queue.peek()).thenReturn(Optional.of(createCeTask(null)));
+ taskProcessorRepository.setProcessorForTask(CeTaskTypes.REPORT, taskProcessor);
underTest.call();
List<String> logs = logTester.logs(LoggerLevel.INFO);
assertThat(logs).hasSize(4);
for (int i = 0; i < 4; i++) {
- assertThat(logs.get(i)).contains(" | submitter=''");
+ assertThat(logs.get(i)).doesNotContain(" | submitter=");
}
}
@Test
- public void display_submitterLogin_in_logs_when_set() throws Exception {
- CeTask task = new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin("FooBar").build();
- when(queue.peek()).thenReturn(Optional.of(task));
- taskProcessorRepository.setProcessorForTask(task.getType(), taskProcessor);
+ public void do_not_display_submitter_param_in_log_when_submitterLogin_is_not_set_in_case_of_error() throws Exception {
+ CeTask ceTask = createCeTask(null);
+ when(queue.peek()).thenReturn(Optional.of(ceTask));
+ taskProcessorRepository.setProcessorForTask(ceTask.getType(), taskProcessor);
+ makeTaskProcessorFail(ceTask);
+
+ underTest.call();
+
+ List<String> logs = logTester.logs(LoggerLevel.INFO);
+ assertThat(logs).hasSize(2);
+ for (int i = 0; i < 2; i++) {
+ assertThat(logs.get(i)).doesNotContain(" | submitter=");
+ }
+ logs = logTester.logs(LoggerLevel.ERROR);
+ assertThat(logs).hasSize(3);
+ for (int i = 0; i < 3; i++) {
+ assertThat(logs.get(i)).doesNotContain(" | submitter=");
+ }
+ }
+
+ @Test
+ public void display_submitterLogin_in_logs_when_set_in_case_of_success() throws Exception {
+ when(queue.peek()).thenReturn(Optional.of(createCeTask("FooBar")));
+ taskProcessorRepository.setProcessorForTask(CeTaskTypes.REPORT, taskProcessor);
underTest.call();
List<String> logs = logTester.logs(LoggerLevel.INFO);
assertThat(logs).hasSize(4);
- for (int i = 0; i < 4; i++) {
- assertThat(logs.get(i)).contains(" | submitter='FooBar'");
+ for (int i = 0; i < 2; i++) {
+ assertThat(logs.get(i)).contains(" | submitter=FooBar");
+ }
+ for (int i = 2; i < 4; i++) {
+ assertThat(logs.get(i)).contains(" | submitter=FooBar | time=");
}
}
+
+ @Test
+ public void display_submitterLogin_in_logs_when_set_in_case_of_error() throws Exception {
+ CeTask ceTask = createCeTask("FooBar");
+ when(queue.peek()).thenReturn(Optional.of(ceTask));
+ taskProcessorRepository.setProcessorForTask(ceTask.getType(), taskProcessor);
+ makeTaskProcessorFail(ceTask);
+
+ underTest.call();
+
+ List<String> logs = logTester.logs(LoggerLevel.INFO);
+ assertThat(logs).hasSize(2);
+ for (int i = 0; i < 2; i++) {
+ assertThat(logs.get(i)).contains(" | submitter=FooBar");
+ }
+ logs = logTester.logs(LoggerLevel.ERROR);
+ assertThat(logs).hasSize(3);
+ for (int i = 0; i < 3; i++) {
+ String log = logs.get(i);
+ assertThat(log.contains(" | submitter=FooBar | time=") || log.equals("Failed to execute task " + ceTask.getUuid()))
+ .isTrue();
+ }
+ }
+
+ private static CeTask createCeTask(@Nullable String submitterLogin) {
+ return new CeTask.Builder().setUuid("TASK_1").setType(CeTaskTypes.REPORT).setComponentUuid("PROJECT_1").setSubmitterLogin(submitterLogin).build();
+ }
}