/*
* SonarQube
* Copyright (C) 2009-2017 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program 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.
*
* This program 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.server.issue;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Lists;
import java.util.Date;
import java.util.Map;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.sonar.api.issue.Issue;
import org.sonar.core.issue.DefaultIssue;
import org.sonar.core.issue.FieldDiffs;
import org.sonar.core.issue.IssueChangeContext;
import org.sonar.db.DbTester;
import org.sonar.db.component.ComponentDto;
import org.sonar.db.issue.IssueDto;
import org.sonar.db.rule.RuleDto;
import org.sonar.server.issue.ws.BulkChangeAction;
import org.sonar.server.tester.UserSessionRule;
import static org.assertj.core.api.Assertions.assertThat;
import static org.sonar.api.rules.RuleType.BUG;
import static org.sonar.api.rules.RuleType.VULNERABILITY;
import static org.sonar.api.web.UserRole.ISSUE_ADMIN;
import static org.sonar.api.web.UserRole.USER;
import static org.sonar.db.component.ComponentTesting.newFileDto;
import static org.sonar.db.issue.IssueTesting.newDto;
import static org.sonar.db.rule.RuleTesting.newRuleDto;
public class SetTypeActionTest {
private static final Date NOW = new Date(10_000_000_000L);
private static final String USER_LOGIN = "john";
@Rule
public ExpectedException expectedException = ExpectedException.none();
@Rule
public UserSessionRule userSession = UserSessionRule.standalone();
@Rule
public DbTester db = DbTester.create();
private IssueFieldsSetter issueUpdater = new IssueFieldsSetter();
private SetTypeAction action = new SetTypeAction(issueUpdater, userSession);
@Test
public void set_type() {
IssueDto issueDto = newIssue().setType(BUG);
DefaultIssue issue = issueDto.toDefaultIssue();
setUserWithBrowseAndAdministerIssuePermission(issueDto);
action.execute(ImmutableMap.of("type", VULNERABILITY.name()),
new BulkChangeAction.ActionContext(issue, IssueChangeContext.createUser(NOW, userSession.getLogin()), null));
assertThat(issue.type()).isEqualTo(VULNERABILITY);
assertThat(issue.isChanged()).isTrue();
assertThat(issue.updateDate()).isEqualTo(NOW);
assertThat(issue.mustSendNotifications()).isFalse();
Map<String, FieldDiffs.Diff> change = issue.currentChange().diffs();
assertThat(change.get("type").newValue()).isEqualTo(VULNERABILITY);
assertThat(change.get("type").oldValue()).isEqualTo(BUG);
}
@Test
public void verify_fail_if_parameter_not_found() {
expectedException.expect(IllegalArgumentException.class);
expectedException.expectMessage("Missing parameter : 'type'");
action.verify(ImmutableMap.of("unknwown", VULNERABILITY.name()), Lists.newArrayList(), userSession);
}
@Test
public void verify_fail_if_type_is_invalid() {
expectedException.expect(IllegalArgumentException.class);
expectedException.expectMessage("Unknown type : unknown");
action.verify(ImmutableMap.of("type", "unknown"), Lists.newArrayList(), userSession);
}
@Test
public void support_only_unresolved_issues() {
IssueDto issueDto = newIssue().setType(BUG);
DefaultIssue issue = issueDto.toDefaultIssue();
setUserWithBrowseAndAdministerIssuePermission(issueDto);
assertThat(action.supports(issue.setResolution(null))).isTrue();
assertThat(action.supports(issue.setResolution(Issue.RESOLUTION_FIXED))).isFalse();
}
@Test
public void support_only_issues_with_issue_admin_permission() {
IssueDto authorizedIssueDto = newIssue().setType(BUG);
DefaultIssue authorizedIssue = authorizedIssueDto.toDefaultIssue();
setUserWithBrowseAndAdministerIssuePermission(authorizedIssueDto);
DefaultIssue unauthorizedIssue = newIssue().setType(BUG).toDefaultIssue();
assertThat(action.supports(authorizedIssue.setResolution(null))).isTrue();
assertThat(action.supports(unauthorizedIssue.setResolution(null))).isFalse();
}
private void setUserWithBrowseAndAdministerIssuePermission(IssueDto issueDto) {
ComponentDto project = db.getDbClient().componentDao().selectByUuid(db.getSession(), issueDto.getProjectUuid()).get();
ComponentDto component = db.getDbClient().componentDao().selectByUuid(db.getSession(), issueDto.getComponentUuid()).get();
userSession.logIn(USER_LOGIN)
.addProjectPermission(ISSUE_ADMIN, project, component)
.addProjectPermission(USER, project, component);
}
private IssueDto newIssue() {
RuleDto rule = db.rules().insertRule(newRuleDto());
ComponentDto project = db.components().insertPrivateProject();
ComponentDto file = db.components().insertComponent(newFileDto(project));
return newDto(rule, file, project);
}
}