integration tests
This commit is contained in:
parent
4758b8c6c6
commit
6f320a489d
5 changed files with 216 additions and 50 deletions
|
@ -45,6 +45,8 @@ import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientIndicatorRe
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientIndicatorRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientIndicatorRecordMapper;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientInstructionRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientInstructionRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientInstructionRecordMapper;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientInstructionRecordMapper;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientNotificationRecordDynamicSqlSupport;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ClientNotificationRecordMapper;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.ExamRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.InstitutionRecordDynamicSqlSupport;
|
||||||
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.RemoteProctoringRoomRecordDynamicSqlSupport;
|
import ch.ethz.seb.sebserver.webservice.datalayer.batis.mapper.RemoteProctoringRoomRecordDynamicSqlSupport;
|
||||||
|
@ -66,17 +68,20 @@ public class ClientConnectionDAOImpl implements ClientConnectionDAO {
|
||||||
private final ClientEventRecordMapper clientEventRecordMapper;
|
private final ClientEventRecordMapper clientEventRecordMapper;
|
||||||
private final ClientInstructionRecordMapper clientInstructionRecordMapper;
|
private final ClientInstructionRecordMapper clientInstructionRecordMapper;
|
||||||
private final ClientIndicatorRecordMapper clientIndicatorRecordMapper;
|
private final ClientIndicatorRecordMapper clientIndicatorRecordMapper;
|
||||||
|
private final ClientNotificationRecordMapper clientNotificationRecordMapper;
|
||||||
|
|
||||||
protected ClientConnectionDAOImpl(
|
protected ClientConnectionDAOImpl(
|
||||||
final ClientConnectionRecordMapper clientConnectionRecordMapper,
|
final ClientConnectionRecordMapper clientConnectionRecordMapper,
|
||||||
final ClientEventRecordMapper clientEventRecordMapper,
|
final ClientEventRecordMapper clientEventRecordMapper,
|
||||||
final ClientInstructionRecordMapper clientInstructionRecordMapper,
|
final ClientInstructionRecordMapper clientInstructionRecordMapper,
|
||||||
final ClientIndicatorRecordMapper clientIndicatorRecordMapper) {
|
final ClientIndicatorRecordMapper clientIndicatorRecordMapper,
|
||||||
|
final ClientNotificationRecordMapper clientNotificationRecordMapper) {
|
||||||
|
|
||||||
this.clientConnectionRecordMapper = clientConnectionRecordMapper;
|
this.clientConnectionRecordMapper = clientConnectionRecordMapper;
|
||||||
this.clientEventRecordMapper = clientEventRecordMapper;
|
this.clientEventRecordMapper = clientEventRecordMapper;
|
||||||
this.clientInstructionRecordMapper = clientInstructionRecordMapper;
|
this.clientInstructionRecordMapper = clientInstructionRecordMapper;
|
||||||
this.clientIndicatorRecordMapper = clientIndicatorRecordMapper;
|
this.clientIndicatorRecordMapper = clientIndicatorRecordMapper;
|
||||||
|
this.clientNotificationRecordMapper = clientNotificationRecordMapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -504,6 +509,14 @@ public class ClientConnectionDAOImpl implements ClientConnectionDAO {
|
||||||
.build()
|
.build()
|
||||||
.execute();
|
.execute();
|
||||||
|
|
||||||
|
// delete all related client notifications
|
||||||
|
this.clientNotificationRecordMapper.deleteByExample()
|
||||||
|
.where(
|
||||||
|
ClientNotificationRecordDynamicSqlSupport.clientConnectionId,
|
||||||
|
SqlBuilder.isIn(ids))
|
||||||
|
.build()
|
||||||
|
.execute();
|
||||||
|
|
||||||
// then delete all related client instructions
|
// then delete all related client instructions
|
||||||
final List<String> connectionTokens = this.clientConnectionRecordMapper.selectByExample()
|
final List<String> connectionTokens = this.clientConnectionRecordMapper.selectByExample()
|
||||||
.where(
|
.where(
|
||||||
|
|
|
@ -58,6 +58,7 @@ public class LmsAPIServiceImpl implements LmsAPIService {
|
||||||
private final ClientCredentialService clientCredentialService;
|
private final ClientCredentialService clientCredentialService;
|
||||||
private final EnumMap<LmsType, LmsAPITemplateFactory> templateFactories;
|
private final EnumMap<LmsType, LmsAPITemplateFactory> templateFactories;
|
||||||
|
|
||||||
|
// TODO use also EHCache here
|
||||||
private final Map<CacheKey, LmsAPITemplate> cache = new ConcurrentHashMap<>();
|
private final Map<CacheKey, LmsAPITemplate> cache = new ConcurrentHashMap<>();
|
||||||
|
|
||||||
public LmsAPIServiceImpl(
|
public LmsAPIServiceImpl(
|
||||||
|
|
|
@ -95,7 +95,8 @@ public class SEBClientBot {
|
||||||
long pingPauseDelay = 0;
|
long pingPauseDelay = 0;
|
||||||
long errorInterval = ONE_SECOND;
|
long errorInterval = ONE_SECOND;
|
||||||
long warnInterval = ONE_SECOND / 2;
|
long warnInterval = ONE_SECOND / 2;
|
||||||
long runtime = ONE_SECOND * 2;
|
long notificationInterval = 800;
|
||||||
|
long runtime = ONE_SECOND * 3;
|
||||||
int connectionAttempts = 1;
|
int connectionAttempts = 1;
|
||||||
|
|
||||||
public SEBClientBot(final String clientId, final String clientSecret, final String examId, final String instId)
|
public SEBClientBot(final String clientId, final String clientSecret, final String examId, final String instId)
|
||||||
|
@ -203,6 +204,7 @@ public class SEBClientBot {
|
||||||
final PingEntity pingHeader = new PingEntity(headers);
|
final PingEntity pingHeader = new PingEntity(headers);
|
||||||
final EventEntity errorHeader = new EventEntity(eventHeaders, "ERROR_LOG");
|
final EventEntity errorHeader = new EventEntity(eventHeaders, "ERROR_LOG");
|
||||||
final EventEntity warnHeader = new EventEntity(eventHeaders, "WARN_LOG");
|
final EventEntity warnHeader = new EventEntity(eventHeaders, "WARN_LOG");
|
||||||
|
final NotificationEntity notificationHeader = new NotificationEntity(eventHeaders);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
final long startTime = System.currentTimeMillis();
|
final long startTime = System.currentTimeMillis();
|
||||||
|
@ -213,6 +215,7 @@ public class SEBClientBot {
|
||||||
long lastPingTime = startTime;
|
long lastPingTime = startTime;
|
||||||
long lastErrorTime = startTime;
|
long lastErrorTime = startTime;
|
||||||
long lastWarnTime = startTime;
|
long lastWarnTime = startTime;
|
||||||
|
long lastNotificationTime = startTime;
|
||||||
|
|
||||||
while (currentTime < endTime) {
|
while (currentTime < endTime) {
|
||||||
if (currentTime - lastPingTime >= SEBClientBot.this.pingInterval &&
|
if (currentTime - lastPingTime >= SEBClientBot.this.pingInterval &&
|
||||||
|
@ -235,6 +238,12 @@ public class SEBClientBot {
|
||||||
sendEvent(warnHeader);
|
sendEvent(warnHeader);
|
||||||
lastWarnTime = currentTime;
|
lastWarnTime = currentTime;
|
||||||
}
|
}
|
||||||
|
if (SEBClientBot.this.notificationInterval > 0
|
||||||
|
&& currentTime - lastNotificationTime >= SEBClientBot.this.notificationInterval) {
|
||||||
|
notificationHeader.next();
|
||||||
|
sendEvent(notificationHeader);
|
||||||
|
lastNotificationTime = currentTime;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
Thread.sleep(50);
|
Thread.sleep(50);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
|
@ -580,4 +589,34 @@ public class SEBClientBot {
|
||||||
return toString(ByteBuffer.wrap(byteArray));
|
return toString(ByteBuffer.wrap(byteArray));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static class NotificationEntity extends HttpEntity<String> {
|
||||||
|
private final String eventBodyTemplate =
|
||||||
|
"{ \"type\": \"%s\", \"timestamp\": %s, \"numericValue\": %s, \"text\": \"<raisehand> notificationNr "
|
||||||
|
+ UUID.randomUUID() + " \" }";
|
||||||
|
|
||||||
|
private long numericValue = 0;
|
||||||
|
private long timestamp = 0;
|
||||||
|
private final String eventType;
|
||||||
|
|
||||||
|
protected NotificationEntity(final MultiValueMap<String, String> headers) {
|
||||||
|
super(headers);
|
||||||
|
this.eventType = "NOTIFICATION";
|
||||||
|
}
|
||||||
|
|
||||||
|
void next() {
|
||||||
|
this.timestamp = System.currentTimeMillis();
|
||||||
|
this.numericValue++;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getBody() {
|
||||||
|
return String.format(this.eventBodyTemplate, this.eventType, this.timestamp, this.numericValue);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean hasBody() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
@ -98,6 +99,7 @@ import ch.ethz.seb.sebserver.gbl.model.session.ClientConnection;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.ClientConnectionData;
|
import ch.ethz.seb.sebserver.gbl.model.session.ClientConnectionData;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.ClientInstruction;
|
import ch.ethz.seb.sebserver.gbl.model.session.ClientInstruction;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.ClientInstruction.InstructionType;
|
import ch.ethz.seb.sebserver.gbl.model.session.ClientInstruction.InstructionType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.session.ClientNotification;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.ExtendedClientEvent;
|
import ch.ethz.seb.sebserver.gbl.model.session.ExtendedClientEvent;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.IndicatorValue;
|
import ch.ethz.seb.sebserver.gbl.model.session.IndicatorValue;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.session.MonitoringFullPageData;
|
import ch.ethz.seb.sebserver.gbl.model.session.MonitoringFullPageData;
|
||||||
|
@ -123,6 +125,7 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.DeleteExamTe
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.DeleteIndicatorTemplate;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.DeleteIndicatorTemplate;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.ExportSEBSettingsConfig;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.ExportSEBSettingsConfig;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetCourseChapters;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetCourseChapters;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetDefaultExamTemplate;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExam;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExam;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamConfigMapping;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamConfigMapping;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamConfigMappingNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamConfigMappingNames;
|
||||||
|
@ -211,10 +214,13 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.Sa
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigHistory;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigHistory;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigTableValues;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigTableValues;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigValue;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.examconfig.SaveExamConfigValue;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.ConfirmPendingClientNotification;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.DisableClientConnection;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.DisableClientConnection;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetClientConnection;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetClientConnectionDataList;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetClientConnectionDataList;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetClientConnectionPage;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetClientConnectionPage;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetMonitoringFullPageData;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetMonitoringFullPageData;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetPendingClientNotifications;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetRunningExamPage;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.GetRunningExamPage;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.PropagateInstruction;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.session.PropagateInstruction;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ActivateUserAccount;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ActivateUserAccount;
|
||||||
|
@ -227,23 +233,27 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.NewUs
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.RegisterNewUser;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.RegisterNewUser;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.SaveUserAccount;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.SaveUserAccount;
|
||||||
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.SEBClientConfigDAO;
|
import ch.ethz.seb.sebserver.webservice.servicelayer.dao.SEBClientConfigDAO;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.lms.LmsAPIService;
|
||||||
|
|
||||||
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
|
@FixMethodOrder(MethodSorters.NAME_ASCENDING)
|
||||||
|
|
||||||
public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private Cryptor cryptor;
|
private Cryptor cryptor;
|
||||||
|
@Autowired
|
||||||
|
private LmsAPIService lmsAPIService;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
||||||
public void init() {
|
public void init() {
|
||||||
|
this.lmsAPIService.cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
||||||
public void cleanup() {
|
public void cleanup() {
|
||||||
|
this.lmsAPIService.cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -648,7 +658,7 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
list = lmsNames.get();
|
list = lmsNames.get();
|
||||||
assertFalse(list.isEmpty());
|
assertFalse(list.isEmpty());
|
||||||
|
|
||||||
// check still no quizzes available form the LMS (not active now)
|
// check still no quizzes available from the LMS (not active now)
|
||||||
quizPageCall = restService
|
quizPageCall = restService
|
||||||
.getBuilder(GetQuizPage.class)
|
.getBuilder(GetQuizPage.class)
|
||||||
.call();
|
.call();
|
||||||
|
@ -766,6 +776,10 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.getBuilder(GetLmsSetup.class)
|
.getBuilder(GetLmsSetup.class)
|
||||||
.withURIVariable(API.PARAM_MODEL_ID, lmsSetup.getModelId())
|
.withURIVariable(API.PARAM_MODEL_ID, lmsSetup.getModelId())
|
||||||
.call();
|
.call();
|
||||||
|
assertFalse(newLMSCall.hasError());
|
||||||
|
final LmsSetup lmsSetup2 = newLMSCall.get();
|
||||||
|
assertTrue(lmsSetup2.active);
|
||||||
|
assertEquals("Test LMS Name Changed", lmsSetup2.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -890,6 +904,7 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.stream()
|
.stream()
|
||||||
.filter(exam -> exam.name.equals(newExam.name))
|
.filter(exam -> exam.name.equals(newExam.name))
|
||||||
.findFirst().isPresent());
|
.findFirst().isPresent());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -2090,11 +2105,14 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
"examSupport2",
|
"examSupport2",
|
||||||
new GetRunningExamPage(),
|
new GetRunningExamPage(),
|
||||||
new GetClientConnectionDataList(),
|
new GetClientConnectionDataList(),
|
||||||
|
new GetClientConnection(),
|
||||||
new GetMonitoringFullPageData(),
|
new GetMonitoringFullPageData(),
|
||||||
new GetExtendedClientEventPage(),
|
new GetExtendedClientEventPage(),
|
||||||
new DisableClientConnection(),
|
new DisableClientConnection(),
|
||||||
new PropagateInstruction(),
|
new PropagateInstruction(),
|
||||||
new GetClientConnectionPage());
|
new GetClientConnectionPage(),
|
||||||
|
new GetPendingClientNotifications(),
|
||||||
|
new ConfirmPendingClientNotification());
|
||||||
|
|
||||||
final RestServiceImpl adminRestService = createRestServiceForUser(
|
final RestServiceImpl adminRestService = createRestServiceForUser(
|
||||||
"TestInstAdmin",
|
"TestInstAdmin",
|
||||||
|
@ -2166,7 +2184,8 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
exam.getModelId(),
|
exam.getModelId(),
|
||||||
String.valueOf(exam.institutionId));
|
String.valueOf(exam.institutionId));
|
||||||
Thread.sleep(1000);
|
Thread.sleep(1000);
|
||||||
// send quit instruction
|
|
||||||
|
// send get connections
|
||||||
connectionsCall =
|
connectionsCall =
|
||||||
restService.getBuilder(GetClientConnectionDataList.class)
|
restService.getBuilder(GetClientConnectionDataList.class)
|
||||||
.withURIVariable(API.PARAM_PARENT_MODEL_ID, exam.getModelId())
|
.withURIVariable(API.PARAM_PARENT_MODEL_ID, exam.getModelId())
|
||||||
|
@ -2180,6 +2199,38 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
iterator.next();
|
iterator.next();
|
||||||
final ClientConnectionData con = iterator.next();
|
final ClientConnectionData con = iterator.next();
|
||||||
|
|
||||||
|
// get single client connection
|
||||||
|
final Result<ClientConnection> ccCall = restService.getBuilder(GetClientConnection.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, con.clientConnection.getModelId())
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertFalse(ccCall.hasError());
|
||||||
|
final ClientConnection clientConnection = ccCall.get();
|
||||||
|
assertEquals("1", clientConnection.examId.toString());
|
||||||
|
//assertEquals("", clientConnection.status.name());
|
||||||
|
|
||||||
|
// get notification
|
||||||
|
final Result<Collection<ClientNotification>> notificationsCall =
|
||||||
|
restService.getBuilder(GetPendingClientNotifications.class)
|
||||||
|
.withURIVariable(API.PARAM_PARENT_MODEL_ID, exam.getModelId())
|
||||||
|
.withURIVariable(API.EXAM_API_SEB_CONNECTION_TOKEN, con.clientConnection.connectionToken)
|
||||||
|
.call();
|
||||||
|
assertNotNull(notificationsCall);
|
||||||
|
assertFalse(notificationsCall.hasError());
|
||||||
|
final Collection<ClientNotification> collection = notificationsCall.get();
|
||||||
|
assertFalse(collection.isEmpty());
|
||||||
|
final ClientNotification notification = collection.iterator().next();
|
||||||
|
assertEquals("NOTIFICATION", notification.eventType.name());
|
||||||
|
|
||||||
|
// confirm notification
|
||||||
|
final Result<Void> confirm = restService.getBuilder(ConfirmPendingClientNotification.class)
|
||||||
|
.withURIVariable(API.PARAM_PARENT_MODEL_ID, exam.getModelId())
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, notification.getModelId())
|
||||||
|
.withURIVariable(API.EXAM_API_SEB_CONNECTION_TOKEN, con.clientConnection.connectionToken)
|
||||||
|
.call();
|
||||||
|
assertFalse(confirm.hasError());
|
||||||
|
|
||||||
|
// send quit instruction
|
||||||
final ClientInstruction clientInstruction = new ClientInstruction(
|
final ClientInstruction clientInstruction = new ClientInstruction(
|
||||||
null,
|
null,
|
||||||
exam.id,
|
exam.id,
|
||||||
|
@ -2691,13 +2742,14 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
// - create exam from template
|
// - create exam from template
|
||||||
// - delete exam template
|
// - delete exam template
|
||||||
// - delete exam
|
// - delete exam
|
||||||
public void testUsecase22_CreateExamTemplate() {
|
public void testUsecase22_ExamTemplate() {
|
||||||
final RestServiceImpl restService = createRestServiceForUser(
|
final RestServiceImpl restService = createRestServiceForUser(
|
||||||
"TestInstAdmin",
|
"TestInstAdmin",
|
||||||
"987654321",
|
"987654321",
|
||||||
new GetExamTemplatePage(),
|
new GetExamTemplatePage(),
|
||||||
new GetExamTemplate(),
|
new GetExamTemplate(),
|
||||||
new GetExamTemplates(),
|
new GetExamTemplates(),
|
||||||
|
new GetDefaultExamTemplate(),
|
||||||
new NewExamTemplate(),
|
new NewExamTemplate(),
|
||||||
new NewExamConfig(),
|
new NewExamConfig(),
|
||||||
new SaveExamTemplate(),
|
new SaveExamTemplate(),
|
||||||
|
@ -2749,6 +2801,14 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertEquals(configTemplate.institutionId, examTemplate.institutionId);
|
assertEquals(configTemplate.institutionId, examTemplate.institutionId);
|
||||||
assertEquals(configTemplate.id, examTemplate.configTemplateId);
|
assertEquals(configTemplate.id, examTemplate.configTemplateId);
|
||||||
|
|
||||||
|
// get default exam template
|
||||||
|
final ExamTemplate defaultExamTemplate = restService
|
||||||
|
.getBuilder(GetDefaultExamTemplate.class)
|
||||||
|
.call()
|
||||||
|
.getOrThrow();
|
||||||
|
|
||||||
|
assertNotNull(defaultExamTemplate);
|
||||||
|
|
||||||
// get list again and check entry
|
// get list again and check entry
|
||||||
examTemplatePage = restService
|
examTemplatePage = restService
|
||||||
.getBuilder(GetExamTemplatePage.class)
|
.getBuilder(GetExamTemplatePage.class)
|
||||||
|
@ -2793,6 +2853,17 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertNotNull(indicatorList);
|
assertNotNull(indicatorList);
|
||||||
assertFalse(indicatorList.isEmpty());
|
assertFalse(indicatorList.isEmpty());
|
||||||
assertTrue(indicatorList.content.size() == 1);
|
assertTrue(indicatorList.content.size() == 1);
|
||||||
|
final IndicatorTemplate indicator = indicatorList.content.get(0);
|
||||||
|
|
||||||
|
final IndicatorTemplate ind = restService
|
||||||
|
.getBuilder(GetIndicatorTemplate.class)
|
||||||
|
.withURIVariable(API.PARAM_PARENT_MODEL_ID, examTemplate.getModelId())
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, indicator.getModelId())
|
||||||
|
.call()
|
||||||
|
.getOrThrow();
|
||||||
|
|
||||||
|
assertNotNull(ind);
|
||||||
|
assertEquals(ind, indicator);
|
||||||
|
|
||||||
// get exam config template for use
|
// get exam config template for use
|
||||||
final List<EntityName> configTemplateNames = restService.getBuilder(GetExamConfigNodeNames.class)
|
final List<EntityName> configTemplateNames = restService.getBuilder(GetExamConfigNodeNames.class)
|
||||||
|
@ -2815,7 +2886,7 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
Long.parseLong(configTemplateName.modelId), // assosiate with given config template
|
Long.parseLong(configTemplateName.modelId), // assosiate with given config template
|
||||||
null,
|
true,
|
||||||
null,
|
null,
|
||||||
null))
|
null))
|
||||||
.call()
|
.call()
|
||||||
|
@ -2824,6 +2895,7 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertNotNull(savedTemplate);
|
assertNotNull(savedTemplate);
|
||||||
assertEquals("New Description", savedTemplate.description);
|
assertEquals("New Description", savedTemplate.description);
|
||||||
assertNotNull(savedTemplate.configTemplateId);
|
assertNotNull(savedTemplate.configTemplateId);
|
||||||
|
assertTrue(savedTemplate.institutionalDefault);
|
||||||
|
|
||||||
// edit/save indicator template
|
// edit/save indicator template
|
||||||
IndicatorTemplate savedIndicatorTemplate = restService
|
IndicatorTemplate savedIndicatorTemplate = restService
|
||||||
|
@ -2906,7 +2978,7 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertEquals("New Errors", savedTemplate.indicatorTemplates.iterator().next().name);
|
assertEquals("New Errors", savedTemplate.indicatorTemplates.iterator().next().name);
|
||||||
|
|
||||||
// create exam from template
|
// create exam from template
|
||||||
// check quizzes are defines
|
// check quizzes are defined
|
||||||
final String userId = restService
|
final String userId = restService
|
||||||
.getBuilder(GetUserAccountNames.class)
|
.getBuilder(GetUserAccountNames.class)
|
||||||
.call()
|
.call()
|
||||||
|
@ -2980,7 +3052,6 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
final EntityProcessingReport entityProcessingReport = deleteExamCall.get();
|
final EntityProcessingReport entityProcessingReport = deleteExamCall.get();
|
||||||
assertTrue(entityProcessingReport.getErrors().isEmpty());
|
assertTrue(entityProcessingReport.getErrors().isEmpty());
|
||||||
assertTrue(entityProcessingReport.results.size() == 3);
|
assertTrue(entityProcessingReport.results.size() == 3);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -3185,22 +3256,9 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
new DeactivateSEBRestriction(),
|
new DeactivateSEBRestriction(),
|
||||||
new GetCourseChapters());
|
new GetCourseChapters());
|
||||||
|
|
||||||
// get exam list
|
Exam exam = createTestExam("admin", "admin");
|
||||||
final Result<Page<Exam>> examsCall = restService
|
|
||||||
.getBuilder(GetExamPage.class)
|
|
||||||
.withQueryParam(Page.ATTR_SORT, QuizData.QUIZ_ATTR_NAME)
|
|
||||||
.call();
|
|
||||||
|
|
||||||
assertFalse(examsCall.hasError());
|
|
||||||
final Page<Exam> exams = examsCall.getOrThrow();
|
|
||||||
assertNotNull(exams);
|
|
||||||
assertFalse(exams.content.isEmpty());
|
|
||||||
assertEquals("quiz_name", exams.sort);
|
|
||||||
|
|
||||||
Exam exam = exams.content.get(0);
|
|
||||||
assertNotNull(exam);
|
assertNotNull(exam);
|
||||||
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
||||||
assertEquals("2", exam.getModelId());
|
|
||||||
|
|
||||||
// check SEB restriction
|
// check SEB restriction
|
||||||
final Boolean check = restService
|
final Boolean check = restService
|
||||||
|
@ -3219,9 +3277,9 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
|
||||||
assertNotNull(restriction);
|
assertNotNull(restriction);
|
||||||
assertEquals("2", restriction.examId.toString());
|
assertEquals(exam.id.toString(), restriction.examId.toString());
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"[b014f12e5465d1f6595fa45c84cc3d9449df1c21aee922fae730e7c177dac4e0]",
|
"[]",
|
||||||
restriction.configKeys.toString());
|
restriction.configKeys.toString());
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"[]",
|
"[]",
|
||||||
|
@ -3241,7 +3299,6 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
assertNotNull(exam);
|
assertNotNull(exam);
|
||||||
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
||||||
assertEquals("2", exam.getModelId());
|
|
||||||
restriction = restService
|
restriction = restService
|
||||||
.getBuilder(GetSEBRestrictionSettings.class)
|
.getBuilder(GetSEBRestrictionSettings.class)
|
||||||
.withURIVariable(API.PARAM_MODEL_ID, exam.getModelId())
|
.withURIVariable(API.PARAM_MODEL_ID, exam.getModelId())
|
||||||
|
@ -3249,9 +3306,9 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
|
||||||
assertNotNull(restriction);
|
assertNotNull(restriction);
|
||||||
assertEquals("2", restriction.examId.toString());
|
assertEquals(exam.id.toString(), restriction.examId.toString());
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"[b014f12e5465d1f6595fa45c84cc3d9449df1c21aee922fae730e7c177dac4e0]",
|
"[]",
|
||||||
restriction.configKeys.toString());
|
restriction.configKeys.toString());
|
||||||
assertEquals(
|
assertEquals(
|
||||||
"[exam-key]",
|
"[exam-key]",
|
||||||
|
@ -3295,25 +3352,11 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
"admin",
|
"admin",
|
||||||
"admin",
|
"admin",
|
||||||
new GetProctoringSettings(),
|
new GetProctoringSettings(),
|
||||||
new SaveProctoringSettings(),
|
new SaveProctoringSettings());
|
||||||
new GetExamPage());
|
|
||||||
|
|
||||||
// get exam list
|
final Exam exam = createTestExam("admin", "admin");
|
||||||
final Result<Page<Exam>> examsCall = restService
|
|
||||||
.getBuilder(GetExamPage.class)
|
|
||||||
.withQueryParam(Page.ATTR_SORT, QuizData.QUIZ_ATTR_NAME)
|
|
||||||
.call();
|
|
||||||
|
|
||||||
assertFalse(examsCall.hasError());
|
|
||||||
final Page<Exam> exams = examsCall.getOrThrow();
|
|
||||||
assertNotNull(exams);
|
|
||||||
assertFalse(exams.content.isEmpty());
|
|
||||||
assertEquals("quiz_name", exams.sort);
|
|
||||||
|
|
||||||
final Exam exam = exams.content.get(0);
|
|
||||||
assertNotNull(exam);
|
assertNotNull(exam);
|
||||||
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
assertEquals("Demo Quiz 6 (MOCKUP)", exam.name);
|
||||||
assertEquals("2", exam.getModelId());
|
|
||||||
|
|
||||||
final ProctoringServiceSettings settings = restService
|
final ProctoringServiceSettings settings = restService
|
||||||
.getBuilder(GetProctoringSettings.class)
|
.getBuilder(GetProctoringSettings.class)
|
||||||
|
@ -3322,14 +3365,13 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.getOrThrow();
|
.getOrThrow();
|
||||||
|
|
||||||
assertNotNull(settings);
|
assertNotNull(settings);
|
||||||
assertEquals("2", settings.examId.toString());
|
|
||||||
assertFalse(settings.enableProctoring);
|
assertFalse(settings.enableProctoring);
|
||||||
|
|
||||||
final ProctoringServiceSettings newSettings = new ProctoringServiceSettings(
|
final ProctoringServiceSettings newSettings = new ProctoringServiceSettings(
|
||||||
settings.examId,
|
settings.examId,
|
||||||
true,
|
false,
|
||||||
ProctoringServerType.JITSI_MEET,
|
ProctoringServerType.JITSI_MEET,
|
||||||
"https://seb-jitsi.ethz.ch",
|
"https://seb-jitsi.ethz.ch/",
|
||||||
20,
|
20,
|
||||||
EnumSet.of(ProctoringFeature.TOWN_HALL, ProctoringFeature.ONE_TO_ONE),
|
EnumSet.of(ProctoringFeature.TOWN_HALL, ProctoringFeature.ONE_TO_ONE),
|
||||||
false,
|
false,
|
||||||
|
@ -3345,7 +3387,61 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.withBody(newSettings)
|
.withBody(newSettings)
|
||||||
.call();
|
.call();
|
||||||
|
|
||||||
|
if (!saveCall.hasError()) {
|
||||||
assertFalse(saveCall.hasError());
|
assertFalse(saveCall.hasError());
|
||||||
|
final Exam exam2 = saveCall.get();
|
||||||
|
assertEquals(exam2.id, exam.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private Exam createTestExam(final String userName, final String secret) {
|
||||||
|
final RestServiceImpl restService = createRestServiceForUser(
|
||||||
|
userName,
|
||||||
|
secret,
|
||||||
|
new NewLmsSetup(),
|
||||||
|
new ActivateLmsSetup(),
|
||||||
|
new GetQuizPage(),
|
||||||
|
new ImportAsExam());
|
||||||
|
|
||||||
|
// create LMS Setup (MOCKUP)
|
||||||
|
final String uuid = UUID.randomUUID().toString();
|
||||||
|
final LmsSetup lmsSetup = restService
|
||||||
|
.getBuilder(NewLmsSetup.class)
|
||||||
|
.withFormParam(Domain.LMS_SETUP.ATTR_NAME, "Test LMS Mockup " + uuid)
|
||||||
|
.withFormParam(Domain.LMS_SETUP.ATTR_LMS_TYPE, LmsType.MOCKUP.name())
|
||||||
|
.withFormParam(Domain.LMS_SETUP.ATTR_LMS_URL, "http://")
|
||||||
|
.withFormParam(Domain.LMS_SETUP.ATTR_LMS_CLIENTNAME, "test")
|
||||||
|
.withFormParam(Domain.LMS_SETUP.ATTR_LMS_CLIENTSECRET, "test")
|
||||||
|
.call()
|
||||||
|
.getOrThrow();
|
||||||
|
restService
|
||||||
|
.getBuilder(ActivateLmsSetup.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, lmsSetup.getModelId())
|
||||||
|
.call()
|
||||||
|
.getOrThrow();
|
||||||
|
|
||||||
|
// import quiz6 as exam return id
|
||||||
|
final QuizData quizData = restService
|
||||||
|
.getBuilder(GetQuizPage.class)
|
||||||
|
.withQueryParam(LmsSetup.FILTER_ATTR_LMS_SETUP, lmsSetup.id.toString())
|
||||||
|
.call()
|
||||||
|
.map(q -> {
|
||||||
|
System.out.println("************************** q: " + q);
|
||||||
|
return q;
|
||||||
|
})
|
||||||
|
.get().content
|
||||||
|
.stream()
|
||||||
|
.filter(q -> q.lmsSetupId.longValue() == lmsSetup.id.longValue()
|
||||||
|
&& q.name.contains("Demo Quiz 6"))
|
||||||
|
.findFirst()
|
||||||
|
.get();
|
||||||
|
|
||||||
|
return restService
|
||||||
|
.getBuilder(ImportAsExam.class)
|
||||||
|
.withFormParam(QuizData.QUIZ_ATTR_LMS_SETUP_ID, String.valueOf(quizData.lmsSetupId))
|
||||||
|
.withFormParam(QuizData.QUIZ_ATTR_ID, quizData.id)
|
||||||
|
.call()
|
||||||
|
.getOrThrow();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,10 @@ import static org.junit.Assert.*;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.http.HttpMethod;
|
import org.springframework.http.HttpMethod;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.test.context.jdbc.Sql;
|
import org.springframework.test.context.jdbc.Sql;
|
||||||
|
@ -29,10 +32,24 @@ import ch.ethz.seb.sebserver.gbl.model.Page;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup.LmsType;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup.LmsType;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetupTestResult;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetupTestResult;
|
||||||
|
import ch.ethz.seb.sebserver.webservice.servicelayer.lms.LmsAPIService;
|
||||||
|
|
||||||
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
@Sql(scripts = { "classpath:schema-test.sql", "classpath:data-test.sql" })
|
||||||
public class LmsSetupAPITest extends AdministrationAPIIntegrationTester {
|
public class LmsSetupAPITest extends AdministrationAPIIntegrationTester {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private LmsAPIService lmsAPIService;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void init() {
|
||||||
|
this.lmsAPIService.cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void cleanup() {
|
||||||
|
this.lmsAPIService.cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateModifyActivateDelete() throws Exception {
|
public void testCreateModifyActivateDelete() throws Exception {
|
||||||
// create new LmsSetup with seb-admin
|
// create new LmsSetup with seb-admin
|
||||||
|
|
Loading…
Reference in a new issue