more tests

This commit is contained in:
anhefti 2022-03-08 11:20:16 +01:00
parent e0057211a1
commit fd64554395
5 changed files with 205 additions and 2 deletions

View file

@ -36,7 +36,7 @@ public class Tuple<T> {
return (TT) this; return (TT) this;
} }
return null; throw new IllegalArgumentException("Type mismatch: " + this.getClass() + " to " + type);
} }
@Override @Override

View file

@ -9,18 +9,53 @@
package ch.ethz.seb.sebserver.gbl.util; package ch.ethz.seb.sebserver.gbl.util;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals;
import static org.junit.jupiter.api.Assertions.fail;
import org.junit.Test; import org.junit.Test;
public class Tuple3Test { public class Tuple3Test {
@Test @Test
public void test() { public void test3() {
final Tuple3<String> candidate = new Tuple3<>("1", "2", "3"); final Tuple3<String> candidate = new Tuple3<>("1", "2", "3");
assertEquals("(1, 2, 3)", candidate.toString()); assertEquals("(1, 2, 3)", candidate.toString());
assertEquals("1", candidate.get_1()); assertEquals("1", candidate.get_1());
assertEquals("2", candidate.get_2()); assertEquals("2", candidate.get_2());
assertEquals("3", candidate.get_3()); assertEquals("3", candidate.get_3());
final Tuple3<String> candidate1 = new Tuple3<>("1", "2", "3");
final Tuple3<String> candidate2 = new Tuple3<>("4", "5", "6");
assertEquals(candidate, candidate1);
assertNotEquals(candidate1, candidate2);
try {
@SuppressWarnings("unchecked")
final Tuple<String> tuple = candidate.adaptTo(Tuple.class);
fail("Should fail here");
} catch (final Exception e) {
assertEquals(
"Type mismatch: class ch.ethz.seb.sebserver.gbl.util.Tuple3 to class ch.ethz.seb.sebserver.gbl.util.Tuple",
e.getMessage());
}
}
@Test
public void test2() {
final Tuple<String> candidate = new Tuple<>("1", "2");
assertEquals("(1, 2)", candidate.toString());
assertEquals("1", candidate.get_1());
assertEquals("2", candidate.get_2());
final Tuple<String> candidate1 = new Tuple<>("1", "2");
final Tuple<String> candidate2 = new Tuple3<>("4", "5", "6");
assertEquals(candidate, candidate1);
assertNotEquals(candidate1, candidate2);
@SuppressWarnings("unchecked")
final Tuple3<String> tuple = candidate2.adaptTo(Tuple3.class);
assertEquals("(4, 5, 6)", tuple.toString());
} }
} }

View file

@ -72,6 +72,8 @@ 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;
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.gbl.model.sebconfig.CertificateInfo;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.CertificateInfo.CertificateType;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigCreationInfo; import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigCreationInfo;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigKey; import ch.ethz.seb.sebserver.gbl.model.sebconfig.ConfigKey;
import ch.ethz.seb.sebserver.gbl.model.sebconfig.Configuration; import ch.ethz.seb.sebserver.gbl.model.sebconfig.Configuration;
@ -152,6 +154,11 @@ import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.logs.GetUserLogPa
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.quiz.GetQuizData; 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.quiz.ImportAsExam;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.AddCertificate;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.GetCertificate;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.GetCertificateNames;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.GetCertificatePage;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.cert.RemoveCertificate;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.ActivateClientConfig; import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.ActivateClientConfig;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.DeactivateClientConfig; import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.DeactivateClientConfig;
import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.ExportClientConfig; import ch.ethz.seb.sebserver.gui.service.remote.webservice.api.seb.clientconfig.ExportClientConfig;
@ -2950,4 +2957,145 @@ public class UseCasesIntegrationTest extends GuiIntegrationTest {
} }
@Test
@Order(23)
// *************************************
// Use Case 23: Certificates
// - check certificates (list) is empty
// - upload test certificate
// - check certificates
// - upload identity certificate
// - check certificates
// - create new connection config with identity certigficate encryption
// - donwload connection config with identity certigficate encryption
// - remove certificate
public void testUsecase23_Certificates() throws Exception {
final RestServiceImpl restService = createRestServiceForUser(
"TestInstAdmin",
"987654321",
new GetCertificate(),
new GetCertificateNames(),
new GetCertificatePage(),
new RemoveCertificate(),
new AddCertificate(),
new NewClientConfig(),
new SaveClientConfig(),
new ActivateClientConfig(),
new DeactivateClientConfig(),
new ExportClientConfig());
// - check certificates (list) is empty
Page<CertificateInfo> certificates = restService
.getBuilder(GetCertificatePage.class)
.call()
.getOrThrow();
assertNotNull(certificates);
assertTrue(certificates.content.isEmpty());
// - upload test certificate
InputStream inputStream = new ClassPathResource("sebserver-test.cer").getInputStream();
final CertificateInfo newCert = restService
.getBuilder(AddCertificate.class)
.withBody(inputStream)
.withHeader(API.IMPORT_FILE_ATTR_NAME, "sebserver-test.cer")
.call()
.getOrThrow();
assertNotNull(newCert);
assertEquals("test.anhefti.sebserver", newCert.alias);
assertTrue(newCert.types.contains(CertificateType.DIGITAL_SIGNATURE));
assertTrue(newCert.types.contains(CertificateType.DATA_ENCIPHERMENT));
// - check certificates
certificates = restService
.getBuilder(GetCertificatePage.class)
.call()
.getOrThrow();
assertNotNull(certificates);
assertFalse(certificates.content.isEmpty());
final CertificateInfo certificateInfo = certificates.content.get(0);
assertEquals("test.anhefti.sebserver", certificateInfo.alias);
// - upload identity certificate
inputStream = new ClassPathResource("testIdentity123.pfx").getInputStream();
final CertificateInfo newCert1 = restService
.getBuilder(AddCertificate.class)
.withBody(inputStream)
.withHeader(API.IMPORT_FILE_ATTR_NAME, "testIdentity123.pfx")
.withHeader(API.IMPORT_PASSWORD_ATTR_NAME, "123")
.call()
.getOrThrow();
assertNotNull(newCert1);
assertEquals("*.2mdn.net", newCert1.alias);
assertTrue(newCert1.types.contains(CertificateType.DATA_ENCIPHERMENT_PRIVATE_KEY));
// - check certificates
certificates = restService
.getBuilder(GetCertificatePage.class)
.call()
.getOrThrow();
assertNotNull(certificates);
assertFalse(certificates.content.isEmpty());
assertTrue(certificates.content.size() == 2);
// - create new connection config with identity certigficate encryption
final SEBClientConfig newConfig = restService
.getBuilder(NewClientConfig.class)
.withFormParam(Domain.SEB_CLIENT_CONFIGURATION.ATTR_NAME, "Connection Config with Cert")
.withFormParam(SEBClientConfig.ATTR_ENCRYPT_CERTIFICATE_ALIAS, "*.2mdn.net")
.withFormParam(SEBClientConfig.ATTR_CONFIG_PURPOSE, SEBClientConfig.ConfigPurpose.START_EXAM.name())
.call()
.getOrThrow();
assertNotNull(newConfig);
assertEquals("*.2mdn.net", newConfig.encryptCertificateAlias);
// - donwload connection config with identity certigficate encryption
final Result<Boolean> exportResponse = restService
.getBuilder(ExportClientConfig.class)
.withURIVariable(API.PARAM_MODEL_ID, newConfig.getModelId())
.withResponseExtractor(response -> {
final InputStream input = response.getBody();
final List<String> readLines = IOUtils.readLines(input, "UTF-8");
assertNotNull(readLines);
assertFalse(readLines.isEmpty());
return true;
})
.call();
assertNotNull(exportResponse);
assertTrue(exportResponse.get());
// - remmove certificate
final CertificateInfo cert = restService
.getBuilder(GetCertificate.class)
.withURIVariable(API.CERTIFICATE_ALIAS, "test.anhefti.sebserver")
//.withURIVariable(API.PARAM_MODEL_ID, newCert.getModelId())
.call()
.getOrThrow();
assertNotNull(cert);
assertEquals("test.anhefti.sebserver", cert.alias);
final Result<Collection<EntityKey>> removeCert = restService
.getBuilder(RemoveCertificate.class)
.withFormParam(API.CERTIFICATE_ALIAS, "test.anhefti.sebserver")
.call();
assertNotNull(removeCert);
assertFalse(removeCert.hasError());
final Collection<EntityKey> collection = removeCert.get();
assertFalse(collection.isEmpty());
final EntityKey next = collection.iterator().next();
assertEquals(
"EntityKey [modelId=test.anhefti.sebserver, entityType=CERTIFICATE]",
next.toString());
}
} }

View file

@ -0,0 +1,20 @@
-----BEGIN CERTIFICATE-----
MIIDPzCCAiegAwIBAgIQUQvCtw+rLZBG+inNAge2ojANBgkqhkiG9w0BAQsFADAh
MR8wHQYDVQQDDBZ0ZXN0LmFuaGVmdGkuc2Vic2VydmVyMB4XDTIxMDUwNjEyMjEw
MVoXDTIyMDUwNjEyNDEwMVowITEfMB0GA1UEAwwWdGVzdC5hbmhlZnRpLnNlYnNl
cnZlcjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOnoI00+x4AO4glp
/n6H6KoOKAsPwJhwa2im5Xe6hU1EODzGxCSjklnzwj0Qa2a5nBkutoek3sAaKHY5
6EaoijjjglckmsxopYygbHho0K1dgnO0Ip2lT1Yq3IZ21hbPbzQXpPkmkjsgA1qD
/WGtLfSz6AC0rv3/4ODQzjTnMpBge/nI0E2+SVxAe25tzCMiAclrAVDYzAIbNo4F
5efZ30RTXMd4GSxNP7YHn+TIYdX+W36eyGEisAuOJWzQfLbXgiOkISGRv/Nvmla7
YXRmCcXOkWCr5QwZshHulD6Zx3m0rM1eNqNuiV7Lxpz5XtDV9m+GJ+ucE+8DGu2Q
AlSZ260CAwEAAaNzMHEwDgYDVR0PAQH/BAQDAgWgMB0GA1UdJQQWMBQGCCsGAQUF
BwMCBggrBgEFBQcDATAhBgNVHREEGjAYghZ0ZXN0LmFuaGVmdGkuc2Vic2VydmVy
MB0GA1UdDgQWBBQ3mdxUQV1Fh9dNOQFz6xnAeC/LfjANBgkqhkiG9w0BAQsFAAOC
AQEAOlh0Nq5ysBNniUFNnvHidayWcI6V1MMg31EOc43rzzBdrssPflFFXm6AfX6M
yFOyeHfU8FRxp3IAiRi/jc+w0GUnIpm803SoxIbalI/lVEV8GhVhKEEe1l9QWs07
oKS1Wu5u3XKF/AwjNs1jhtNobo4jvAVylgRc/fxsXM7SwyFfkMMiwml0rBDzokrM
y6obH2UdK8sRGL7xTGAmOBMRVlI+EiNd8Cc42wARuMMamIF/SEOSzgfR4kMTzSzB
GTM2CnNQsE2Jfg2Uz+fD8wT5roqFBFux1AY8ZW2VjLppupUuZMRx3OWAR77Bh/01
2iZ4+3rMmgqErbkgCB6fDLGh9g==
-----END CERTIFICATE-----

Binary file not shown.