package org.apereo.cas.support.rest;
import org.apache.commons.lang3.StringUtils;
import org.apereo.cas.CentralAuthenticationService;
import org.apereo.cas.authentication.CoreAuthenticationTestUtils;
import org.apereo.cas.services.RegisteredService;
import org.apereo.cas.services.RegisteredServiceTestUtils;
import org.apereo.cas.services.ServicesManager;
import org.apereo.cas.ticket.TicketGrantingTicket;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnitRunner;
import org.springframework.http.MediaType;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import java.util.HashMap;
import static org.mockito.Mockito.*;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
/**
* Unit tests for {@link RegisteredServiceResource}.
*
* @author Dmitriy Kopylenko
* @since 4.0.0
*/
@RunWith(MockitoJUnitRunner.Silent.class)
public class RegisteredServiceResourceTests {
private static final String SERVICE_ID = "serviceId";
private static final String NAME = "name";
private static final String DESCRIPTION = "description";
@Mock
private CentralAuthenticationService casMock;
@Mock
private ServicesManager servicesManager;
@Test
public void checkRegisteredServiceNotAuthorized() throws Exception {
configureCasMockToCreateValidTGT();
final RegisteredServiceResource registeredServiceResource = new RegisteredServiceResource(servicesManager, casMock, "memberOf", "staff");
configureMockMvcFor(registeredServiceResource)
.perform(post("/cas/v1/services/add/TGT-1")
.param(SERVICE_ID, SERVICE_ID)
.param(NAME, NAME)
.param(DESCRIPTION, DESCRIPTION)
.param("evaluationOrder", "1000")
.param("enabled", "false")
.param("ssoEnabled", "true"))
.andExpect(status().isBadRequest());
}
@Test
public void checkRegisteredServiceNormal() throws Exception {
configureCasMockToCreateValidTGT();
final RegisteredServiceResource registeredServiceResource = new RegisteredServiceResource(servicesManager, casMock, "memberOf", "cas");
configureMockMvcFor(registeredServiceResource)
.perform(post("/cas/v1/services/add/TGT-1")
.param(SERVICE_ID, SERVICE_ID)
.param(NAME, NAME)
.param(DESCRIPTION, DESCRIPTION)
.param("evaluationOrder", "1000")
.param("enabled", "false")
.param("ssoEnabled", "true"))
.andExpect(status().isOk());
}
@Test
public void checkRegisteredServiceNoTgt() throws Exception {
final RegisteredServiceResource registeredServiceResource = new RegisteredServiceResource(servicesManager, casMock, "memberOf", "staff");
configureMockMvcFor(registeredServiceResource)
.perform(post("/cas/v1/services/add/TGT-1")
.param(SERVICE_ID, SERVICE_ID)
.param(NAME, NAME)
.param(DESCRIPTION, DESCRIPTION)
.param("evaluationOrder", "1000")
.param("enabled", "false")
.param("ssoEnabled", "true"))
.andExpect(status().isNotFound());
}
@Test
public void checkRegisteredServiceNoAttributeValue() throws Exception {
final RegisteredServiceResource registeredServiceResource = new RegisteredServiceResource(servicesManager, casMock, "Test", StringUtils.EMPTY);
configureMockMvcFor(registeredServiceResource)
.perform(post("/cas/v1/services/add/TGT-12345"))
.andExpect(status().isBadRequest());
}
@Test
public void checkRegisteredServiceNoAttributeName() throws Exception {
final RegisteredServiceResource registeredServiceResource = new RegisteredServiceResource(servicesManager, casMock, null, "staff");
configureMockMvcFor(registeredServiceResource)
.perform(post("/cas/v1/services/add/TGT-12345"))
.andExpect(status().isBadRequest());
}
@Test
public void checkRegisteredServiceNoAttributes() throws Exception {
configureMockMvcFor(new RegisteredServiceResource(servicesManager, casMock, null, null))
.perform(post("/cas/v1/services/add/TGT-12345"))
.andExpect(status().isBadRequest());
}
private void configureCasMockToCreateValidTGT() throws Exception {
final TicketGrantingTicket tgt = mock(TicketGrantingTicket.class);
when(tgt.getId()).thenReturn("TGT-1");
when(tgt.getAuthentication()).thenReturn(CoreAuthenticationTestUtils.getAuthentication(
CoreAuthenticationTestUtils.getPrincipal("casuser",
new HashMap<>(RegisteredServiceTestUtils.getTestAttributes()))));
final Class<TicketGrantingTicket> clazz = TicketGrantingTicket.class;
when(this.casMock.getTicket(anyString(), any(clazz.getClass()))).thenReturn(tgt);
when(this.servicesManager.save(any(RegisteredService.class))).thenReturn(
RegisteredServiceTestUtils.getRegisteredService("TEST"));
}
private MockMvc configureMockMvcFor(final RegisteredServiceResource registeredServiceResource) {
return MockMvcBuilders.standaloneSetup(registeredServiceResource)
.defaultRequest(get("/")
.contextPath("/cas")
.contentType(MediaType.APPLICATION_FORM_URLENCODED))
.build();
}
}