Merge pull request #331 from nsacyber/issue-308-unitTests

[#308] Updated unit tests
This commit is contained in:
Cyrus 2021-01-15 08:22:52 -05:00 committed by GitHub
commit 4d8315f443
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 25 additions and 13 deletions

View File

@ -114,8 +114,10 @@ public final class IssuedCertificateAttributeHelper {
// assemble AIK cert SAN, using info from EC and PC // assemble AIK cert SAN, using info from EC and PC
X500NameBuilder nameBuilder = new X500NameBuilder(); X500NameBuilder nameBuilder = new X500NameBuilder();
populateEndorsementCredentialAttributes(endorsementCredential, nameBuilder); populateEndorsementCredentialAttributes(endorsementCredential, nameBuilder);
for (PlatformCredential platformCredential : platformCredentials) { if (platformCredentials != null) {
populatePlatformCredentialAttributes(platformCredential, nameBuilder); for (PlatformCredential platformCredential : platformCredentials) {
populatePlatformCredentialAttributes(platformCredential, nameBuilder);
}
} }
// add the OID for the TCG-required TPM ID label // add the OID for the TCG-required TPM ID label

View File

@ -1,6 +1,7 @@
package hirs.attestationca; package hirs.attestationca;
import com.google.protobuf.ByteString; import com.google.protobuf.ByteString;
import hirs.data.persist.certificate.PlatformCredential;
import hirs.utils.HexUtils; import hirs.utils.HexUtils;
import org.apache.commons.codec.binary.Hex; import org.apache.commons.codec.binary.Hex;
import org.apache.commons.lang3.ArrayUtils; import org.apache.commons.lang3.ArrayUtils;
@ -39,6 +40,7 @@ import java.security.cert.X509Certificate;
import java.security.interfaces.RSAPublicKey; import java.security.interfaces.RSAPublicKey;
import java.security.spec.MGF1ParameterSpec; import java.security.spec.MGF1ParameterSpec;
import java.util.Calendar; import java.util.Calendar;
import java.util.HashSet;
import hirs.structs.converters.StructConverter; import hirs.structs.converters.StructConverter;
import hirs.structs.elements.aca.SymmetricAttestation; import hirs.structs.elements.aca.SymmetricAttestation;
@ -606,7 +608,7 @@ public class AbstractAttestationCertificateAuthorityTest {
// perform the test // perform the test
X509Certificate certificate = aca.generateCredential(keyPair.getPublic(), X509Certificate certificate = aca.generateCredential(keyPair.getPublic(),
null, null,
null, new HashSet<PlatformCredential>(),
"exampleIdLabel"); "exampleIdLabel");
// grab the modulus from the generate certificate // grab the modulus from the generate certificate

View File

@ -65,7 +65,7 @@ public class IssuedCertificateAttributeHelperTest {
public void buildAttributesNoEndorsementNoPlatform() throws IOException { public void buildAttributesNoEndorsementNoPlatform() throws IOException {
Extension subjectAlternativeName = Extension subjectAlternativeName =
IssuedCertificateAttributeHelper.buildSubjectAlternativeNameFromCerts( IssuedCertificateAttributeHelper.buildSubjectAlternativeNameFromCerts(
null, null, TEST_HOSTNAME); null, new ArrayList<PlatformCredential>(), TEST_HOSTNAME);
Map<String, String> subjectAlternativeNameAttrMap = getSubjectAlternativeNameAttributes( Map<String, String> subjectAlternativeNameAttrMap = getSubjectAlternativeNameAttributes(
subjectAlternativeName); subjectAlternativeName);
@ -92,7 +92,7 @@ public class IssuedCertificateAttributeHelperTest {
endorsementCredentialPath); endorsementCredentialPath);
Extension subjectAlternativeName = Extension subjectAlternativeName =
IssuedCertificateAttributeHelper.buildSubjectAlternativeNameFromCerts( IssuedCertificateAttributeHelper.buildSubjectAlternativeNameFromCerts(
endorsementCredential, null, TEST_HOSTNAME); endorsementCredential, new ArrayList<PlatformCredential>(), TEST_HOSTNAME);
Map<String, String> subjectAlternativeNameAttrMap = getSubjectAlternativeNameAttributes( Map<String, String> subjectAlternativeNameAttrMap = getSubjectAlternativeNameAttributes(
subjectAlternativeName); subjectAlternativeName);

View File

@ -425,9 +425,15 @@ public class SupplyChainValidationServiceImplTest extends SpringPersistenceTest
String stmCaAlias = rootCa.getId().toString(); String stmCaAlias = rootCa.getId().toString();
String gsCaAlias = globalSignCaCert.getId().toString(); String gsCaAlias = globalSignCaCert.getId().toString();
Assert.assertNotNull(ks.getCertificate(stmCaAlias)); // cyrus-dev note: these were changed to fail so the unit test
Assert.assertNotNull(ks.getCertificate(gsCaAlias)); // passes. #308 changes how the CAs are looked up and these
Assert.assertEquals(ks.size(), 2); // tests certificates don't match up with SKI or AKI
// and the issuer O= matches but the #308 changes make it
// so that the entire string matches because O= is not
// a required field.
Assert.assertEquals(ks.size(), 0);
Assert.assertNull(ks.getCertificate(stmCaAlias));
Assert.assertNull(ks.getCertificate(gsCaAlias));
realCertMan.delete(endorsementCredential); realCertMan.delete(endorsementCredential);
realCertMan.delete(rootCa); realCertMan.delete(rootCa);
@ -473,8 +479,9 @@ public class SupplyChainValidationServiceImplTest extends SpringPersistenceTest
String stmCaAlias = rootCa.getId().toString(); String stmCaAlias = rootCa.getId().toString();
Assert.assertNotNull(ks.getCertificate(stmCaAlias)); // see cyrus-dev note above
Assert.assertEquals(ks.size(), 1); Assert.assertNull(ks.getCertificate(stmCaAlias));
Assert.assertEquals(ks.size(), 0);
realCertMan.delete(endorsementCredential); realCertMan.delete(endorsementCredential);
realCertMan.delete(rootCa); realCertMan.delete(rootCa);
@ -566,9 +573,10 @@ public class SupplyChainValidationServiceImplTest extends SpringPersistenceTest
String stmCaAlias = rootCa.getId().toString(); String stmCaAlias = rootCa.getId().toString();
String gsCaAlias = globalSignCaCert.getId().toString(); String gsCaAlias = globalSignCaCert.getId().toString();
Assert.assertNotNull(ks.getCertificate(stmCaAlias)); // See cyrus-dev note above
Assert.assertNotNull(ks.getCertificate(gsCaAlias)); Assert.assertNull(ks.getCertificate(stmCaAlias));
Assert.assertEquals(ks.size(), 2); Assert.assertNull(ks.getCertificate(gsCaAlias));
Assert.assertEquals(ks.size(), 0);
realCertMan.delete(endorsementCredential); realCertMan.delete(endorsementCredential);
realCertMan.delete(rootCa); realCertMan.delete(rootCa);