blob: a325751d8d2cbd17a52f082d5b6da5f048db2814 [file] [log] [blame]
/*
* 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.metron.rest.service.impl;
import org.apache.metron.common.configuration.SensorParserGroup;
import org.apache.metron.rest.model.TopologyResponse;
import org.apache.metron.rest.model.TopologyStatus;
import org.apache.metron.rest.model.TopologyStatusCode;
import org.apache.metron.rest.model.TopologySummary;
import org.apache.metron.rest.service.SensorParserGroupService;
import org.apache.metron.rest.service.StormStatusService;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.springframework.core.env.Environment;
import org.springframework.web.client.RestTemplate;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import static org.apache.metron.rest.MetronRestConstants.*;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
@SuppressWarnings("ALL")
public class StormStatusServiceImplTest {
private static final String HTTP_STORM_UI = "http://storm_ui";
private static final String HTTPS_STORM_UI = "https://storm_ui";
private static final String NO_PROTOCOL_STORM_UI = "storm_ui";
Environment environment;
RestTemplate restTemplate;
StormStatusService stormStatusService;
SensorParserGroupService sensorParserGroupService;
@BeforeEach
public void setUp() throws Exception {
environment = mock(Environment.class);
restTemplate = mock(RestTemplate.class);
sensorParserGroupService = mock(SensorParserGroupService.class);
stormStatusService = new StormStatusServiceImpl(environment, restTemplate, sensorParserGroupService);
}
@Test
public void testgetStormUiPropertyHttp() {
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
StormStatusServiceImpl serviceImpl = (StormStatusServiceImpl) stormStatusService;
assertEquals(HTTP_STORM_UI, serviceImpl.getStormUiProperty());
}
@Test
public void testgetStormUiPropertyHttps() {
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTPS_STORM_UI);
StormStatusServiceImpl serviceImpl = (StormStatusServiceImpl) stormStatusService;
assertEquals(HTTPS_STORM_UI, serviceImpl.getStormUiProperty());
}
@Test
public void testgetStormUiPropertyNoProtocol() {
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(NO_PROTOCOL_STORM_UI);
StormStatusServiceImpl serviceImpl = (StormStatusServiceImpl) stormStatusService;
assertEquals(HTTP_STORM_UI, serviceImpl.getStormUiProperty());
}
@Test
public void getTopologySummaryShouldReturnTopologySummary() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setStatus(TopologyStatusCode.STARTED);
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
TopologyStatus expectedStatus = new TopologyStatus();
expectedStatus.setStatus(TopologyStatusCode.STARTED);
expectedStatus.setName("bro");
expectedStatus.setId("bro_id");
TopologySummary expected = new TopologySummary();
expected.setTopologies(new TopologyStatus[]{expectedStatus});
TopologySummary actual = stormStatusService.getTopologySummary();
assertEquals(expected, actual);
assertEquals(expected.hashCode(), actual.hashCode());
}
@Test
public void getTopologyStatusShouldReturnTopologyStatus() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setStatus(TopologyStatusCode.STARTED);
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id", TopologyStatus.class)).thenReturn(topologyStatus);
TopologyStatus expected = new TopologyStatus();
expected.setStatus(TopologyStatusCode.STARTED);
expected.setName("bro");
expected.setId("bro_id");
TopologyStatus actual = stormStatusService.getTopologyStatus("bro");
assertEquals(expected, actual);
assertEquals(expected.hashCode(), actual.hashCode());
}
@Test
public void getTopologyStatusByGroupShouldReturnTopologyStatus() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setStatus(TopologyStatusCode.STARTED);
topologyStatus.setName("bro__snort");
topologyStatus.setId("bro_snort_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
SensorParserGroup group = new SensorParserGroup();
group.setName("group");
group.setSensors(new HashSet<String>() {{
add("bro");
add("snort");
}});
when(sensorParserGroupService.findOne("group")).thenReturn(group);
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_snort_id", TopologyStatus.class)).thenReturn(topologyStatus);
TopologyStatus expected = new TopologyStatus();
expected.setStatus(TopologyStatusCode.STARTED);
expected.setName("bro__snort");
expected.setId("bro_snort_id");
TopologyStatus actual = stormStatusService.getTopologyStatus("group");
assertEquals(expected, actual);
assertEquals(expected.hashCode(), actual.hashCode());
}
@Test
public void getAllTopologyStatusShouldReturnAllTopologyStatus() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setStatus(TopologyStatusCode.STARTED);
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id", TopologyStatus.class)).thenReturn(topologyStatus);
TopologyStatus expected = new TopologyStatus();
expected.setStatus(TopologyStatusCode.STARTED);
expected.setName("bro");
expected.setId("bro_id");
assertEquals(new ArrayList() {{ add(expected); }}, stormStatusService.getAllTopologyStatus());
}
@Test
public void activateTopologyShouldReturnActiveTopologyResponse() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.postForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id/activate", null, Map.class))
.thenReturn(new HashMap() {{ put("status", "success"); }});
TopologyResponse expected = new TopologyResponse();
expected.setSuccessMessage(TopologyStatusCode.ACTIVE.toString());
assertEquals(expected, stormStatusService.activateTopology("bro"));
}
@Test
public void activateTopologyShouldReturnErrorTopologyResponse() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.postForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id/activate", null, Map.class))
.thenReturn(new HashMap() {{ put("status", "error message"); }});
TopologyResponse expected = new TopologyResponse();
expected.setErrorMessage("error message");
assertEquals(expected, stormStatusService.activateTopology("bro"));
}
@Test
public void activateTopologyShouldReturnTopologyNotFoundTopologyResponse() throws Exception {
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(new TopologySummary());
TopologyResponse expected = new TopologyResponse();
expected.setErrorMessage(TopologyStatusCode.TOPOLOGY_NOT_FOUND.toString());
assertEquals(expected, stormStatusService.activateTopology("bro"));
}
@Test
public void deactivateTopologyShouldReturnActiveTopologyResponse() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.postForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id/deactivate", null, Map.class))
.thenReturn(new HashMap() {{ put("status", "success"); }});
TopologyResponse expected = new TopologyResponse();
expected.setSuccessMessage(TopologyStatusCode.INACTIVE.toString());
assertEquals(expected, stormStatusService.deactivateTopology("bro"));
}
@Test
public void deactivateTopologyShouldReturnErrorTopologyResponse() throws Exception {
final TopologyStatus topologyStatus = new TopologyStatus();
topologyStatus.setName("bro");
topologyStatus.setId("bro_id");
final TopologySummary topologySummary = new TopologySummary();
topologySummary.setTopologies(new TopologyStatus[]{topologyStatus});
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(topologySummary);
when(restTemplate.postForObject(HTTP_STORM_UI + TOPOLOGY_URL + "/bro_id/deactivate", null, Map.class))
.thenReturn(new HashMap() {{ put("status", "error message"); }});
TopologyResponse expected = new TopologyResponse();
expected.setErrorMessage("error message");
assertEquals(expected, stormStatusService.deactivateTopology("bro"));
}
@Test
public void deactivateTopologyShouldReturnTopologyNotFoundTopologyResponse() throws Exception {
when(environment.getProperty(STORM_UI_SPRING_PROPERTY)).thenReturn(HTTP_STORM_UI);
when(restTemplate.getForObject(HTTP_STORM_UI + TOPOLOGY_SUMMARY_URL, TopologySummary.class)).thenReturn(new TopologySummary());
TopologyResponse expected = new TopologyResponse();
expected.setErrorMessage(TopologyStatusCode.TOPOLOGY_NOT_FOUND.toString());
assertEquals(expected, stormStatusService.deactivateTopology("bro"));
}
}