Merge branch 'master' into PAN-46
This commit is contained in:
@@ -5,11 +5,11 @@ create table accounts (
|
|||||||
id int not null auto_increment primary key unique,
|
id int not null auto_increment primary key unique,
|
||||||
username varchar(50) not null unique,
|
username varchar(50) not null unique,
|
||||||
password varchar(256) not null,
|
password varchar(256) not null,
|
||||||
administrator_status boolean default false,
|
administrator boolean default false,
|
||||||
last_login date,
|
last_login date,
|
||||||
version int default 1
|
version int default 1
|
||||||
);
|
);
|
||||||
insert into accounts (username, password, administrator_status)
|
insert into accounts (username, password, administrator)
|
||||||
values ('admin', 'secret', true),
|
values ('admin', 'secret', true),
|
||||||
('atusa', 'secret', true),
|
('atusa', 'secret', true),
|
||||||
('dantanxiaotian', 'secret', true),
|
('dantanxiaotian', 'secret', true),
|
||||||
@@ -34,17 +34,17 @@ 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,
|
||||||
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)
|
primary key (id)
|
||||||
);
|
);
|
||||||
+3
-3
@@ -29,7 +29,7 @@ public class AccountsIntegrationTest {
|
|||||||
|
|
||||||
assertEquals("Test username", savedAccount.getUsername());
|
assertEquals("Test username", savedAccount.getUsername());
|
||||||
assertEquals("test password", savedAccount.getPassword());
|
assertEquals("test password", savedAccount.getPassword());
|
||||||
assertTrue(savedAccount.getAdministratorStatus());
|
assertTrue(savedAccount.isAdministrator());
|
||||||
|
|
||||||
savedAccount.setPassword("Test Update");
|
savedAccount.setPassword("Test Update");
|
||||||
|
|
||||||
@@ -37,7 +37,7 @@ public class AccountsIntegrationTest {
|
|||||||
|
|
||||||
assertEquals("Test username", savedAccount.getUsername());
|
assertEquals("Test username", savedAccount.getUsername());
|
||||||
assertEquals("Test Update", savedAccount.getPassword());
|
assertEquals("Test Update", savedAccount.getPassword());
|
||||||
assertTrue(savedAccount.getAdministratorStatus());
|
assertTrue(savedAccount.isAdministrator());
|
||||||
assertEquals(updatedAccount.getId(), id);
|
assertEquals(updatedAccount.getId(), id);
|
||||||
|
|
||||||
accountsRepository.delete(account);
|
accountsRepository.delete(account);
|
||||||
@@ -49,7 +49,7 @@ public class AccountsIntegrationTest {
|
|||||||
final Account account = new Account();
|
final Account account = new Account();
|
||||||
account.setUsername("Test username");
|
account.setUsername("Test username");
|
||||||
account.setPassword("test password");
|
account.setPassword("test password");
|
||||||
account.setAdministratorStatus(true);
|
account.setAdministrator(true);
|
||||||
|
|
||||||
return account;
|
return account;
|
||||||
}
|
}
|
||||||
|
|||||||
+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() {
|
||||||
|
|||||||
@@ -19,21 +19,11 @@ import java.util.Date;
|
|||||||
public class Account extends BaseDto implements Serializable {
|
public class Account extends BaseDto implements Serializable {
|
||||||
@NotBlank(groups = Insert.class, message = "A username must be specified") @Size(max = 50) private String username;
|
@NotBlank(groups = Insert.class, message = "A username must be specified") @Size(max = 50) private String username;
|
||||||
@NotBlank(groups = Insert.class, message = "A password must be specified") @Size(max = 256) private String password;
|
@NotBlank(groups = Insert.class, message = "A password must be specified") @Size(max = 256) private String password;
|
||||||
@NotNull @Column(name = "administrator_status") private boolean administratorStatus;
|
@NotNull private boolean administrator;
|
||||||
@Temporal(TemporalType.DATE) @Column(name = "last_login") private Date lastLogin;
|
@Temporal(TemporalType.DATE) @Column(name = "last_login") private Date lastLogin;
|
||||||
|
|
||||||
private static final long serialVersionUID = 7095627971593953734L;
|
private static final long serialVersionUID = 7095627971593953734L;
|
||||||
|
|
||||||
@JsonProperty("administrator_status")
|
|
||||||
public boolean getAdministratorStatus() {
|
|
||||||
return administratorStatus;
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonProperty("administrator_status")
|
|
||||||
public void setAdministratorStatus(final boolean administratorStatus) {
|
|
||||||
this.administratorStatus = administratorStatus;
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonProperty("last_login")
|
@JsonProperty("last_login")
|
||||||
public Date getLastLogin() {
|
public Date getLastLogin() {
|
||||||
return lastLogin;
|
return lastLogin;
|
||||||
|
|||||||
+3
-5
@@ -27,10 +27,8 @@ import static org.mockito.Mockito.*;
|
|||||||
@RunWith(MockitoJUnitRunner.class)
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
@WebMvcTest(controllers = AccountController.class)
|
@WebMvcTest(controllers = AccountController.class)
|
||||||
public class AccountControllerTest {
|
public class AccountControllerTest {
|
||||||
@Mock
|
@Mock private AccountsRepository accountsRepository;
|
||||||
private AccountsRepository accountsRepository;
|
@InjectMocks private AccountController accountController;
|
||||||
@InjectMocks
|
|
||||||
private AccountController accountController;
|
|
||||||
@Mock private BindingResult bindingResult;
|
@Mock private BindingResult bindingResult;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -236,7 +234,7 @@ public class AccountControllerTest {
|
|||||||
final Account account = new Account();
|
final Account account = new Account();
|
||||||
account.setUsername("Test username");
|
account.setUsername("Test username");
|
||||||
account.setPassword("test password");
|
account.setPassword("test password");
|
||||||
account.setAdministratorStatus(true);
|
account.setAdministrator(true);
|
||||||
|
|
||||||
return account;
|
return account;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,10 +18,12 @@ repositories {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
compile project(':persistence')
|
|
||||||
compile group: 'org.apache.httpcomponents', name: 'httpcore', version: '4.4.11'
|
compile group: 'org.apache.httpcomponents', name: 'httpcore', version: '4.4.11'
|
||||||
compile group: 'org.apache.httpcomponents', name: 'fluent-hc', version: '4.5.7'
|
compile group: 'org.apache.httpcomponents', name: 'fluent-hc', version: '4.5.7'
|
||||||
compile group: 'com.google.code.gson', name: 'gson', version: '2.7'
|
compile group: 'com.google.code.gson', name: 'gson', version: '2.7'
|
||||||
|
compile group: 'org.springframework.boot', name: 'spring-boot-devtools', version: '2.0.5.RELEASE'
|
||||||
|
compile group: 'org.springframework.boot', name: 'spring-boot-starter-web', version: '2.0.5.RELEASE'
|
||||||
|
compile group: 'javax.persistence', name: 'javax.persistence-api', version: '2.2'
|
||||||
compile fileTree(dir: 'lib', include: '**/*.jar')
|
compile fileTree(dir: 'lib', include: '**/*.jar')
|
||||||
|
|
||||||
testCompile "org.springframework:spring-test:5.0.9.RELEASE"
|
testCompile "org.springframework:spring-test:5.0.9.RELEASE"
|
||||||
|
|||||||
+85
@@ -0,0 +1,85 @@
|
|||||||
|
package edu.msudenver.tsp.services;
|
||||||
|
|
||||||
|
import edu.msudenver.tsp.services.dto.Definition;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.TestPropertySource;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
import static org.hamcrest.CoreMatchers.equalTo;
|
||||||
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@ContextConfiguration(classes = ServicesTestConfig.class)
|
||||||
|
@TestPropertySource(locations = "classpath:test.properties")
|
||||||
|
public class DefinitionServiceIntegrationTest {
|
||||||
|
@Autowired private DefinitionService definitionService;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCRUD() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertTrue(createdDefinition.isPresent());
|
||||||
|
assertNotEquals(0, createdDefinition.get().getId());
|
||||||
|
assertThat(createdDefinition.get().getVersion(), is(0));
|
||||||
|
assertThat(createdDefinition.get().getName(), is("Test Name"));
|
||||||
|
assertNotNull(createdDefinition.get().getDefinition());
|
||||||
|
assertThat(createdDefinition.get().getDefinition().size(), is(1));
|
||||||
|
assertThat(createdDefinition.get().getDefinition().get(0), is("Test definition 1"));
|
||||||
|
assertNotNull(createdDefinition.get().getNotation());
|
||||||
|
assertThat(createdDefinition.get().getNotation().size(), is(1));
|
||||||
|
assertThat(createdDefinition.get().getNotation().get(0), is("\\testLaTeX"));
|
||||||
|
|
||||||
|
final Optional<Definition> definitionFoundById = definitionService.findById(createdDefinition.get().getId());
|
||||||
|
|
||||||
|
assertThat(definitionFoundById.get(), is(equalTo(createdDefinition.get())));
|
||||||
|
|
||||||
|
final Definition definitionUpdate = new Definition();
|
||||||
|
definitionUpdate.setId(createdDefinition.get().getId());
|
||||||
|
definitionUpdate.setName("Test Update");
|
||||||
|
|
||||||
|
final Optional<Definition> updatedDefinition = definitionService.updateDefinition(definitionUpdate);
|
||||||
|
|
||||||
|
assertTrue(updatedDefinition.isPresent());
|
||||||
|
assertNotEquals(0, updatedDefinition.get().getId());
|
||||||
|
assertThat(updatedDefinition.get().getVersion(), is(1));
|
||||||
|
assertThat(updatedDefinition.get().getName(), is("Test Update"));
|
||||||
|
assertNotNull(updatedDefinition.get().getDefinition());
|
||||||
|
assertThat(updatedDefinition.get().getDefinition().size(), is(1));
|
||||||
|
assertThat(updatedDefinition.get().getDefinition().get(0), is("Test definition 1"));
|
||||||
|
assertNotNull(updatedDefinition.get().getNotation());
|
||||||
|
assertThat(updatedDefinition.get().getNotation().size(), is(1));
|
||||||
|
assertThat(updatedDefinition.get().getNotation().get(0), is("\\testLaTeX"));
|
||||||
|
|
||||||
|
final boolean deletionWasSuccessful = definitionService.deleteDefinition(updatedDefinition.get());
|
||||||
|
|
||||||
|
assertThat(deletionWasSuccessful, is(true));
|
||||||
|
|
||||||
|
final Optional<Definition> deletedDefinitionFoundById = definitionService.findById(createdDefinition.get().getId());
|
||||||
|
|
||||||
|
assertFalse(deletedDefinitionFoundById.isPresent());
|
||||||
|
}
|
||||||
|
|
||||||
|
private Definition createDefinition() {
|
||||||
|
final List<String> definitionList = new ArrayList<>();
|
||||||
|
definitionList.add("Test definition 1");
|
||||||
|
|
||||||
|
final List<String> notationList = new ArrayList<>();
|
||||||
|
notationList.add("\\testLaTeX");
|
||||||
|
|
||||||
|
final Definition definition = new Definition();
|
||||||
|
definition.setName("Test Name");
|
||||||
|
definition.setDefinition(definitionList);
|
||||||
|
definition.setNotation(notationList);
|
||||||
|
|
||||||
|
return definition;
|
||||||
|
}
|
||||||
|
}
|
||||||
+6
-6
@@ -23,7 +23,7 @@ public class UserServiceIntegrationTest {
|
|||||||
private UserService userService;
|
private UserService userService;
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUserService(){
|
public void testCRUD() {
|
||||||
final Account testAccount = createAccount();
|
final Account testAccount = createAccount();
|
||||||
|
|
||||||
final Optional<Account> testCreatedAccount = userService.createAccount(testAccount);
|
final Optional<Account> testCreatedAccount = userService.createAccount(testAccount);
|
||||||
@@ -31,21 +31,21 @@ public class UserServiceIntegrationTest {
|
|||||||
final Account returnedAccount = testCreatedAccount.get();
|
final Account returnedAccount = testCreatedAccount.get();
|
||||||
assertEquals("test_user", returnedAccount.getUsername());
|
assertEquals("test_user", returnedAccount.getUsername());
|
||||||
assertEquals("test_password", returnedAccount.getPassword());
|
assertEquals("test_password", returnedAccount.getPassword());
|
||||||
assertFalse(returnedAccount.isAdministratorStatus());
|
assertFalse(returnedAccount.isAdministrator());
|
||||||
|
|
||||||
final Optional<Account> getAccountById = userService.findAccountById(returnedAccount.getId());
|
final Optional<Account> getAccountById = userService.findAccountById(returnedAccount.getId());
|
||||||
assertTrue(getAccountById.isPresent());
|
assertTrue(getAccountById.isPresent());
|
||||||
final Account returnedAccountById = getAccountById.get();
|
final Account returnedAccountById = getAccountById.get();
|
||||||
assertEquals("test_user", returnedAccountById.getUsername());
|
assertEquals("test_user", returnedAccountById.getUsername());
|
||||||
assertEquals("test_password", returnedAccountById.getPassword());
|
assertEquals("test_password", returnedAccountById.getPassword());
|
||||||
assertFalse(returnedAccountById.isAdministratorStatus());
|
assertFalse(returnedAccountById.isAdministrator());
|
||||||
|
|
||||||
final Optional<Account> getAccountByUsername = userService.findAccountByUsername(returnedAccount.getUsername());
|
final Optional<Account> getAccountByUsername = userService.findAccountByUsername(returnedAccount.getUsername());
|
||||||
assertTrue(getAccountByUsername.isPresent());
|
assertTrue(getAccountByUsername.isPresent());
|
||||||
final Account returnedAccountByUsername = getAccountByUsername.get();
|
final Account returnedAccountByUsername = getAccountByUsername.get();
|
||||||
assertEquals("test_user", returnedAccountByUsername.getUsername());
|
assertEquals("test_user", returnedAccountByUsername.getUsername());
|
||||||
assertEquals("test_password", returnedAccountByUsername.getPassword());
|
assertEquals("test_password", returnedAccountByUsername.getPassword());
|
||||||
assertFalse(returnedAccountById.isAdministratorStatus());
|
assertFalse(returnedAccountById.isAdministrator());
|
||||||
|
|
||||||
returnedAccount.setUsername("test_updatedUser");
|
returnedAccount.setUsername("test_updatedUser");
|
||||||
returnedAccount.setPassword("test_updatedPassword");
|
returnedAccount.setPassword("test_updatedPassword");
|
||||||
@@ -55,7 +55,7 @@ public class UserServiceIntegrationTest {
|
|||||||
final Account returnedUpdatedAccount = updatedAccount.get();
|
final Account returnedUpdatedAccount = updatedAccount.get();
|
||||||
assertEquals("test_updatedUser", returnedUpdatedAccount.getUsername());
|
assertEquals("test_updatedUser", returnedUpdatedAccount.getUsername());
|
||||||
assertEquals("test_updatedPassword", returnedUpdatedAccount.getPassword());
|
assertEquals("test_updatedPassword", returnedUpdatedAccount.getPassword());
|
||||||
assertFalse(returnedUpdatedAccount.isAdministratorStatus());
|
assertFalse(returnedUpdatedAccount.isAdministrator());
|
||||||
|
|
||||||
final boolean result = userService.deleteAccount(returnedUpdatedAccount);
|
final boolean result = userService.deleteAccount(returnedUpdatedAccount);
|
||||||
assertTrue(result);
|
assertTrue(result);
|
||||||
@@ -65,7 +65,7 @@ public class UserServiceIntegrationTest {
|
|||||||
final Account testAccount = new Account();
|
final Account testAccount = new Account();
|
||||||
testAccount.setUsername("test_user");
|
testAccount.setUsername("test_user");
|
||||||
testAccount.setPassword("test_password");
|
testAccount.setPassword("test_password");
|
||||||
testAccount.setAdministratorStatus(false);
|
testAccount.setAdministrator(false);
|
||||||
testAccount.setLastLogin(new Date());
|
testAccount.setLastLogin(new Date());
|
||||||
|
|
||||||
return testAccount;
|
return testAccount;
|
||||||
|
|||||||
@@ -0,0 +1,186 @@
|
|||||||
|
package edu.msudenver.tsp.services;
|
||||||
|
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import com.google.gson.reflect.TypeToken;
|
||||||
|
import edu.msudenver.tsp.services.dto.Definition;
|
||||||
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
import org.springframework.http.HttpStatus;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.time.Duration;
|
||||||
|
import java.time.Instant;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
|
@Service
|
||||||
|
public class DefinitionService {
|
||||||
|
private final RestService restService;
|
||||||
|
@Value("${persistence.api.connection.timeout.milliseconds}") private int connectionTimeoutMilliseconds;
|
||||||
|
@Value("${persistence.api.socket.timeout.milliseconds}") private int socketTimeoutMilliseconds;
|
||||||
|
@Value("${persistence.api.base.url}") private String persistenceApiBaseUrl;
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
public DefinitionService(final RestService restService) {
|
||||||
|
this.restService = restService;
|
||||||
|
}
|
||||||
|
|
||||||
|
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> findById(final int id) {
|
||||||
|
if (id == 0) {
|
||||||
|
LOG.error("Null id specified; returning {}");
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.info("Sending request to find definition by id {}", id);
|
||||||
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
|
try {
|
||||||
|
final TypeToken<Definition> typeToken = new TypeToken<Definition>(){};
|
||||||
|
final Optional<Definition> persistenceApiResponse = restService.get(persistenceApiBaseUrl + "definitions/" + id,
|
||||||
|
typeToken, connectionTimeoutMilliseconds, socketTimeoutMilliseconds, null);
|
||||||
|
|
||||||
|
if (persistenceApiResponse.isPresent()) {
|
||||||
|
LOG.info("Returning {}", persistenceApiResponse.get());
|
||||||
|
} else {
|
||||||
|
LOG.info("Unable to find definition with id {}", id);
|
||||||
|
}
|
||||||
|
|
||||||
|
return persistenceApiResponse;
|
||||||
|
} catch (final Exception e) {
|
||||||
|
LOG.error("Error finding definition by id", e);
|
||||||
|
return Optional.empty();
|
||||||
|
} finally {
|
||||||
|
LOG.info("Find by id request took {}ms", Duration.between(start, Instant.now()).toMillis());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<Definition> createDefinition(final Definition definition) {
|
||||||
|
if (definition == null) {
|
||||||
|
LOG.error("Given null definition, returning {}");
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.info("Sending request to insert definition {}", definition);
|
||||||
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
|
try {
|
||||||
|
final TypeToken<Definition> typeToken = new TypeToken<Definition>() {};
|
||||||
|
final Optional<Definition> persistenceApiResponse = restService.post(persistenceApiBaseUrl + "definitions/",
|
||||||
|
new GsonBuilder().create().toJson(definition),
|
||||||
|
typeToken,
|
||||||
|
connectionTimeoutMilliseconds,
|
||||||
|
socketTimeoutMilliseconds);
|
||||||
|
|
||||||
|
if (persistenceApiResponse.isPresent()) {
|
||||||
|
LOG.info("Creation successful. Returning {}", persistenceApiResponse.get());
|
||||||
|
} else {
|
||||||
|
LOG.info("Unable to create new definition {}", definition);
|
||||||
|
}
|
||||||
|
|
||||||
|
return persistenceApiResponse;
|
||||||
|
} catch (final Exception e) {
|
||||||
|
LOG.error("Error creating new definition", e);
|
||||||
|
return Optional.empty();
|
||||||
|
} finally {
|
||||||
|
LOG.info("Create new definition request took {}ms", Duration.between(start, Instant.now()).toMillis());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Optional<Definition> updateDefinition(final Definition definition) {
|
||||||
|
if (definition == null) {
|
||||||
|
LOG.error("Given null definition, returning {}");
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (definition.getId() == 0) {
|
||||||
|
LOG.error("Given invalid id 0, returning {}");
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.info("Sending request to update definition {}", definition);
|
||||||
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
|
try {
|
||||||
|
final TypeToken<Definition> typeToken = new TypeToken<Definition>(){};
|
||||||
|
final Optional<Definition> persistenceApiResponse = restService.patch(persistenceApiBaseUrl + "definitions/" + definition.getId(),
|
||||||
|
new GsonBuilder().create().toJson(definition),
|
||||||
|
typeToken,
|
||||||
|
connectionTimeoutMilliseconds,
|
||||||
|
socketTimeoutMilliseconds);
|
||||||
|
|
||||||
|
if (persistenceApiResponse.isPresent()) {
|
||||||
|
LOG.info("Update successful. Returning {}", persistenceApiResponse.get());
|
||||||
|
} else {
|
||||||
|
LOG.info("Unable to update definition {}", definition);
|
||||||
|
}
|
||||||
|
|
||||||
|
return persistenceApiResponse;
|
||||||
|
} catch (final Exception e) {
|
||||||
|
LOG.error("Error updating definition", e);
|
||||||
|
return Optional.empty();
|
||||||
|
} finally {
|
||||||
|
LOG.info("Update definition request took {}ms", Duration.between(start, Instant.now()).toMillis());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean deleteDefinition(final Definition definition) {
|
||||||
|
if (definition == null) {
|
||||||
|
LOG.error("Given null definition, returning false");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (definition.getId() == 0) {
|
||||||
|
LOG.error("Given invalid id 0, returning false");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG.info("Sending request to delete definition {}", definition);
|
||||||
|
final Instant start = Instant.now();
|
||||||
|
|
||||||
|
try {
|
||||||
|
final boolean deleteIsSuccessful = restService.delete(persistenceApiBaseUrl + "definitions/" + definition.getId(),
|
||||||
|
connectionTimeoutMilliseconds,
|
||||||
|
socketTimeoutMilliseconds,
|
||||||
|
HttpStatus.NO_CONTENT);
|
||||||
|
|
||||||
|
if (deleteIsSuccessful) {
|
||||||
|
LOG.info("Deletion successful. Returning true");
|
||||||
|
} else {
|
||||||
|
LOG.info("Unable to delete definition {}", definition);
|
||||||
|
}
|
||||||
|
|
||||||
|
return deleteIsSuccessful;
|
||||||
|
} catch (final Exception e) {
|
||||||
|
LOG.error("Error when deleting definition", e);
|
||||||
|
return false;
|
||||||
|
} finally {
|
||||||
|
LOG.info("Delete definition request took {}ms", Duration.between(start, Instant.now()).toMillis());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -16,7 +16,7 @@ import java.util.Date;
|
|||||||
public class Account extends BaseDto implements Serializable {
|
public class Account extends BaseDto implements Serializable {
|
||||||
@Size(max = 50) private String username;
|
@Size(max = 50) private String username;
|
||||||
@Size(max = 256) private String password;
|
@Size(max = 256) private String password;
|
||||||
@NotNull @SerializedName("administrator_status") private boolean administratorStatus;
|
@NotNull private boolean administrator;
|
||||||
@Temporal(TemporalType.DATE) @SerializedName("last_login") private Date lastLogin;
|
@Temporal(TemporalType.DATE) @SerializedName("last_login") private Date lastLogin;
|
||||||
|
|
||||||
private static final long serialVersionUID = 7095627971593953734L;
|
private static final long serialVersionUID = 7095627971593953734L;
|
||||||
|
|||||||
@@ -0,0 +1,24 @@
|
|||||||
|
package edu.msudenver.tsp.services.dto;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotBlank;
|
||||||
|
import javax.validation.constraints.Size;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
public class Definition extends BaseDto implements Serializable {
|
||||||
|
@NotBlank(groups = Insert.class, message = "A name must be specified")
|
||||||
|
@Size(min = 1, max = 200, message = "Must be between 1 and 200 characters")
|
||||||
|
private String name;
|
||||||
|
@NotBlank(groups = Insert.class, message = "At least one (1) definition must be specified")
|
||||||
|
private List<String> definition;
|
||||||
|
private List<String> notation;
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 3412178112996807691L;
|
||||||
|
|
||||||
|
public interface Insert {}
|
||||||
|
}
|
||||||
@@ -0,0 +1,290 @@
|
|||||||
|
package edu.msudenver.tsp.services;
|
||||||
|
|
||||||
|
import com.google.gson.GsonBuilder;
|
||||||
|
import edu.msudenver.tsp.services.dto.Definition;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.InjectMocks;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.runners.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
|
import static junit.framework.TestCase.assertTrue;
|
||||||
|
import static org.hamcrest.CoreMatchers.is;
|
||||||
|
import static org.hamcrest.core.IsEqual.equalTo;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
import static org.mockito.Matchers.*;
|
||||||
|
import static org.mockito.Mockito.*;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class DefinitionServiceTest {
|
||||||
|
@Mock private RestService restService;
|
||||||
|
@InjectMocks private DefinitionService definitionService;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetAllDefinitions() {
|
||||||
|
final List<Definition> definitionList = new ArrayList<>();
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
definitionList.add(testDefinition);
|
||||||
|
definitionList.add(testDefinition);
|
||||||
|
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenReturn(Optional.of(definitionList));
|
||||||
|
|
||||||
|
final Optional<List<Definition>> listOfDefinitions = definitionService.getAllDefinitions();
|
||||||
|
|
||||||
|
assertTrue(listOfDefinitions.isPresent());
|
||||||
|
assertThat(listOfDefinitions.get().size(), is(2));
|
||||||
|
listOfDefinitions.get().forEach(definition -> assertThat(definition, equalTo(testDefinition)));
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetAllDefinitions_RequestReturnsEmptyOptional() {
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
final Optional<List<Definition>> listOfDefinitions = definitionService.getAllDefinitions();
|
||||||
|
|
||||||
|
assertFalse(listOfDefinitions.isPresent());
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetAllDefinitions_ExceptionThrownWhenSendingRequest() {
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenThrow(new UnsupportedOperationException("Test exception"));
|
||||||
|
|
||||||
|
final Optional<List<Definition>> listOfDefinitions = definitionService.getAllDefinitions();
|
||||||
|
|
||||||
|
assertFalse(listOfDefinitions.isPresent());
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFindById() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenReturn(Optional.of(testDefinition));
|
||||||
|
|
||||||
|
final Optional<Definition> foundDefinition = definitionService.findById(testDefinition.getId());
|
||||||
|
|
||||||
|
assertTrue(foundDefinition.isPresent());
|
||||||
|
assertThat(foundDefinition.get().getId(), is(1));
|
||||||
|
assertThat(foundDefinition.get(), is(equalTo(testDefinition)));
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFindById_RequestReturnsEmptyOptional() {
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
final Optional<Definition> nonExistentDefinition = definitionService.findById(1);
|
||||||
|
|
||||||
|
assertFalse(nonExistentDefinition.isPresent());
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFindById_ExceptionThrownWhenSendingRequest() {
|
||||||
|
when(restService.get(anyString(), any(), anyInt(), anyInt(), anyString()))
|
||||||
|
.thenThrow(new UnsupportedOperationException("test exception"));
|
||||||
|
|
||||||
|
final Optional<Definition> exceptionThrowingDefinition = definitionService.findById(1);
|
||||||
|
|
||||||
|
assertFalse(exceptionThrowingDefinition.isPresent());
|
||||||
|
verify(restService).get(anyString(), any(), anyInt(), anyInt(), anyString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFindById_IdIsZero() {
|
||||||
|
final Optional<Definition> impossibleDefinition = definitionService.findById(0);
|
||||||
|
|
||||||
|
assertFalse(impossibleDefinition.isPresent());
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateDefinition() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenReturn(Optional.of(testDefinition));
|
||||||
|
|
||||||
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertNotNull(createdDefinition);
|
||||||
|
assertTrue(createdDefinition.isPresent());
|
||||||
|
assertEquals(testDefinition, createdDefinition.get());
|
||||||
|
verify(restService).post(anyString(), eq(testDefinitionJson), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateDefinition_NullDefinition() {
|
||||||
|
final Optional<Definition> nullDefinition = definitionService.createDefinition(null);
|
||||||
|
|
||||||
|
assertFalse(nullDefinition.isPresent());
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateDefinition_UnableToCreateDefinition() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertNotNull(createdDefinition);
|
||||||
|
assertFalse(createdDefinition.isPresent());
|
||||||
|
verify(restService).post(anyString(), eq(testDefinitionJson), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateDefinition_RestServiceThrowsException() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
final String testDefinitionJson = new GsonBuilder().create().toJson(testDefinition);
|
||||||
|
|
||||||
|
when(restService.post(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenThrow(new UnsupportedOperationException("test exception"));
|
||||||
|
|
||||||
|
final Optional<Definition> createdDefinition = definitionService.createDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertNotNull(createdDefinition);
|
||||||
|
assertFalse(createdDefinition.isPresent());
|
||||||
|
verify(restService).post(anyString(), eq(testDefinitionJson), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateDefinition() {
|
||||||
|
when(restService.patch(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenReturn(Optional.of(createDefinition().setName("Test update")));
|
||||||
|
|
||||||
|
final Definition testDefinition = new Definition();
|
||||||
|
testDefinition.setName("Test update");
|
||||||
|
testDefinition.setId(1);
|
||||||
|
|
||||||
|
final Optional<Definition> updatedDefinition = definitionService.updateDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertTrue(updatedDefinition.isPresent());
|
||||||
|
assertThat(updatedDefinition.get().getId(), is(1));
|
||||||
|
assertThat(updatedDefinition.get().getName(), is(equalTo("Test update")));
|
||||||
|
verify(restService).patch(anyString(), anyString(), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateDefinition_nullDefinition() {
|
||||||
|
final Optional<Definition> testUpdate = definitionService.updateDefinition(null);
|
||||||
|
|
||||||
|
assertFalse(testUpdate.isPresent());
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateDefinition_IdIsZero() {
|
||||||
|
final Definition impossibleDefinition = createDefinition();
|
||||||
|
impossibleDefinition.setId(0);
|
||||||
|
|
||||||
|
final Optional<Definition> testUpdate = definitionService.updateDefinition(impossibleDefinition);
|
||||||
|
|
||||||
|
assertFalse(testUpdate.isPresent());
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateDefinition_RequestReturnsEmptyOptional() {
|
||||||
|
when(restService.patch(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenReturn(Optional.empty());
|
||||||
|
|
||||||
|
final Optional<Definition> nonExistentDefinition = definitionService.updateDefinition(createDefinition());
|
||||||
|
|
||||||
|
assertFalse(nonExistentDefinition.isPresent());
|
||||||
|
verify(restService).patch(anyString(), anyString(), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUpdateDefinition_ExceptionThrownWhenSendingRequest() {
|
||||||
|
when(restService.patch(anyString(), anyString(), any(), anyInt(), anyInt()))
|
||||||
|
.thenThrow(new UnsupportedOperationException("test exception"));
|
||||||
|
|
||||||
|
final Optional<Definition> exceptionThrowingDefinition = definitionService.updateDefinition(createDefinition());
|
||||||
|
|
||||||
|
assertFalse(exceptionThrowingDefinition.isPresent());
|
||||||
|
verify(restService).patch(anyString(), anyString(), any(), anyInt(), anyInt());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteDefinition() {
|
||||||
|
when(restService.delete(anyString(), anyInt(), anyInt(), any()))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
final boolean deleteIsSuccessful = definitionService.deleteDefinition(createDefinition());
|
||||||
|
|
||||||
|
assertTrue(deleteIsSuccessful);
|
||||||
|
verify(restService).delete(anyString(), anyInt(), anyInt(), any());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteDefinition_NullDefinition() {
|
||||||
|
final boolean deleteIsSuccessful = definitionService.deleteDefinition(null);
|
||||||
|
|
||||||
|
assertFalse(deleteIsSuccessful);
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteDefinition_IdIsZero() {
|
||||||
|
final Definition testDefinition = createDefinition();
|
||||||
|
testDefinition.setId(0);
|
||||||
|
|
||||||
|
final boolean deleteIsSuccessful = definitionService.deleteDefinition(testDefinition);
|
||||||
|
|
||||||
|
assertFalse(deleteIsSuccessful);
|
||||||
|
verifyZeroInteractions(restService);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteDefinition_RequestReturnsFalse() {
|
||||||
|
when(restService.delete(anyString(), anyInt(), anyInt(), any()))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
final boolean deleteIsSuccessful = definitionService.deleteDefinition(createDefinition());
|
||||||
|
|
||||||
|
assertFalse(deleteIsSuccessful);
|
||||||
|
verify(restService).delete(anyString(), anyInt(), anyInt(), any());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDeleteDefinition_ExceptionThrownWhenSendingRequest() {
|
||||||
|
when(restService.delete(anyString(), anyInt(), anyInt(), any()))
|
||||||
|
.thenThrow(new UnsupportedOperationException("test exception"));
|
||||||
|
|
||||||
|
final boolean deleteIsSuccessful = definitionService.deleteDefinition(createDefinition());
|
||||||
|
|
||||||
|
assertFalse(deleteIsSuccessful);
|
||||||
|
verify(restService).delete(anyString(), anyInt(), anyInt(), any());
|
||||||
|
}
|
||||||
|
|
||||||
|
private Definition createDefinition() {
|
||||||
|
final List<String> definitionList = new ArrayList<>();
|
||||||
|
definitionList.add("Test definition 1");
|
||||||
|
|
||||||
|
final List<String> notationList = new ArrayList<>();
|
||||||
|
notationList.add("\\testLaTeX");
|
||||||
|
|
||||||
|
final Definition definition = new Definition();
|
||||||
|
definition.setName("Test Name");
|
||||||
|
definition.setDefinition(definitionList);
|
||||||
|
definition.setNotation(notationList);
|
||||||
|
definition.setId(1);
|
||||||
|
|
||||||
|
return definition;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -306,7 +306,7 @@ public class UserServiceTest {
|
|||||||
final Account account = new Account();
|
final Account account = new Account();
|
||||||
account.setUsername("Test username");
|
account.setUsername("Test username");
|
||||||
account.setPassword("test password");
|
account.setPassword("test password");
|
||||||
account.setAdministratorStatus(true);
|
account.setAdministrator(true);
|
||||||
account.setLastLogin(new Date());
|
account.setLastLogin(new Date());
|
||||||
return account;
|
return account;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user