new tests and findbugs fixes
This commit is contained in:
parent
ebbfde4718
commit
02446b5003
9 changed files with 148 additions and 12 deletions
|
@ -24,7 +24,7 @@
|
||||||
<Bug pattern="REC_CATCH_EXCEPTION" />
|
<Bug pattern="REC_CATCH_EXCEPTION" />
|
||||||
</Match>
|
</Match>
|
||||||
<Match>
|
<Match>
|
||||||
<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>
|
||||||
|
|
||||||
|
|
|
@ -105,8 +105,7 @@ public class WebSecurityConfig extends WebSecurityConfigurerAdapter implements E
|
||||||
.ignoring()
|
.ignoring()
|
||||||
.antMatchers("/error")
|
.antMatchers("/error")
|
||||||
.antMatchers(this.examAPIDiscoveryEndpoint)
|
.antMatchers(this.examAPIDiscoveryEndpoint)
|
||||||
.antMatchers(this.adminAPIEndpoint + API.INFO_ENDPOINT + API.LOGO_PATH_SEGMENT + "/**")
|
.antMatchers(this.adminAPIEndpoint + API.INFO_ENDPOINT + API.LOGO_PATH_SEGMENT + "/**");
|
||||||
.and();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequestMapping("/error")
|
@RequestMapping("/error")
|
||||||
|
|
|
@ -30,6 +30,9 @@ public final class Constants {
|
||||||
public static final String EMPTY_NOTE = "--";
|
public static final String EMPTY_NOTE = "--";
|
||||||
public static final String FORM_URL_ENCODED_SEPARATOR = "&";
|
public static final String FORM_URL_ENCODED_SEPARATOR = "&";
|
||||||
public static final String FORM_URL_ENCODED_NAME_VALUE_SEPARATOR = "=";
|
public static final String FORM_URL_ENCODED_NAME_VALUE_SEPARATOR = "=";
|
||||||
|
public static final String URL_PORT_SEPARATOR = ":";
|
||||||
|
public static final String URL_ADDRESS_SEPARATOR = "://";
|
||||||
|
public static final String URL_PATH_SEPARATOR = "/";
|
||||||
|
|
||||||
public static final String PERCENTAGE = "%";
|
public static final String PERCENTAGE = "%";
|
||||||
|
|
||||||
|
|
|
@ -60,6 +60,16 @@ public class EntityName extends EntityKey {
|
||||||
return new EntityKey(getModelId(), getEntityType());
|
return new EntityKey(getModelId(), getEntityType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return super.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(final Object obj) {
|
||||||
|
return super.equals(obj);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
final StringBuilder builder = new StringBuilder();
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
|
|
@ -136,11 +136,11 @@ public final class Orientation implements Entity {
|
||||||
return this.groupId;
|
return this.groupId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getXPosition() {
|
public Integer getxPosition() {
|
||||||
return this.xPosition;
|
return this.xPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getYPosition() {
|
public Integer getyPosition() {
|
||||||
return this.yPosition;
|
return this.yPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -69,7 +69,7 @@ public class ClientConnectionData {
|
||||||
while (i1.hasNext()) {
|
while (i1.hasNext()) {
|
||||||
final IndicatorValue iv1 = i1.next();
|
final IndicatorValue iv1 = i1.next();
|
||||||
final IndicatorValue iv2 = i2.next();
|
final IndicatorValue iv2 = i2.next();
|
||||||
if (iv1.getType() != iv2.getType() || iv1.getValue() != iv2.getValue()) {
|
if (iv1.getType() != iv2.getType() || Math.round(iv1.getValue() - iv2.getValue()) < .0001) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,7 @@ public class ModalInputDialog<T> extends Dialog {
|
||||||
private final WidgetFactory widgetFactory;
|
private final WidgetFactory widgetFactory;
|
||||||
private int dialogWidth = 400;
|
private int dialogWidth = 400;
|
||||||
private int dialogHeight = 600;
|
private int dialogHeight = 600;
|
||||||
private final int buttonWidth = 100;
|
private int buttonWidth = 100;
|
||||||
|
|
||||||
public ModalInputDialog(
|
public ModalInputDialog(
|
||||||
final Shell parent,
|
final Shell parent,
|
||||||
|
@ -62,6 +62,11 @@ public class ModalInputDialog<T> extends Dialog {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ModalInputDialog<T> setButtonWidth(final int buttonWidth) {
|
||||||
|
this.buttonWidth = buttonWidth;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public void open(
|
public void open(
|
||||||
final LocTextKey title,
|
final LocTextKey title,
|
||||||
final Consumer<T> callback,
|
final Consumer<T> callback,
|
||||||
|
|
|
@ -267,11 +267,11 @@ final class OpenEdxLmsAPITemplate implements LmsAPITemplate {
|
||||||
final URL url = new URL(lmsSetup.lmsApiUrl);
|
final URL url = new URL(lmsSetup.lmsApiUrl);
|
||||||
final int port = url.getPort();
|
final int port = url.getPort();
|
||||||
_externalStartURI = this.webserviceInfo.getHttpScheme() +
|
_externalStartURI = this.webserviceInfo.getHttpScheme() +
|
||||||
"://" + externalAddressAlias +
|
Constants.URL_ADDRESS_SEPARATOR + externalAddressAlias +
|
||||||
((port >= 0)
|
((port >= 0)
|
||||||
? ":" + port
|
? Constants.URL_PORT_SEPARATOR + port
|
||||||
: "")
|
: StringUtils.EMPTY)
|
||||||
+ "/";
|
+ Constants.URL_PATH_SEPARATOR;
|
||||||
|
|
||||||
log.info("Use external address for course access: {}", _externalStartURI);
|
log.info("Use external address for course access: {}", _externalStartURI);
|
||||||
} catch (final Exception e) {
|
} catch (final Exception e) {
|
||||||
|
|
|
@ -26,6 +26,8 @@ import ch.ethz.seb.sebserver.gbl.model.Domain;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.EntityName;
|
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.exam.Exam;
|
||||||
|
import ch.ethz.seb.sebserver.gbl.model.exam.Exam.ExamType;
|
||||||
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;
|
||||||
|
@ -34,8 +36,12 @@ import ch.ethz.seb.sebserver.gbl.model.user.PasswordChange;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserInfo;
|
||||||
import ch.ethz.seb.sebserver.gbl.model.user.UserRole;
|
import ch.ethz.seb.sebserver.gbl.model.user.UserRole;
|
||||||
import ch.ethz.seb.sebserver.gbl.util.Result;
|
import ch.ethz.seb.sebserver.gbl.util.Result;
|
||||||
|
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.GetExamPage;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.exam.SaveExam;
|
||||||
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;
|
||||||
|
@ -46,7 +52,9 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.GetLmsSe
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.GetLmsSetupNames;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.GetLmsSetupNames;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.NewLmsSetup;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.NewLmsSetup;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.SaveLmsSetup;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.lmssetup.SaveLmsSetup;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.quiz.GetQuizData;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.quiz.GetQuizPage;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.quiz.GetQuizPage;
|
||||||
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.quiz.ImportAsExam;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ActivateUserAccount;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ActivateUserAccount;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ChangePassword;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.ChangePassword;
|
||||||
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.GetUserAccount;
|
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.useraccount.GetUserAccount;
|
||||||
|
@ -301,7 +309,8 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
"TestInstAdmin",
|
"TestInstAdmin",
|
||||||
"987654321",
|
"987654321",
|
||||||
new GetInstitutionNames(),
|
new GetInstitutionNames(),
|
||||||
new NewUserAccount());
|
new NewUserAccount(),
|
||||||
|
new ActivateUserAccount());
|
||||||
|
|
||||||
final String instId = restService.getBuilder(GetInstitutionNames.class)
|
final String instId = restService.getBuilder(GetInstitutionNames.class)
|
||||||
.call()
|
.call()
|
||||||
|
@ -328,6 +337,12 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertNotNull(result);
|
assertNotNull(result);
|
||||||
assertFalse(result.hasError());
|
assertFalse(result.hasError());
|
||||||
|
|
||||||
|
Result<EntityProcessingReport> activation = restService.getBuilder(ActivateUserAccount.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, result.get().uuid)
|
||||||
|
.call();
|
||||||
|
assertNotNull(activation);
|
||||||
|
assertFalse(activation.hasError());
|
||||||
|
|
||||||
result = restService.getBuilder(NewUserAccount.class)
|
result = restService.getBuilder(NewUserAccount.class)
|
||||||
.withFormParam(Domain.USER.ATTR_INSTITUTION_ID, instId)
|
.withFormParam(Domain.USER.ATTR_INSTITUTION_ID, instId)
|
||||||
.withFormParam(Domain.USER.ATTR_NAME, "examSupport2")
|
.withFormParam(Domain.USER.ATTR_NAME, "examSupport2")
|
||||||
|
@ -343,6 +358,12 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertNotNull(result);
|
assertNotNull(result);
|
||||||
assertFalse(result.hasError());
|
assertFalse(result.hasError());
|
||||||
|
|
||||||
|
activation = restService.getBuilder(ActivateUserAccount.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, result.get().uuid)
|
||||||
|
.call();
|
||||||
|
assertNotNull(activation);
|
||||||
|
assertFalse(activation.hasError());
|
||||||
|
|
||||||
result = restService.getBuilder(NewUserAccount.class)
|
result = restService.getBuilder(NewUserAccount.class)
|
||||||
.withFormParam(Domain.USER.ATTR_INSTITUTION_ID, instId)
|
.withFormParam(Domain.USER.ATTR_INSTITUTION_ID, instId)
|
||||||
.withFormParam(Domain.USER.ATTR_NAME, "examSupport1")
|
.withFormParam(Domain.USER.ATTR_NAME, "examSupport1")
|
||||||
|
@ -358,6 +379,12 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
assertNotNull(result);
|
assertNotNull(result);
|
||||||
assertFalse(result.hasError());
|
assertFalse(result.hasError());
|
||||||
|
|
||||||
|
activation = restService.getBuilder(ActivateUserAccount.class)
|
||||||
|
.withURIVariable(API.PARAM_MODEL_ID, result.get().uuid)
|
||||||
|
.call();
|
||||||
|
assertNotNull(activation);
|
||||||
|
assertFalse(activation.hasError());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -544,4 +571,96 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
|
||||||
.call();
|
.call();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Order(6)
|
||||||
|
// *************************************
|
||||||
|
// Use Case 6: Login as examAdmin2
|
||||||
|
// - Check if there are some quizzes form previous LMS Setup
|
||||||
|
// - Import a quiz as Exam
|
||||||
|
// - get exam page and check the exam is there
|
||||||
|
// - edit exam property and save again
|
||||||
|
public void testUsecase6() {
|
||||||
|
final RestServiceImpl restService = createRestServiceForUser(
|
||||||
|
"examAdmin2",
|
||||||
|
"examAdmin2",
|
||||||
|
new GetUserAccountNames(),
|
||||||
|
new NewLmsSetup(),
|
||||||
|
new GetQuizPage(),
|
||||||
|
new GetQuizData(),
|
||||||
|
new ImportAsExam(),
|
||||||
|
new SaveExam(),
|
||||||
|
new GetExam(),
|
||||||
|
new GetExamPage());
|
||||||
|
|
||||||
|
final Result<List<EntityName>> userNamesResult = restService
|
||||||
|
.getBuilder(GetUserAccountNames.class)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(userNamesResult);
|
||||||
|
assertFalse(userNamesResult.hasError());
|
||||||
|
|
||||||
|
final String userId = userNamesResult.get()
|
||||||
|
.stream()
|
||||||
|
.filter(userName -> "examSupport2".equals(userName.name))
|
||||||
|
.findFirst()
|
||||||
|
.map(EntityName::getModelId)
|
||||||
|
.orElse(null);
|
||||||
|
|
||||||
|
// check quizzes are defines
|
||||||
|
final Result<Page<QuizData>> quizPageCall = restService
|
||||||
|
.getBuilder(GetQuizPage.class)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(quizPageCall);
|
||||||
|
assertFalse(quizPageCall.hasError());
|
||||||
|
final Page<QuizData> quizzes = quizPageCall.get();
|
||||||
|
assertFalse(quizzes.isEmpty());
|
||||||
|
final QuizData quizData = quizzes.content.get(0);
|
||||||
|
assertNotNull(quizData);
|
||||||
|
assertEquals("Demo Quiz 1", quizData.name);
|
||||||
|
|
||||||
|
// import quiz as exam
|
||||||
|
final Result<Exam> newExamResult = restService
|
||||||
|
.getBuilder(ImportAsExam.class)
|
||||||
|
.withFormParam(QuizData.QUIZ_ATTR_LMS_SETUP_ID, String.valueOf(quizData.lmsSetupId))
|
||||||
|
.withFormParam(QuizData.QUIZ_ATTR_ID, quizData.id)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(newExamResult);
|
||||||
|
assertFalse(newExamResult.hasError());
|
||||||
|
final Exam newExam = newExamResult.get();
|
||||||
|
|
||||||
|
assertEquals("Demo Quiz 1", newExam.name);
|
||||||
|
assertEquals(ExamType.UNDEFINED, newExam.type);
|
||||||
|
assertTrue(newExam.supporter.isEmpty());
|
||||||
|
|
||||||
|
// create Exam with type and supporter examSupport2
|
||||||
|
final Exam examForSave = new Exam(
|
||||||
|
newExam.id,
|
||||||
|
newExam.institutionId,
|
||||||
|
newExam.lmsSetupId,
|
||||||
|
newExam.externalId,
|
||||||
|
newExam.name,
|
||||||
|
newExam.description,
|
||||||
|
newExam.startTime,
|
||||||
|
newExam.endTime,
|
||||||
|
newExam.startURL,
|
||||||
|
ExamType.MANAGED,
|
||||||
|
null, null, null,
|
||||||
|
Utils.immutableCollectionOf(userId),
|
||||||
|
true);
|
||||||
|
|
||||||
|
final Result<Exam> savedExamResult = restService
|
||||||
|
.getBuilder(SaveExam.class)
|
||||||
|
.withBody(examForSave)
|
||||||
|
.call();
|
||||||
|
|
||||||
|
assertNotNull(savedExamResult);
|
||||||
|
assertFalse(savedExamResult.hasError());
|
||||||
|
final Exam savedExam = savedExamResult.get();
|
||||||
|
|
||||||
|
assertEquals(ExamType.MANAGED, savedExam.type);
|
||||||
|
assertFalse(savedExam.supporter.isEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue