more tests
This commit is contained in:
parent
04d438923d
commit
c7c6bf1a42
4 changed files with 42 additions and 25 deletions
|
@ -24,4 +24,6 @@ public class SEBServerRestEndpoints {
|
||||||
|
|
||||||
public static final String NAMES_ENDPOINT_SUFFIX = "/names";
|
public static final String NAMES_ENDPOINT_SUFFIX = "/names";
|
||||||
|
|
||||||
|
public static final String LIST_ENDPOINT_SUFFIX = "/list";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2019 ETH Zürich, Educational Development and Technology (LET)
|
|
||||||
*
|
|
||||||
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package ch.ethz.seb.sebserver.webservice.servicelayer.lms;
|
|
||||||
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.profile.WebServiceProfile;
|
|
||||||
|
|
||||||
@Configuration
|
|
||||||
@WebServiceProfile
|
|
||||||
public class LmsBindingConfig {
|
|
||||||
|
|
||||||
}
|
|
|
@ -29,6 +29,7 @@ import org.springframework.web.bind.annotation.RequestParam;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.Constants;
|
import ch.ethz.seb.sebserver.gbl.Constants;
|
||||||
import ch.ethz.seb.sebserver.gbl.api.POSTMapper;
|
import ch.ethz.seb.sebserver.gbl.api.POSTMapper;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.api.SEBServerRestEndpoints;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Domain;
|
import ch.ethz.seb.sebserver.gbl.model.Domain;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
import ch.ethz.seb.sebserver.gbl.model.Entity;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
import ch.ethz.seb.sebserver.gbl.model.EntityKey;
|
||||||
|
@ -120,7 +121,7 @@ public abstract class EntityController<T extends GrantEntity, M extends GrantEnt
|
||||||
// ******************
|
// ******************
|
||||||
|
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
path = "/names",
|
path = SEBServerRestEndpoints.NAMES_ENDPOINT_SUFFIX,
|
||||||
method = RequestMethod.GET,
|
method = RequestMethod.GET,
|
||||||
consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE,
|
consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE,
|
||||||
produces = MediaType.APPLICATION_JSON_VALUE)
|
produces = MediaType.APPLICATION_JSON_VALUE)
|
||||||
|
@ -168,16 +169,19 @@ public abstract class EntityController<T extends GrantEntity, M extends GrantEnt
|
||||||
// ******************
|
// ******************
|
||||||
|
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
path = "/list",
|
path = SEBServerRestEndpoints.LIST_ENDPOINT_SUFFIX,
|
||||||
method = RequestMethod.GET,
|
method = RequestMethod.GET,
|
||||||
consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE,
|
consumes = MediaType.APPLICATION_FORM_URLENCODED_VALUE,
|
||||||
produces = MediaType.APPLICATION_JSON_VALUE)
|
produces = MediaType.APPLICATION_JSON_VALUE)
|
||||||
public Collection<T> getForIds(@RequestParam(name = "ids", required = true) final String ids) {
|
public Collection<T> getForIds(@RequestParam(name = "ids", required = true) final String ids) {
|
||||||
|
|
||||||
return Result.tryCatch(() -> {
|
return Result.tryCatch(() -> {
|
||||||
|
|
||||||
return Arrays.asList(StringUtils.split(ids, Constants.LIST_SEPARATOR_CHAR))
|
return Arrays.asList(StringUtils.split(ids, Constants.LIST_SEPARATOR_CHAR))
|
||||||
.stream()
|
.stream()
|
||||||
.map(modelId -> new EntityKey(modelId, this.entityDAO.entityType()))
|
.map(modelId -> new EntityKey(modelId, this.entityDAO.entityType()))
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
})
|
})
|
||||||
.flatMap(this.entityDAO::loadEntities)
|
.flatMap(this.entityDAO::loadEntities)
|
||||||
.getOrThrow()
|
.getOrThrow()
|
||||||
|
@ -274,17 +278,17 @@ public abstract class EntityController<T extends GrantEntity, M extends GrantEnt
|
||||||
// ******************
|
// ******************
|
||||||
|
|
||||||
@RequestMapping(
|
@RequestMapping(
|
||||||
path = "/{id}",
|
path = "/{modelId}",
|
||||||
method = RequestMethod.DELETE,
|
method = RequestMethod.DELETE,
|
||||||
produces = MediaType.APPLICATION_JSON_VALUE)
|
produces = MediaType.APPLICATION_JSON_VALUE)
|
||||||
public EntityProcessingReport hardDelete(@PathVariable final String id) {
|
public EntityProcessingReport hardDelete(@PathVariable final String modelId) {
|
||||||
final EntityType entityType = this.entityDAO.entityType();
|
final EntityType entityType = this.entityDAO.entityType();
|
||||||
final BulkAction bulkAction = new BulkAction(
|
final BulkAction bulkAction = new BulkAction(
|
||||||
Type.HARD_DELETE,
|
Type.HARD_DELETE,
|
||||||
entityType,
|
entityType,
|
||||||
new EntityKey(id, entityType));
|
new EntityKey(modelId, entityType));
|
||||||
|
|
||||||
return this.entityDAO.byModelId(id)
|
return this.entityDAO.byModelId(modelId)
|
||||||
.flatMap(entity -> this.authorizationGrantService.checkGrantOnEntity(
|
.flatMap(entity -> this.authorizationGrantService.checkGrantOnEntity(
|
||||||
entity,
|
entity,
|
||||||
PrivilegeType.WRITE))
|
PrivilegeType.WRITE))
|
||||||
|
|
|
@ -22,6 +22,7 @@ import com.fasterxml.jackson.core.type.TypeReference;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.api.APIMessage;
|
import ch.ethz.seb.sebserver.gbl.api.APIMessage;
|
||||||
import ch.ethz.seb.sebserver.gbl.api.SEBServerRestEndpoints;
|
import ch.ethz.seb.sebserver.gbl.api.SEBServerRestEndpoints;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.EntityName;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityProcessingReport;
|
import ch.ethz.seb.sebserver.gbl.model.EntityProcessingReport;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.Page;
|
import ch.ethz.seb.sebserver.gbl.model.Page;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
||||||
|
@ -337,6 +338,35 @@ public class InstitutionAPITest extends AdministrationAPIIntegrationTester {
|
||||||
assertEquals("Resource INSTITUTION with ID: 4 not found", error.get(0).details);
|
assertEquals("Resource INSTITUTION with ID: 4 not found", error.get(0).details);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getForIds() throws Exception {
|
||||||
|
final Collection<Institution> institutions = new RestAPITestHelper()
|
||||||
|
.withAccessToken(getSebAdminAccess())
|
||||||
|
.withPath(SEBServerRestEndpoints.ENDPOINT_INSTITUTION)
|
||||||
|
.withPath(SEBServerRestEndpoints.LIST_ENDPOINT_SUFFIX)
|
||||||
|
.withAttribute("ids", "1,2,3")
|
||||||
|
.withExpectedStatus(HttpStatus.OK)
|
||||||
|
.getAsObject(new TypeReference<Collection<Institution>>() {
|
||||||
|
});
|
||||||
|
|
||||||
|
assertNotNull(institutions);
|
||||||
|
assertTrue(institutions.size() == 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getNames() throws Exception {
|
||||||
|
final Collection<EntityName> institutions = new RestAPITestHelper()
|
||||||
|
.withAccessToken(getSebAdminAccess())
|
||||||
|
.withPath(SEBServerRestEndpoints.ENDPOINT_INSTITUTION)
|
||||||
|
.withPath(SEBServerRestEndpoints.NAMES_ENDPOINT_SUFFIX)
|
||||||
|
.withExpectedStatus(HttpStatus.OK)
|
||||||
|
.getAsObject(new TypeReference<Collection<EntityName>>() {
|
||||||
|
});
|
||||||
|
|
||||||
|
assertNotNull(institutions);
|
||||||
|
assertTrue(institutions.size() == 3);
|
||||||
|
}
|
||||||
|
|
||||||
static void assertContainsInstitution(final String name, final Collection<Institution> institutions) {
|
static void assertContainsInstitution(final String name, final Collection<Institution> institutions) {
|
||||||
assert institutions != null;
|
assert institutions != null;
|
||||||
assert institutions.stream()
|
assert institutions.stream()
|
||||||
|
|
Loading…
Reference in a new issue