aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-server
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-server')
-rw-r--r--sonar-server/src/main/java/org/sonar/server/issue/ActionService.java16
-rw-r--r--sonar-server/src/main/java/org/sonar/server/issue/InternalRubyIssueService.java4
-rw-r--r--sonar-server/src/main/java/org/sonar/server/issue/IssueService.java13
-rw-r--r--sonar-server/src/test/java/org/sonar/server/issue/ActionServiceTest.java4
-rw-r--r--sonar-server/src/test/java/org/sonar/server/issue/IssueServiceTest.java20
5 files changed, 17 insertions, 40 deletions
diff --git a/sonar-server/src/main/java/org/sonar/server/issue/ActionService.java b/sonar-server/src/main/java/org/sonar/server/issue/ActionService.java
index 3e55485410d..48df6ff62d7 100644
--- a/sonar-server/src/main/java/org/sonar/server/issue/ActionService.java
+++ b/sonar-server/src/main/java/org/sonar/server/issue/ActionService.java
@@ -68,6 +68,12 @@ public class ActionService implements ServerComponent {
this.actions = actions;
}
+ public List<Action> listAvailableActions(String issueKey) {
+ IssueQueryResult queryResult = loadIssue(issueKey);
+ final DefaultIssue issue = (DefaultIssue) queryResult.first();
+ return listAvailableActions(issue);
+ }
+
public List<Action> listAvailableActions(final Issue issue) {
return newArrayList(Iterables.filter(actions.list(), new Predicate<Action>() {
@Override
@@ -77,21 +83,11 @@ public class ActionService implements ServerComponent {
}));
}
- public List<Action> listAvailableActions(String issueKey) {
- IssueQueryResult queryResult = loadIssue(issueKey);
- final DefaultIssue issue = (DefaultIssue) queryResult.first();
- return listAvailableActions(issue);
- }
-
public Issue execute(String issueKey, String actionKey, UserSession userSession) {
Preconditions.checkArgument(!Strings.isNullOrEmpty(actionKey), "Missing action");
IssueQueryResult queryResult = loadIssue(issueKey);
DefaultIssue issue = (DefaultIssue) queryResult.first();
- if (issue == null) {
- throw new IllegalArgumentException("Issue is not found : " + issueKey);
- }
-
Action action = getAction(actionKey);
if (action == null) {
throw new IllegalArgumentException("Action is not found : " + actionKey);
diff --git a/sonar-server/src/main/java/org/sonar/server/issue/InternalRubyIssueService.java b/sonar-server/src/main/java/org/sonar/server/issue/InternalRubyIssueService.java
index 321506a0528..87533a774ab 100644
--- a/sonar-server/src/main/java/org/sonar/server/issue/InternalRubyIssueService.java
+++ b/sonar-server/src/main/java/org/sonar/server/issue/InternalRubyIssueService.java
@@ -81,11 +81,11 @@ public class InternalRubyIssueService implements ServerComponent {
}
public List<Transition> listTransitions(String issueKey) {
- return issueService.listTransitions(issueKey, UserSession.get());
+ return issueService.listTransitions(issueKey);
}
public List<Transition> listTransitions(Issue issue) {
- return issueService.listTransitions(issue, UserSession.get());
+ return issueService.listTransitions(issue);
}
public List<String> listStatus() {
diff --git a/sonar-server/src/main/java/org/sonar/server/issue/IssueService.java b/sonar-server/src/main/java/org/sonar/server/issue/IssueService.java
index 14ade9f87e4..331bc0ebdc4 100644
--- a/sonar-server/src/main/java/org/sonar/server/issue/IssueService.java
+++ b/sonar-server/src/main/java/org/sonar/server/issue/IssueService.java
@@ -92,25 +92,25 @@ public class IssueService implements ServerComponent {
* <p/>
* Never return null, but return an empty list if the issue does not exist.
*/
- public List<Transition> listTransitions(String issueKey, UserSession userSession) {
- return listTransitions(loadIssue(issueKey).first(), userSession);
+ public List<Transition> listTransitions(String issueKey) {
+ Issue issue = loadIssue(issueKey).first();
+ return listTransitions(issue);
}
/**
* Never return null, but an empty list if the issue does not exist.
+ * No security check is done since it should already have been done to get the issue
*/
- public List<Transition> listTransitions(@Nullable Issue issue, UserSession userSession) {
+ public List<Transition> listTransitions(@Nullable Issue issue) {
if (issue == null) {
return Collections.emptyList();
}
- checkAuthorization(userSession, issue, UserRole.USER);
return workflow.outTransitions(issue);
}
public Issue doTransition(String issueKey, String transition, UserSession userSession) {
IssueQueryResult queryResult = loadIssue(issueKey);
DefaultIssue issue = (DefaultIssue) queryResult.first();
- checkAuthorization(userSession, issue, UserRole.USER);
IssueChangeContext context = IssueChangeContext.createUser(new Date(), userSession.login());
if (workflow.doTransition(issue, transition, context)) {
issueStorage.save(issue);
@@ -122,7 +122,6 @@ public class IssueService implements ServerComponent {
public Issue assign(String issueKey, @Nullable String assignee, UserSession userSession) {
IssueQueryResult queryResult = loadIssue(issueKey);
DefaultIssue issue = (DefaultIssue) queryResult.first();
- checkAuthorization(userSession, issue, UserRole.USER);
if (assignee != null && userFinder.findByLogin(assignee) == null) {
throw new IllegalArgumentException("Unknown user: " + assignee);
}
@@ -140,7 +139,6 @@ public class IssueService implements ServerComponent {
}
IssueQueryResult queryResult = loadIssue(issueKey);
DefaultIssue issue = (DefaultIssue) queryResult.first();
- checkAuthorization(userSession, issue, UserRole.USER);
IssueChangeContext context = IssueChangeContext.createUser(new Date(), userSession.login());
if (issueUpdater.plan(issue, actionPlanKey, context)) {
@@ -153,7 +151,6 @@ public class IssueService implements ServerComponent {
public Issue setSeverity(String issueKey, String severity, UserSession userSession) {
IssueQueryResult queryResult = loadIssue(issueKey);
DefaultIssue issue = (DefaultIssue) queryResult.first();
- checkAuthorization(userSession, issue, UserRole.USER);
IssueChangeContext context = IssueChangeContext.createUser(new Date(), userSession.login());
if (issueUpdater.setManualSeverity(issue, severity, context)) {
diff --git a/sonar-server/src/test/java/org/sonar/server/issue/ActionServiceTest.java b/sonar-server/src/test/java/org/sonar/server/issue/ActionServiceTest.java
index 1e4831301ad..9624fe12cfd 100644
--- a/sonar-server/src/test/java/org/sonar/server/issue/ActionServiceTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/issue/ActionServiceTest.java
@@ -124,7 +124,7 @@ public class ActionServiceTest {
actionService.execute("ABCD", "link-to-jira", mock(UserSession.class));
fail();
} catch (Exception e) {
- assertThat(e).isInstanceOf(IllegalStateException.class).hasMessage("No issue");
+ assertThat(e).isInstanceOf(IllegalStateException.class).hasMessage("No issue found");
}
verifyZeroInteractions(function);
}
@@ -187,7 +187,7 @@ public class ActionServiceTest {
actionService.listAvailableActions("ABCD");
fail();
} catch (Exception e) {
- assertThat(e).isInstanceOf(IllegalStateException.class).hasMessage("No issue");
+ assertThat(e).isInstanceOf(IllegalStateException.class).hasMessage("No issue found");
}
}
diff --git a/sonar-server/src/test/java/org/sonar/server/issue/IssueServiceTest.java b/sonar-server/src/test/java/org/sonar/server/issue/IssueServiceTest.java
index bfeec5cbfc1..b529a572902 100644
--- a/sonar-server/src/test/java/org/sonar/server/issue/IssueServiceTest.java
+++ b/sonar-server/src/test/java/org/sonar/server/issue/IssueServiceTest.java
@@ -118,29 +118,25 @@ public class IssueServiceTest {
@Test
public void should_list_transitions() {
- grantAccess();
List<Transition> transitions = newArrayList(transition);
when(workflow.outTransitions(issue)).thenReturn(transitions);
- List<Transition> result = issueService.listTransitions("ABCD", userSession);
+ List<Transition> result = issueService.listTransitions("ABCD");
assertThat(result).hasSize(1);
assertThat(result.get(0)).isEqualTo(transition);
- verify(authorizationDao).isAuthorizedComponentId(anyLong(), anyInt(), eq(UserRole.USER));
}
@Test
public void should_return_no_transition() {
- grantAccess();
when(issueQueryResult.first()).thenReturn(null);
when(issueQueryResult.issues()).thenReturn(newArrayList((Issue) new DefaultIssue()));
- assertThat(issueService.listTransitions("ABCD", userSession)).isEmpty();
+ assertThat(issueService.listTransitions("ABCD")).isEmpty();
verifyZeroInteractions(workflow);
}
@Test
public void should_do_transition() {
- grantAccess();
when(workflow.doTransition(eq(issue), eq(transition.key()), any(IssueChangeContext.class))).thenReturn(true);
Issue result = issueService.doTransition("ABCD", transition.key(), userSession);
@@ -155,7 +151,6 @@ public class IssueServiceTest {
assertThat(issueChangeContext.date()).isNotNull();
verify(issueNotifications).sendChanges(eq(issue), eq(issueChangeContext), eq(issueQueryResult));
- verify(authorizationDao).isAuthorizedComponentId(anyLong(), anyInt(), eq(UserRole.USER));
}
@Test
@@ -172,7 +167,6 @@ public class IssueServiceTest {
@Test
public void should_assign() {
- grantAccess();
String assignee = "perceval";
when(userFinder.findByLogin(assignee)).thenReturn(new DefaultUser());
@@ -190,12 +184,10 @@ public class IssueServiceTest {
assertThat(issueChangeContext.date()).isNotNull();
verify(issueNotifications).sendChanges(eq(issue), eq(issueChangeContext), eq(issueQueryResult));
- verify(authorizationDao).isAuthorizedComponentId(anyLong(), anyInt(), eq(UserRole.USER));
}
@Test
public void should_not_assign() {
- grantAccess();
String assignee = "perceval";
when(userFinder.findByLogin(assignee)).thenReturn(new DefaultUser());
@@ -210,7 +202,6 @@ public class IssueServiceTest {
@Test
public void should_fail_assign_if_assignee_not_found() {
- grantAccess();
String assignee = "perceval";
when(userFinder.findByLogin(assignee)).thenReturn(null);
@@ -229,7 +220,6 @@ public class IssueServiceTest {
@Test
public void should_plan() {
- grantAccess();
String actionPlanKey = "EFGH";
when(actionPlanService.findByKey(actionPlanKey, userSession)).thenReturn(new DefaultActionPlan());
@@ -247,12 +237,10 @@ public class IssueServiceTest {
assertThat(issueChangeContext.date()).isNotNull();
verify(issueNotifications).sendChanges(eq(issue), eq(issueChangeContext), eq(issueQueryResult));
- verify(authorizationDao).isAuthorizedComponentId(anyLong(), anyInt(), eq(UserRole.USER));
}
@Test
public void should_not_plan() {
- grantAccess();
String actionPlanKey = "EFGH";
when(actionPlanService.findByKey(actionPlanKey, userSession)).thenReturn(new DefaultActionPlan());
@@ -267,7 +255,6 @@ public class IssueServiceTest {
@Test
public void should_fail_plan_if_action_plan_not_found() {
- grantAccess();
String actionPlanKey = "EFGH";
when(actionPlanService.findByKey(actionPlanKey, userSession)).thenReturn(null);
@@ -285,7 +272,6 @@ public class IssueServiceTest {
@Test
public void should_set_severity() {
- grantAccess();
String severity = "MINOR";
when(issueUpdater.setManualSeverity(eq(issue), eq(severity), any(IssueChangeContext.class))).thenReturn(true);
@@ -301,12 +287,10 @@ public class IssueServiceTest {
assertThat(issueChangeContext.date()).isNotNull();
verify(issueNotifications).sendChanges(eq(issue), eq(issueChangeContext), eq(issueQueryResult));
- verify(authorizationDao).isAuthorizedComponentId(anyLong(), anyInt(), eq(UserRole.USER));
}
@Test
public void should_not_set_severity() {
- grantAccess();
String severity = "MINOR";
when(issueUpdater.setManualSeverity(eq(issue), eq(severity), any(IssueChangeContext.class))).thenReturn(false);