/components/camel-jira/src/test/java/org/apache/camel/component/jira/producer/AddWorkLogProducerTest.java
Java | 210 lines | 163 code | 31 blank | 16 comment | 0 complexity | dd8f256bcf265528d0143a83e0655f7d MD5 | raw file
- /*
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- package org.apache.camel.component.jira.producer;
- import java.net.URI;
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.Date;
- import java.util.HashMap;
- import java.util.Map;
- import com.atlassian.jira.rest.client.api.IssueRestClient;
- import com.atlassian.jira.rest.client.api.JiraRestClient;
- import com.atlassian.jira.rest.client.api.JiraRestClientFactory;
- import com.atlassian.jira.rest.client.api.domain.Issue;
- import com.atlassian.jira.rest.client.api.domain.Worklog;
- import com.atlassian.jira.rest.client.api.domain.input.WorklogInput;
- import io.atlassian.util.concurrent.Promises;
- import org.apache.camel.CamelContext;
- import org.apache.camel.CamelExecutionException;
- import org.apache.camel.EndpointInject;
- import org.apache.camel.Produce;
- import org.apache.camel.ProducerTemplate;
- import org.apache.camel.builder.RouteBuilder;
- import org.apache.camel.component.jira.JiraComponent;
- import org.apache.camel.component.mock.MockEndpoint;
- import org.apache.camel.spi.Registry;
- import org.apache.camel.test.junit5.CamelTestSupport;
- import org.junit.jupiter.api.Test;
- import org.junit.jupiter.api.extension.ExtendWith;
- import org.mockito.Mock;
- import org.mockito.junit.jupiter.MockitoExtension;
- import org.mockito.stubbing.Answer;
- import static org.apache.camel.component.jira.JiraConstants.ISSUE_KEY;
- import static org.apache.camel.component.jira.JiraConstants.JIRA;
- import static org.apache.camel.component.jira.JiraConstants.JIRA_REST_CLIENT_FACTORY;
- import static org.apache.camel.component.jira.JiraConstants.MINUTES_SPENT;
- import static org.apache.camel.component.jira.JiraTestConstants.JIRA_CREDENTIALS;
- import static org.apache.camel.component.jira.Utils.createIssueWithComments;
- import static org.apache.camel.component.jira.Utils.createIssueWithWorkLogs;
- import static org.apache.camel.component.jira.Utils.newWorkLog;
- import static org.apache.camel.test.junit5.TestSupport.assertIsInstanceOf;
- import static org.apache.camel.test.junit5.TestSupport.assertStringContains;
- import static org.junit.jupiter.api.Assertions.fail;
- import static org.mockito.ArgumentMatchers.any;
- import static org.mockito.ArgumentMatchers.eq;
- import static org.mockito.Mockito.lenient;
- import static org.mockito.Mockito.never;
- import static org.mockito.Mockito.verify;
- import static org.mockito.Mockito.when;
- @ExtendWith(MockitoExtension.class)
- public class AddWorkLogProducerTest extends CamelTestSupport {
- @Mock
- private JiraRestClient jiraClient;
- @Mock
- private JiraRestClientFactory jiraRestClientFactory;
- @Mock
- private IssueRestClient issueRestClient;
- @Produce("direct:start")
- private ProducerTemplate template;
- @EndpointInject("mock:result")
- private MockEndpoint mockResult;
- private Issue backendIssue;
- @Override
- protected void bindToRegistry(Registry registry) {
- registry.bind(JIRA_REST_CLIENT_FACTORY, jiraRestClientFactory);
- }
- public void setMocks() {
- lenient().when(jiraRestClientFactory.createWithBasicHttpAuthentication(any(), any(), any())).thenReturn(jiraClient);
- lenient().when(jiraClient.getIssueClient()).thenReturn(issueRestClient);
- backendIssue = createIssueWithComments(1, 1);
- lenient().when(issueRestClient.getIssue(any())).then(inv -> Promises.promise(backendIssue));
- }
- @Override
- protected CamelContext createCamelContext() throws Exception {
- setMocks();
- CamelContext camelContext = super.createCamelContext();
- camelContext.disableJMX();
- JiraComponent component = new JiraComponent(camelContext);
- camelContext.addComponent(JIRA, component);
- return camelContext;
- }
- @Override
- protected RouteBuilder createRouteBuilder() {
- return new RouteBuilder() {
- @Override
- public void configure() {
- from("direct:start")
- .to("jira://addWorkLog?jiraUrl=" + JIRA_CREDENTIALS)
- .to(mockResult);
- }
- };
- }
- @Test
- public void testAddWorkLog() throws InterruptedException {
- int minutesSpent = 10;
- Map<String, Object> headers = new HashMap<>();
- headers.put(ISSUE_KEY, backendIssue.getKey());
- headers.put(MINUTES_SPENT, minutesSpent);
- String comment = "A new test comment " + new Date();
- when(issueRestClient.addWorklog(any(URI.class), any(WorklogInput.class)))
- .then((Answer<Void>) inv -> {
- Collection<Worklog> workLogs = new ArrayList<>();
- workLogs.add(newWorkLog(backendIssue.getId(), minutesSpent, comment));
- backendIssue = createIssueWithWorkLogs(backendIssue.getId(), workLogs);
- return null;
- });
- template.sendBodyAndHeaders(comment, headers);
- mockResult.expectedMessageCount(1);
- mockResult.assertIsSatisfied();
- verify(issueRestClient).getIssue(backendIssue.getKey());
- verify(issueRestClient).addWorklog(eq(backendIssue.getWorklogUri()), any(WorklogInput.class));
- }
- @Test
- public void testAddWorkLogMissingIssueKey() throws InterruptedException {
- int minutesSpent = 3;
- Map<String, Object> headers = new HashMap<>();
- headers.put(MINUTES_SPENT, minutesSpent);
- String comment = "A new test comment " + new Date();
- try {
- template.sendBodyAndHeaders(comment, headers);
- fail("Should have thrown an exception");
- } catch (CamelExecutionException e) {
- IllegalArgumentException cause = assertIsInstanceOf(IllegalArgumentException.class, e.getCause());
- assertStringContains(cause.getMessage(), ISSUE_KEY);
- }
- mockResult.expectedMessageCount(0);
- mockResult.assertIsSatisfied();
- verify(issueRestClient, never()).getIssue(any(String.class));
- verify(issueRestClient, never()).addWorklog(any(URI.class), any(WorklogInput.class));
- }
- @Test
- public void testAddWorkLogMissingMinutesSpent() throws InterruptedException {
- Map<String, Object> headers = new HashMap<>();
- headers.put(ISSUE_KEY, backendIssue.getKey());
- String comment = "A new test comment " + new Date();
- try {
- template.sendBodyAndHeaders(comment, headers);
- fail("Should have thrown an exception");
- } catch (CamelExecutionException e) {
- IllegalArgumentException cause = assertIsInstanceOf(IllegalArgumentException.class, e.getCause());
- assertStringContains(cause.getMessage(), MINUTES_SPENT);
- }
- mockResult.expectedMessageCount(0);
- mockResult.assertIsSatisfied();
- verify(issueRestClient, never()).getIssue(any(String.class));
- verify(issueRestClient, never()).addWorklog(any(URI.class), any(WorklogInput.class));
- }
- @Test
- public void testAddWorkLogMissingComment() throws InterruptedException {
- int minutesSpent = 60;
- Map<String, Object> headers = new HashMap<>();
- headers.put(ISSUE_KEY, backendIssue.getKey());
- headers.put(MINUTES_SPENT, minutesSpent);
- try {
- template.sendBodyAndHeaders(null, headers);
- fail("Should have thrown an exception");
- } catch (CamelExecutionException e) {
- IllegalArgumentException cause = assertIsInstanceOf(IllegalArgumentException.class, e.getCause());
- assertStringContains(cause.getMessage(), "Missing exchange body");
- }
- mockResult.expectedMessageCount(0);
- mockResult.assertIsSatisfied();
- verify(issueRestClient, never()).getIssue(any(String.class));
- verify(issueRestClient, never()).addWorklog(any(URI.class), any(WorklogInput.class));
- }
- }