PAN-11 wrote the GetAllDefinitions() method
This commit is contained in:
@@ -34,17 +34,16 @@ referenced_theorems json,
|
|||||||
proven_status boolean default false,
|
proven_status boolean default false,
|
||||||
version int default 1
|
version int default 1
|
||||||
);
|
);
|
||||||
CREATE TABLE proofs
|
create table proofs
|
||||||
(
|
(
|
||||||
id INT NOT NULL AUTO_INCREMENT,
|
id int not null auto_increment primary key unique,
|
||||||
theorem_name VARCHAR(512) NOT NULL,
|
theorem_name varchar(512) not null,
|
||||||
proof VARCHAR(4096) NOT NULL,
|
proof varchar(4096) not null,
|
||||||
branch VARCHAR(512) NOT NULL,
|
branch varchar(512) not null,
|
||||||
theorem INT NOT NULL,
|
theorem int not null,
|
||||||
referenced_definitions JSON,
|
referenced_definitions json,
|
||||||
referenced_theorems JSON,
|
referenced_theorems json,
|
||||||
date_added DATE,
|
date_added date,
|
||||||
last_updated DATE,
|
last_updated date,
|
||||||
version INT DEFAULT 1,
|
version int default 1
|
||||||
PRIMARY KEY (id)
|
|
||||||
);
|
);
|
||||||
+1
-2
@@ -18,8 +18,7 @@ import static org.junit.Assert.*;
|
|||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
@ContextConfiguration(classes = PersistenceTestConfig.class)
|
@ContextConfiguration(classes = PersistenceTestConfig.class)
|
||||||
public class ProofsIntegrationTest {
|
public class ProofsIntegrationTest {
|
||||||
@Autowired
|
@Autowired private ProofRepository proofRepository;
|
||||||
private ProofRepository proofRepository;
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCRUDFunctionality() {
|
public void testCRUDFunctionality() {
|
||||||
|
|||||||
+4
-4
@@ -6,7 +6,7 @@ import org.junit.runner.RunWith;
|
|||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
import org.springframework.test.context.TestPropertySource;
|
import org.springframework.test.context.TestPropertySource;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -16,16 +16,16 @@ import static org.hamcrest.CoreMatchers.is;
|
|||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
import static org.mockito.AdditionalMatchers.not;
|
import static org.mockito.AdditionalMatchers.not;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
@ContextConfiguration(classes = ServiceTestConfig.class)
|
@ContextConfiguration(classes = ServiceTestConfig.class)
|
||||||
@TestPropertySource(locations = "classpath:test.properties")
|
@TestPropertySource(locations = "classpath:test.properties")
|
||||||
public class DefinitionServiceIntegrationTest {
|
public class DefinitionServiceIntegrationTest {
|
||||||
@Autowired private DefinitionService definitionService;
|
@Autowired private DefinitionService definitionService;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateNewDefinition() {
|
public void testCreateDefinition() {
|
||||||
final Definition testDefinition = createDefinition();
|
final Definition testDefinition = createDefinition();
|
||||||
final Optional<Definition> createdDefinition = definitionService.createNewDefinition(testDefinition);
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
assertNotNull(createdDefinition);
|
assertNotNull(createdDefinition);
|
||||||
assertTrue(createdDefinition.isPresent());
|
assertTrue(createdDefinition.isPresent());
|
||||||
|
|||||||
@@ -1,20 +1,17 @@
|
|||||||
package edu.msudenver.tsp.services;
|
package edu.msudenver.tsp.services;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.CommandLineRunner;
|
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.ComponentScan;
|
import org.springframework.context.annotation.ComponentScan;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.context.annotation.FilterType;
|
|
||||||
|
|
||||||
@Configuration
|
@Configuration
|
||||||
@ComponentScan(excludeFilters = @ComponentScan.Filter(type = FilterType.ASSIGNABLE_TYPE, value = CommandLineRunner.class))
|
@ComponentScan
|
||||||
@EnableAutoConfiguration
|
|
||||||
public class ServiceTestConfig {
|
public class ServiceTestConfig {
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
@Autowired public DefinitionService definitionService(final RestService restService) {
|
@Autowired
|
||||||
|
public DefinitionService definitionService(final RestService restService) {
|
||||||
return new DefinitionService(restService);
|
return new DefinitionService(restService);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ import org.springframework.stereotype.Service;
|
|||||||
|
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@@ -25,25 +26,51 @@ public class DefinitionService {
|
|||||||
this.restService = restService;
|
this.restService = restService;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Optional<Definition> createNewDefinition(final Definition definition) {
|
public Optional<List<Definition>> getAllDefinitions() {
|
||||||
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
|
try {
|
||||||
|
final TypeToken<List<Definition>> typeToken = new TypeToken<List<Definition>>(){};
|
||||||
|
final Optional<List<Definition>> persistenceApiResponse =
|
||||||
|
restService.get(persistenceApiBaseUrl + "definitions/",
|
||||||
|
typeToken, connectionTimeoutMilliseconds, socketTimeoutMilliseconds, null);
|
||||||
|
|
||||||
|
if (persistenceApiResponse.isPresent()) {
|
||||||
|
LOG.info("Returning {}", persistenceApiResponse.get());
|
||||||
|
} else {
|
||||||
|
LOG.info("Unable to get list of definitions");
|
||||||
|
}
|
||||||
|
|
||||||
|
return persistenceApiResponse;
|
||||||
|
} catch (final Exception e) {
|
||||||
|
LOG.error("Error getting list of definitions! {}", e);
|
||||||
|
return Optional.empty();
|
||||||
|
} finally {
|
||||||
|
LOG.info("Get all definitions request took {}ms", Duration.between(start, Instant.now()).toMillis());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<Definition> createDefinition(final Definition definition) {
|
||||||
if (definition == null) {
|
if (definition == null) {
|
||||||
LOG.error("Given null definition, returning {}");
|
LOG.error("Given null definition, returning {}");
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
LOG.info("Sending request to insert definition {}", definition);
|
||||||
final Instant start = Instant.now();
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
final TypeToken<Definition> definitionTypeToken = new TypeToken<Definition>() {};
|
final TypeToken<Definition> definitionTypeToken = new TypeToken<Definition>() {};
|
||||||
final Optional<Definition> persistenceApiResponse = restService.post(persistenceApiBaseUrl + "/",
|
final Optional<Definition> persistenceApiResponse = restService.post(persistenceApiBaseUrl + "definitions/",
|
||||||
new GsonBuilder().create().toJson(definition),
|
new GsonBuilder().create().toJson(definition),
|
||||||
definitionTypeToken,
|
definitionTypeToken,
|
||||||
connectionTimeoutMilliseconds,
|
connectionTimeoutMilliseconds,
|
||||||
socketTimeoutMilliseconds);
|
socketTimeoutMilliseconds);
|
||||||
|
|
||||||
if(persistenceApiResponse.isPresent()) {
|
if (persistenceApiResponse.isPresent()) {
|
||||||
LOG.info("Returning {}", persistenceApiResponse.get());
|
LOG.info("Returning {}", persistenceApiResponse.get());
|
||||||
} else {
|
} else {
|
||||||
LOG.info("Unable to create new definition {}", definition.toString());
|
LOG.info("Unable to create new definition {}", definition);
|
||||||
}
|
}
|
||||||
|
|
||||||
return persistenceApiResponse;
|
return persistenceApiResponse;
|
||||||
|
|||||||
@@ -24,14 +24,14 @@ public class DefinitionServiceTest {
|
|||||||
@InjectMocks private DefinitionService definitionService;
|
@InjectMocks private DefinitionService definitionService;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateNewDefinition() {
|
public void testCreateDefinition() {
|
||||||
final Definition testDefinition = createDefinition();
|
final Definition testDefinition = createDefinition();
|
||||||
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
.thenReturn(Optional.of(testDefinition));
|
.thenReturn(Optional.of(testDefinition));
|
||||||
|
|
||||||
final Optional<Definition> createdDefinition = definitionService.createNewDefinition(testDefinition);
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
assertNotNull(createdDefinition);
|
assertNotNull(createdDefinition);
|
||||||
assertTrue(createdDefinition.isPresent());
|
assertTrue(createdDefinition.isPresent());
|
||||||
@@ -40,14 +40,14 @@ public class DefinitionServiceTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateNewDefinition_unableToCreateNewDefinition() {
|
public void testCreateDefinition_unableToCreateDefinition() {
|
||||||
final Definition testDefinition = createDefinition();
|
final Definition testDefinition = createDefinition();
|
||||||
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
.thenReturn(Optional.empty());
|
.thenReturn(Optional.empty());
|
||||||
|
|
||||||
final Optional<Definition> createdDefinition = definitionService.createNewDefinition(testDefinition);
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
assertNotNull(createdDefinition);
|
assertNotNull(createdDefinition);
|
||||||
assertFalse(createdDefinition.isPresent());
|
assertFalse(createdDefinition.isPresent());
|
||||||
@@ -55,14 +55,14 @@ public class DefinitionServiceTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateNewDefinition_restServiceThrowsException() {
|
public void testCreateDefinition_restServiceThrowsException() {
|
||||||
final Definition testDefinition = createDefinition();
|
final Definition testDefinition = createDefinition();
|
||||||
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
.thenThrow(new UnsupportedOperationException("test exception"));
|
.thenThrow(new UnsupportedOperationException("test exception"));
|
||||||
|
|
||||||
final Optional<Definition> createdDefinition = definitionService.createNewDefinition(testDefinition);
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
assertNotNull(createdDefinition);
|
assertNotNull(createdDefinition);
|
||||||
assertFalse(createdDefinition.isPresent());
|
assertFalse(createdDefinition.isPresent());
|
||||||
|
|||||||
Reference in New Issue
Block a user