integration tests

This commit is contained in:
anhefti 2022-03-10 16:04:41 +01:00
parent 4758b8c6c6
commit 6f320a489d
5 changed files with 216 additions and 50 deletions

View file

@ -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(

View file

@ -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(

View file

@ -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;
}
}
} }

View file

@ -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();
} }
} }

View file

@ -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