more tests and find-bug fixes
This commit is contained in:
parent
02446b5003
commit
71635c85f6
4 changed files with 118 additions and 23 deletions
|
@ -27,6 +27,10 @@
|
||||||
<Package name="ch.ethz.seb.sebserver.gui.*" />
|
<Package name="ch.ethz.seb.sebserver.gui.*" />
|
||||||
<Bug pattern="SE_BAD_FIELD" />
|
<Bug pattern="SE_BAD_FIELD" />
|
||||||
</Match>
|
</Match>
|
||||||
|
<Match>
|
||||||
|
<Package name="ch.ethz.seb.sebserver.gui.content.*" />
|
||||||
|
<Bug pattern="RV_RETURN_VALUE_IGNORED_NO_SIDE_EFFECT" />
|
||||||
|
</Match>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -9,8 +9,6 @@
|
||||||
package ch.ethz.seb.sebserver.gui;
|
package ch.ethz.seb.sebserver.gui;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import javax.servlet.RequestDispatcher;
|
import javax.servlet.RequestDispatcher;
|
||||||
import javax.servlet.ServletException;
|
import javax.servlet.ServletException;
|
||||||
|
@ -18,9 +16,6 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.eclipse.rap.rwt.RWT;
|
|
||||||
import org.eclipse.rap.rwt.client.WebClient;
|
|
||||||
import org.eclipse.rap.rwt.internal.application.ApplicationContextImpl;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import org.springframework.beans.factory.annotation.Value;
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
@ -36,7 +31,6 @@ import org.springframework.stereotype.Component;
|
||||||
import org.springframework.web.client.RestTemplate;
|
import org.springframework.web.client.RestTemplate;
|
||||||
|
|
||||||
import ch.ethz.seb.sebserver.gbl.api.API;
|
import ch.ethz.seb.sebserver.gbl.api.API;
|
||||||
import ch.ethz.seb.sebserver.gui.RAPConfiguration.RAPSpringEntryPointFactory;
|
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.WebserviceURIService;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.auth.WebserviceURIService;
|
||||||
|
|
||||||
@Lazy
|
@Lazy
|
||||||
|
@ -146,24 +140,24 @@ final class InstitutionalAuthenticationEntryPoint implements AuthenticationEntry
|
||||||
/** TODO this seems not to work as expected. Different Theme is only possible in RAP on different
|
/** TODO this seems not to work as expected. Different Theme is only possible in RAP on different
|
||||||
* entry-points and since entry-points are statically defined within the RAPConficuration
|
* entry-points and since entry-points are statically defined within the RAPConficuration
|
||||||
* there is no possibility to apply them dynamically within an institution so far.
|
* there is no possibility to apply them dynamically within an institution so far.
|
||||||
*
|
*
|
||||||
* @param institutionalEndpoint
|
* @param institutionalEndpoint
|
||||||
* @return */
|
* @return */
|
||||||
private boolean initInstitutionalBasedThemeEntryPoint(final String institutionalEndpoint) {
|
// private boolean initInstitutionalBasedThemeEntryPoint(final String institutionalEndpoint) {
|
||||||
try {
|
// try {
|
||||||
final ApplicationContextImpl appContext = (ApplicationContextImpl) RWT.getApplicationContext();
|
// final ApplicationContextImpl appContext = (ApplicationContextImpl) RWT.getApplicationContext();
|
||||||
final Map<String, String> properties = new HashMap<>();
|
// final Map<String, String> properties = new HashMap<>();
|
||||||
properties.put(WebClient.THEME_ID, "sms");
|
// properties.put(WebClient.THEME_ID, "sms");
|
||||||
appContext.getEntryPointManager().register(
|
// appContext.getEntryPointManager().register(
|
||||||
institutionalEndpoint,
|
// institutionalEndpoint,
|
||||||
new RAPSpringEntryPointFactory(),
|
// new RAPSpringEntryPointFactory(),
|
||||||
properties);
|
// properties);
|
||||||
|
//
|
||||||
return true;
|
// return true;
|
||||||
} catch (final Exception e) {
|
// } catch (final Exception e) {
|
||||||
log.warn("Failed to dynamically set entry point for institution: {}", institutionalEndpoint, e);
|
// log.warn("Failed to dynamically set entry point for institution: {}", institutionalEndpoint, e);
|
||||||
return false;
|
// return false;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
}
|
}
|
|
@ -151,6 +151,9 @@ public class RAPConfiguration implements ApplicationConfiguration {
|
||||||
return WebApplicationContextUtils
|
return WebApplicationContextUtils
|
||||||
.getRequiredWebApplicationContext(servletContext);
|
.getRequiredWebApplicationContext(servletContext);
|
||||||
|
|
||||||
|
} catch (final RuntimeException e) {
|
||||||
|
log.error("Failed to initialize Spring-Context on HttpSession: " + httpSession);
|
||||||
|
throw e;
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
log.error("Failed to initialize Spring-Context on HttpSession: " + httpSession);
|
log.error("Failed to initialize Spring-Context on HttpSession: " + httpSession);
|
||||||
throw new RuntimeException("Failed to initialize Spring-Context on HttpSession: " + httpSession);
|
throw new RuntimeException("Failed to initialize Spring-Context on HttpSession: " + httpSession);
|
||||||
|
|
|
@ -10,6 +10,8 @@ package ch.ethz.seb.sebserver.gui.integration;
|
||||||
|
|
||||||
import static org.junit.Assert.*;
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.LinkedHashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
@ -28,6 +30,9 @@ 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.exam.Exam;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Exam;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.Exam.ExamType;
|
import ch.ethz.seb.sebserver.gbl.model.exam.Exam.ExamType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.IndicatorType;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.exam.Indicator.Threshold;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
import ch.ethz.seb.sebserver.gbl.model.exam.QuizData;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
import ch.ethz.seb.sebserver.gbl.model.institution.Institution;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
import ch.ethz.seb.sebserver.gbl.model.institution.LmsSetup;
|
||||||
|
@ -40,8 +45,13 @@ import ch.ethz.seb.sebserver.gbl.util.Utils;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.RestCallError;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.RestCallError;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.RestServiceImpl;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.RestServiceImpl;
|
||||||
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.GetExamNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamPage;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetExamPage;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetIndicator;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.GetIndicatorPage;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.NewIndicator;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.SaveExam;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.SaveExam;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.SaveIndicator;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.ActivateInstitution;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.ActivateInstitution;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.GetInstitution;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.GetInstitution;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.GetInstitutionNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.institution.GetInstitutionNames;
|
||||||
|
@ -663,4 +673,88 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertFalse(savedExam.supporter.isEmpty());
|
assertFalse(savedExam.supporter.isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Order(7)
|
||||||
|
// *************************************
|
||||||
|
// Use Case 7: Login as examAdmin2
|
||||||
|
// - Get imported exam
|
||||||
|
// - add new indicator for exam
|
||||||
|
// - save exam with new indicator and test
|
||||||
|
// - create some thresholds for the new indicator
|
||||||
|
public void testUsecase7() {
|
||||||
|
final RestServiceImpl restService = createRestServiceForUser(
|
||||||
|
"examAdmin2",
|
||||||
|
"examAdmin2",
|
||||||
|
new GetExam(),
|
||||||
|
new GetExamNames(),
|
||||||
|
new NewIndicator(),
|
||||||
|
new SaveIndicator(),
|
||||||
|
new GetIndicator(),
|
||||||
|
new GetIndicatorPage());
|
||||||
|
|
||||||
|
final Result<List<EntityName>> examNamesResult = restService
|
||||||
|
.getBuilder(GetExamNames.class)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(examNamesResult);
|
||||||
|
assertFalse(examNamesResult.hasError());
|
||||||
|
final List<EntityName> exams = examNamesResult.get();
|
||||||
|
assertFalse(exams.isEmpty());
|
||||||
|
final EntityName examName = exams.get(0);
|
||||||
|
assertEquals("Demo Quiz 1", examName.name);
|
||||||
|
|
||||||
|
final Result<Exam> examResult = restService
|
||||||
|
.getBuilder(GetExam.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, examName.modelId)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(examResult);
|
||||||
|
assertFalse(examResult.hasError());
|
||||||
|
final Exam exam = examResult.get();
|
||||||
|
|
||||||
|
final Result<Indicator> newIndicatorResult = restService
|
||||||
|
.getBuilder(NewIndicator.class)
|
||||||
|
.withFormParam(Domain.INDICATOR.ATTR_EXAM_ID, exam.getModelId())
|
||||||
|
.withFormParam(Domain.INDICATOR.ATTR_NAME, "Ping")
|
||||||
|
.withFormParam(Domain.INDICATOR.ATTR_TYPE, IndicatorType.LAST_PING.name)
|
||||||
|
.withFormParam(Domain.INDICATOR.ATTR_COLOR, "000001")
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(newIndicatorResult);
|
||||||
|
assertFalse(newIndicatorResult.hasError());
|
||||||
|
final Indicator newIndicator = newIndicatorResult.get();
|
||||||
|
|
||||||
|
assertEquals("Ping", newIndicator.name);
|
||||||
|
assertEquals("000001", newIndicator.defaultColor);
|
||||||
|
|
||||||
|
final Indicator indicatorToSave = new Indicator(
|
||||||
|
newIndicator.id, newIndicator.examId, newIndicator.name, newIndicator.type, newIndicator.defaultColor,
|
||||||
|
Utils.immutableCollectionOf(
|
||||||
|
new Indicator.Threshold(2000d, "000011"),
|
||||||
|
new Indicator.Threshold(5000d, "001111")));
|
||||||
|
|
||||||
|
final Result<Indicator> savedIndicatorResult = restService
|
||||||
|
.getBuilder(SaveIndicator.class)
|
||||||
|
.withBody(indicatorToSave)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(savedIndicatorResult);
|
||||||
|
assertFalse(savedIndicatorResult.hasError());
|
||||||
|
final Indicator savedIndicator = savedIndicatorResult.get();
|
||||||
|
|
||||||
|
assertEquals("Ping", savedIndicator.name);
|
||||||
|
assertEquals("000001", savedIndicator.defaultColor);
|
||||||
|
final Collection<Threshold> thresholds = savedIndicator.getThresholds();
|
||||||
|
assertFalse(thresholds.isEmpty());
|
||||||
|
assertTrue(thresholds.size() == 2);
|
||||||
|
final Iterator<Threshold> iterator = thresholds.iterator();
|
||||||
|
final Threshold t1 = iterator.next();
|
||||||
|
final Threshold t2 = iterator.next();
|
||||||
|
|
||||||
|
assertTrue(2000d - t1.value < .0001);
|
||||||
|
assertEquals("000011", t1.color);
|
||||||
|
assertTrue(5000d - t2.value < .0001);
|
||||||
|
assertEquals("001111", t2.color);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue