diff options
author | Julien Lancelot <julien.lancelot@gmail.com> | 2013-06-03 16:32:53 +0200 |
---|---|---|
committer | Julien Lancelot <julien.lancelot@gmail.com> | 2013-06-03 16:32:53 +0200 |
commit | f39271bce5a3a175885d98ba3630932471b580c4 (patch) | |
tree | 7eb859ffe6f3050e3e557b1a84aa2b4c051ced7e /sonar-plugin-api | |
parent | db1c1223dfcb54f3771c4918f4363006488312c3 (diff) | |
download | sonarqube-f39271bce5a3a175885d98ba3630932471b580c4.tar.gz sonarqube-f39271bce5a3a175885d98ba3630932471b580c4.zip |
SONAR-3755 Remove Action builder and replace it by Actions
Diffstat (limited to 'sonar-plugin-api')
3 files changed, 82 insertions, 59 deletions
diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Action.java b/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Action.java index 6da2f1ecbc4..a797d20106c 100644 --- a/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Action.java +++ b/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Action.java @@ -21,34 +21,46 @@ package org.sonar.api.issue.action; import com.google.common.base.Preconditions; import com.google.common.base.Strings; -import com.google.common.collect.Lists; -import org.sonar.api.ServerExtension; +import com.google.common.collect.ImmutableList; import org.sonar.api.issue.Issue; import org.sonar.api.issue.condition.Condition; -import java.util.Arrays; import java.util.List; -public class Action implements ServerExtension { +import static com.google.common.collect.Lists.newArrayList; + +public class Action { private final String key; private final List<Condition> conditions; private final List<Function> functions; - private Action(ActionBuilder builder) { - key = builder.key; - conditions = builder.conditions; - functions = builder.functions; + public Action(String key) { + this.key = key; + this.conditions = newArrayList(); + this.functions = newArrayList(); + + Preconditions.checkArgument(!Strings.isNullOrEmpty(key), "Action key must be set"); } public String key() { return key; } + public Action setConditions(Condition... conditions) { + this.conditions.addAll(ImmutableList.copyOf(conditions)); + return this; + } + public List<Condition> conditions() { return conditions; } + public Action setFunctions(Function... functions) { + this.functions.addAll(ImmutableList.copyOf(functions)); + return this; + } + public List<Function> functions() { return functions; } @@ -87,36 +99,4 @@ public class Action implements ServerExtension { return key; } - public static Action create(String key) { - return builder(key).build(); - } - - public static ActionBuilder builder(String key) { - return new ActionBuilder(key); - } - - public static class ActionBuilder { - private final String key; - private List<Condition> conditions = Lists.newArrayList(); - private List<Function> functions = Lists.newArrayList(); - - private ActionBuilder(String key) { - this.key = key; - } - - public ActionBuilder conditions(Condition... c) { - this.conditions.addAll(Arrays.asList(c)); - return this; - } - - public ActionBuilder functions(Function... f) { - this.functions.addAll(Arrays.asList(f)); - return this; - } - - public Action build() { - Preconditions.checkArgument(!Strings.isNullOrEmpty(key), "Action key must be set"); - return new Action(this); - } - } } diff --git a/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Actions.java b/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Actions.java new file mode 100644 index 00000000000..ae6ccb0e2cb --- /dev/null +++ b/sonar-plugin-api/src/main/java/org/sonar/api/issue/action/Actions.java @@ -0,0 +1,45 @@ +/* + * SonarQube, open source software quality management tool. + * Copyright (C) 2008-2013 SonarSource + * mailto:contact AT sonarsource DOT com + * + * SonarQube is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * SonarQube is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.api.issue.action; + +import org.sonar.api.ServerExtension; + +import java.util.List; + +import static com.google.common.collect.Lists.newArrayList; + +public class Actions implements ServerExtension { + + private final List<Action> actions; + + public Actions() { + actions = newArrayList(); + } + + public Action add(String actionKey) { + Action action = new Action(actionKey); + this.actions.add(action); + return action; + } + + public List<Action> list() { + return actions; + } +} diff --git a/sonar-plugin-api/src/test/java/org/sonar/api/issue/action/ActionTest.java b/sonar-plugin-api/src/test/java/org/sonar/api/issue/action/ActionTest.java index d961d134e21..d5a01d3ce6d 100644 --- a/sonar-plugin-api/src/test/java/org/sonar/api/issue/action/ActionTest.java +++ b/sonar-plugin-api/src/test/java/org/sonar/api/issue/action/ActionTest.java @@ -37,21 +37,20 @@ public class ActionTest { Function function2 = mock(Function.class); @Test - public void test_builder() throws Exception { - Action transition = Action.builder("link-to-jira") - .conditions(condition1, condition2) - .functions(function1, function2) - .build(); - assertThat(transition.key()).isEqualTo("link-to-jira"); - assertThat(transition.conditions()).containsOnly(condition1, condition2); - assertThat(transition.functions()).containsOnly(function1, function2); + public void test_action() throws Exception { + Action action = new Action("link-to-jira") + .setConditions(condition1, condition2) + .setFunctions(function1, function2); + + assertThat(action.key()).isEqualTo("link-to-jira"); + assertThat(action.conditions()).containsOnly(condition1, condition2); + assertThat(action.functions()).containsOnly(function1, function2); } - @Test public void key_should_be_set() throws Exception { try { - Action.builder("").build(); + new Action(""); fail(); } catch (Exception e) { assertThat(e).hasMessage("Action key must be set"); @@ -61,24 +60,23 @@ public class ActionTest { @Test public void should_verify_conditions() throws Exception { DefaultIssue issue = new DefaultIssue(); - Action transition = Action.builder("link-to-jira") - .conditions(condition1, condition2) - .build(); + Action action = new Action("link-to-jira") + .setConditions(condition1, condition2); when(condition1.matches(issue)).thenReturn(true); when(condition2.matches(issue)).thenReturn(false); - assertThat(transition.supports(issue)).isFalse(); + assertThat(action.supports(issue)).isFalse(); when(condition1.matches(issue)).thenReturn(true); when(condition2.matches(issue)).thenReturn(true); - assertThat(transition.supports(issue)).isTrue(); + assertThat(action.supports(issue)).isTrue(); } @Test public void test_equals_and_hashCode() throws Exception { - Action t1 = Action.create("link-to-jira"); - Action t2 = Action.create("link-to-jira"); - Action t3 = Action.create("comment"); + Action t1 = new Action("link-to-jira"); + Action t2 = new Action("link-to-jira"); + Action t3 = new Action("comment"); assertThat(t1).isEqualTo(t1); assertThat(t1).isEqualTo(t2); @@ -89,7 +87,7 @@ public class ActionTest { @Test public void test_toString() throws Exception { - Action t1 = Action.create("link-to-jira"); + Action t1 = new Action("link-to-jira"); assertThat(t1.toString()).isEqualTo("link-to-jira"); } |