203 lines
8.2 KiB
Java
203 lines
8.2 KiB
Java
package com.mattrixwv.cipherstream.controller.polysubstitution;
|
|
|
|
|
|
import static org.hamcrest.Matchers.*;
|
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*;
|
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*;
|
|
|
|
import java.util.List;
|
|
|
|
import org.junit.jupiter.api.BeforeEach;
|
|
import org.junit.jupiter.api.Tag;
|
|
import org.junit.jupiter.api.Test;
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
import org.springframework.boot.webmvc.test.autoconfigure.WebMvcTest;
|
|
import org.springframework.http.MediaType;
|
|
import org.springframework.test.util.ReflectionTestUtils;
|
|
import org.springframework.test.web.servlet.MockMvc;
|
|
|
|
import com.mattrixwv.cipherstream.controller.CipherStreamControllerIntegrationTestBase;
|
|
import com.mattrixwv.cipherstream.utils.CipherInfoUtil;
|
|
import com.mattrixwv.cipherstream.utils.CipherParameterUtil;
|
|
|
|
import tools.jackson.databind.node.ObjectNode;
|
|
|
|
|
|
@Tag("integration-test")
|
|
@WebMvcTest(controllers = TrifidCipherController.class)
|
|
public class TrifidCipherControllerIntegrationTest extends CipherStreamControllerIntegrationTestBase{
|
|
@Autowired
|
|
private MockMvc mockMvc;
|
|
@Autowired
|
|
private TrifidCipherController trifidCipherController;
|
|
//TODO: Fix logger testing
|
|
//Loggers
|
|
//@Mock(name = "com.mattrixwv.cipherstream.controller.polysubstitution.TrifidCipherController")
|
|
//protected Logger trifidLogger;
|
|
//Fields
|
|
private static final ObjectNode blankNode = mapper.createObjectNode();
|
|
private static final String url = "/trifid";
|
|
private static final String decodedString = "Message to^encode+";
|
|
private static final String encodedString = "Gqdokpd od^ljvflf+";
|
|
private static final String keyword = "keyword";
|
|
private static final String trifidFill = "=";
|
|
private static final int grouplength = Integer.MAX_VALUE;
|
|
private static final String trifidName = "trifidName";
|
|
private static final String trifidDescription = "trifidDescription";
|
|
private static final List<String> trifidExplanation = List.of("trifidExplanation1", "trifidExplanation2", "trifidExplanation3");
|
|
private static final List<String> trifidFacts = List.of("trifidFact1", "trifidFact2", "trifidFact3");
|
|
|
|
|
|
@BeforeEach
|
|
public void setup(){
|
|
decodedNode = mapper.createObjectNode();
|
|
decodedNode.put(CipherParameterUtil.PRESERVE_CAPITALS, true);
|
|
decodedNode.put(CipherParameterUtil.PRESERVE_WHITESPACE, true);
|
|
decodedNode.put(CipherParameterUtil.PRESERVE_SYMBOLS, true);
|
|
decodedNode.put(CipherParameterUtil.KEYWORD, keyword);
|
|
decodedNode.put(CipherParameterUtil.TRIFID_FILL, trifidFill);
|
|
decodedNode.put(CipherParameterUtil.TRIFID_GROUP_LENGTH, grouplength);
|
|
decodedNode.put(CipherParameterUtil.INPUT_STRING, decodedString);
|
|
decodedNode.put(CipherParameterUtil.OUTPUT_STRING, encodedString);
|
|
|
|
encodedNode = mapper.createObjectNode();
|
|
encodedNode.put(CipherParameterUtil.PRESERVE_CAPITALS, true);
|
|
encodedNode.put(CipherParameterUtil.PRESERVE_WHITESPACE, true);
|
|
encodedNode.put(CipherParameterUtil.PRESERVE_SYMBOLS, true);
|
|
encodedNode.put(CipherParameterUtil.KEYWORD, keyword);
|
|
encodedNode.put(CipherParameterUtil.TRIFID_FILL, trifidFill);
|
|
encodedNode.put(CipherParameterUtil.TRIFID_GROUP_LENGTH, grouplength);
|
|
encodedNode.put(CipherParameterUtil.INPUT_STRING, encodedString);
|
|
encodedNode.put(CipherParameterUtil.OUTPUT_STRING, decodedString);
|
|
|
|
ReflectionTestUtils.setField(trifidCipherController, "trifidName", trifidName);
|
|
ReflectionTestUtils.setField(trifidCipherController, "trifidDescription", trifidDescription);
|
|
ReflectionTestUtils.setField(trifidCipherController, "trifidExplanation", trifidExplanation);
|
|
ReflectionTestUtils.setField(trifidCipherController, "trifidFacts", trifidFacts);
|
|
}
|
|
|
|
|
|
@Test
|
|
public void testGetCipherInfo() throws Exception{
|
|
mockMvc.perform(get(url)
|
|
.header("X-Request-Id", requestId)
|
|
.header("X-Forwarded-For", ipAddress))
|
|
.andExpect(status().isOk())
|
|
.andExpect(content().contentTypeCompatibleWith(MediaType.APPLICATION_JSON))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_NAME).value(trifidName))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_DESCRIPTION).value(trifidDescription))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_EXPLANATION).isArray())
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_EXPLANATION, hasSize(trifidExplanation.size())))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_EXPLANATION, hasItems(trifidExplanation.get(0), trifidExplanation.get(1), trifidExplanation.get(2))))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_FACTS).isArray())
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_FACTS, hasSize(trifidFacts.size())))
|
|
.andExpect(jsonPath(CipherInfoUtil.CIPHER_FACTS, hasItems(trifidFacts.get(0), trifidFacts.get(1), trifidFacts.get(2))));
|
|
|
|
//Filter
|
|
//TODO: Fix logger testing
|
|
/*
|
|
super.verifyFilter(url);
|
|
//Controller
|
|
verify(trifidLogger, times(1)).info("Getting info for {}", trifidName);
|
|
verifyNoMoreInteractions(trifidLogger);
|
|
verify(mdc, times(1)).put(CipherStreamLoggingAspect.CIPHER_NAME_LOGGING, trifidName);
|
|
*/
|
|
}
|
|
|
|
@Test
|
|
public void testEncodeTrifid() throws Exception{
|
|
mockMvc.perform(post(url + "/encode")
|
|
.header("X-Request-Id", requestId)
|
|
.header("X-Forwarded-For", ipAddress)
|
|
.contentType(MediaType.APPLICATION_JSON)
|
|
.content(decodedNode.toString()))
|
|
.andExpect(status().isOk())
|
|
.andExpect(content().contentTypeCompatibleWith(MediaType.APPLICATION_JSON))
|
|
.andExpect(jsonPath(CipherParameterUtil.OUTPUT_STRING).value(encodedString));
|
|
|
|
//Filter
|
|
//TODO: Fix logger testing
|
|
/*
|
|
super.verifyFilter(url + "/encode");
|
|
//Controller
|
|
verify(trifidLogger, times(1)).info("Encoding {}", trifidName);
|
|
verifyNoMoreInteractions(trifidLogger);
|
|
verify(mdc, times(1)).put(CipherStreamLoggingAspect.CIPHER_NAME_LOGGING, trifidName);
|
|
//Cipher Aspect
|
|
verifyAspectLogging(decodedNode);
|
|
*/
|
|
}
|
|
|
|
@Test
|
|
public void testEncodetrifid_error() throws Exception{
|
|
mockMvc.perform(post(url + "/encode")
|
|
.header("X-Request-Id", requestId)
|
|
.header("X-Forwarded-For", ipAddress)
|
|
.contentType(MediaType.APPLICATION_JSON)
|
|
.content(blankNode.toString()))
|
|
.andExpect(status().isBadRequest())
|
|
.andExpect(content().contentTypeCompatibleWith(MediaType.APPLICATION_JSON))
|
|
.andExpect(jsonPath("message").value(CipherParameterUtil.PRESERVE_CAPITALS + CipherParameterUtil.PRESENT_MESSAGE));
|
|
|
|
//Filter
|
|
//TODO: Fix logger testing
|
|
/*
|
|
super.verifyFilter(url + "/encode");
|
|
//Controller
|
|
verify(trifidLogger, times(1)).info("Encoding {}", trifidName);
|
|
verifyNoMoreInteractions(trifidLogger);
|
|
verify(mdc, times(1)).put(CipherStreamLoggingAspect.CIPHER_NAME_LOGGING, trifidName);
|
|
//Cipher Aspect
|
|
verifyNoInteractions(aspectLogger);
|
|
*/
|
|
}
|
|
|
|
@Test
|
|
public void testDecodeTrifid() throws Exception{
|
|
mockMvc.perform(post(url + "/decode")
|
|
.header("X-Request-Id", requestId)
|
|
.header("X-Forwarded-For", ipAddress)
|
|
.contentType(MediaType.APPLICATION_JSON)
|
|
.content(encodedNode.toString()))
|
|
.andExpect(status().isOk())
|
|
.andExpect(content().contentTypeCompatibleWith(MediaType.APPLICATION_JSON))
|
|
.andExpect(jsonPath(CipherParameterUtil.OUTPUT_STRING).value(decodedString));
|
|
|
|
//Filter
|
|
//TODO: Fix logger testing
|
|
/*
|
|
super.verifyFilter(url + "/decode");
|
|
//Controller
|
|
verify(trifidLogger, times(1)).info("Decoding {}", trifidName);
|
|
verifyNoMoreInteractions(trifidLogger);
|
|
verify(mdc, times(1)).put(CipherStreamLoggingAspect.CIPHER_NAME_LOGGING, trifidName);
|
|
//Cipher Aspect
|
|
verifyAspectLogging(encodedNode);
|
|
*/
|
|
}
|
|
|
|
@Test
|
|
public void testDecodetrifid_error() throws Exception{
|
|
mockMvc.perform(post(url + "/decode")
|
|
.header("X-Request-Id", requestId)
|
|
.header("X-Forwarded-For", ipAddress)
|
|
.contentType(MediaType.APPLICATION_JSON)
|
|
.content(blankNode.toString()))
|
|
.andExpect(status().isBadRequest())
|
|
.andExpect(content().contentTypeCompatibleWith(MediaType.APPLICATION_JSON))
|
|
.andExpect(jsonPath("message").value(CipherParameterUtil.PRESERVE_CAPITALS + CipherParameterUtil.PRESENT_MESSAGE));
|
|
|
|
//Filter
|
|
//TODO: Fix logger testing
|
|
/*
|
|
super.verifyFilter(url + "/decode");
|
|
//Controller
|
|
verify(trifidLogger, times(1)).info("Decoding {}", trifidName);
|
|
verifyNoMoreInteractions(trifidLogger);
|
|
verify(mdc, times(1)).put(CipherStreamLoggingAspect.CIPHER_NAME_LOGGING, trifidName);
|
|
//Cipher Aspect
|
|
verifyNoInteractions(aspectLogger);
|
|
*/
|
|
}
|
|
}
|