Skip to content

Commit 838c13e

Browse files
committed
See #134. Fix some tests
1 parent e5e25f0 commit 838c13e

File tree

6 files changed

+73
-15
lines changed

6 files changed

+73
-15
lines changed

core/src/test/java/com/onelogin/saml2/test/authn/AuthnResponseTest.java

Lines changed: 30 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -78,6 +78,23 @@ public void testConstructor() throws IOException, Error, XPathExpressionExceptio
7878
assertTrue(samlResponse instanceof SamlResponse);
7979
}
8080

81+
/**
82+
* Tests that a invalid SAMLResponse with not expected elements fails
83+
*
84+
* @throws Exception
85+
*
86+
* @see com.onelogin.saml2.authn.SamlResponse
87+
*/
88+
@Test
89+
public void testOInvalidResponseWithNonExpectedElementsFail() throws Exception {
90+
expectedEx.expect(ValidationError.class);
91+
expectedEx.expectMessage("SAML Response could not be processed");
92+
93+
Saml2Settings settings = new SettingsBuilder().fromFile("config/config.my.properties").build();
94+
String samlResponseEncoded = Util.getFileAsString("data/responses/invalids/wrapped_response_2.xml.base64");
95+
96+
SamlResponse samlResponse = new SamlResponse(settings, newHttpRequest(samlResponseEncoded));
97+
}
8198
/**
8299
* Tests the constructor of SamlResponse
83100
* Case: Encrypted assertion but no key
@@ -906,28 +923,28 @@ public void testGetAttributesDuplicatedNames() throws IOException, Error, XPathE
906923

907924
HashMap<String, List<String>> attributes = samlResponse.getAttributes();
908925
}
909-
926+
910927
/**
911-
* Tests the isValid method of SamlResponse
928+
* Tests that queryAssertion method of SamlResponse
929+
* Case: Elements retrieved are covered by a Signature
912930
*
913931
* @throws Exception
914932
*
915-
* @see com.onelogin.saml2.authn.SamlResponse#isValid
933+
* @see com.onelogin.saml2.authn.SamlResponse#queryAssertion
916934
*/
917935
@Test
918-
public void testOnlyRetrieveAssertionWithIDThatMatchesSignatureReference() throws Exception {
919-
expectedEx.expect(ValidationError.class);
920-
expectedEx.expectMessage("SAML Response could not be processed");
921-
936+
public void testOnlyRetrieveAssertionWithIDThatMatchesSignatureReference() throws Exception {
922937
Saml2Settings settings = new SettingsBuilder().fromFile("config/config.my.properties").build();
923-
String samlResponseEncoded = Util.getFileAsString("data/responses/invalids/wrapped_response_2.xml.base64");
938+
String samlResponseEncoded = Util.getFileAsString("data/responses/signed_assertion_response_with_2_assertions.xml.base64");
924939
SamlResponse samlResponse = new SamlResponse(settings, newHttpRequest(samlResponseEncoded));
925-
926-
String nameID = samlResponse.getNameId();
927-
assertFalse(samlResponse.isValid());
928-
assertFalse("root@example.com".equals(nameID));
940+
assertEquals("492882615acf31c8096b627245d76ae53036c090", samlResponse.getNameId());
941+
942+
samlResponseEncoded = Util.getFileAsString("data/responses/signed_assertion_response_with_2_assertions_differrent_order.xml.base64");
943+
samlResponse = new SamlResponse(settings, newHttpRequest(samlResponseEncoded));
944+
assertEquals("492882615acf31c8096b627245d76ae53036c090", samlResponse.getNameId());
929945
}
930-
946+
947+
931948
/**
932949
* Tests the isValid method of SamlResponse
933950
*

core/src/test/java/com/onelogin/saml2/test/logout/LogoutRequestTest.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -327,10 +327,10 @@ public void testGetNameIdDataNoKey() throws Exception {
327327
@Test
328328
public void testGetNameIdDataWrongKey() throws Exception {
329329
expectedEx.expect(Exception.class);
330-
expectedEx.expectMessage("algid parse error, not a sequence");
330+
expectedEx.expectMessage("Not able to decrypt the EncryptedID and get a NameID");
331331

332332
String logoutRequestStr = Util.getFileAsString("data/logout_requests/logout_request_encrypted_nameid.xml");
333-
String keyString = Util.getFileAsString("data/misc/sp3.key");
333+
String keyString = Util.getFileAsString("data/misc/sp4.key");
334334
PrivateKey key = Util.loadPrivateKey(keyString);
335335
String nameIdDataStr = LogoutRequest.getNameIdData(logoutRequestStr, key).toString();
336336
}

core/src/test/java/com/onelogin/saml2/test/util/UtilsTest.java

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,10 +37,13 @@
3737
import javax.xml.parsers.ParserConfigurationException;
3838
import javax.xml.xpath.XPathExpressionException;
3939

40+
import org.junit.rules.ExpectedException;
41+
4042
import org.apache.commons.codec.binary.Base64;
4143
import org.apache.xml.security.exceptions.XMLSecurityException;
4244
import org.apache.xml.security.signature.XMLSignatureException;
4345
import org.joda.time.DateTime;
46+
import org.junit.Rule;
4447
import org.junit.Test;
4548
import org.w3c.dom.Document;
4649
import org.w3c.dom.Element;
@@ -49,6 +52,7 @@
4952
import org.w3c.dom.NodeList;
5053
import org.xml.sax.SAXException;
5154

55+
import com.onelogin.saml2.logout.LogoutRequest;
5256
import com.onelogin.saml2.util.Constants;
5357
import com.onelogin.saml2.util.SchemaFactory;
5458
import com.onelogin.saml2.util.Util;
@@ -58,6 +62,9 @@
5862
*/
5963
public class UtilsTest {
6064

65+
@Rule
66+
public ExpectedException expectedEx = ExpectedException.none();
67+
6168
/**
6269
* Tests the loadXML method for XXE/XEE attacks
6370
* Case: Use of ENTITY
@@ -614,6 +621,22 @@ public void testLoadPrivateKeyPKCS1() throws URISyntaxException, GeneralSecurity
614621
PrivateKey keyObject1 = Util.loadPrivateKey(key);
615622
assertNull(keyObject1);
616623
}
624+
625+
/**
626+
* Tests the loadPrivateKey method
627+
*
628+
* @throws Exception
629+
*
630+
* @see com.onelogin.saml2.logout.LogoutRequest#getNameIdData
631+
*/
632+
@Test
633+
public void testGetNameIdDataWrongKey() throws Exception {
634+
expectedEx.expect(Exception.class);
635+
expectedEx.expectMessage("algid parse error, not a sequence");
636+
637+
String keyString = Util.getFileAsString("data/misc/sp3.key");
638+
PrivateKey key = Util.loadPrivateKey(keyString);
639+
}
617640

618641
/**
619642
* Tests load Private Key String with heads.
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
-----BEGIN PRIVATE KEY-----
2+
MIICeQIBADANBgkqhkiG9w0BAQEFAASCAmMwggJfAgEAAoGBAOOkQGlAE+6AXoNQ
3+
rjpYpwHHeZ+J/3KybDqJkya3D9+v8N4I5hZmoaNioVCzfmOmauPX07U7JmZY3PsP
4+
VCs9Er1hCUBYV0Le2976/8EK2nW/xcQ2aE/2UseiNRppmo7VdqhtoHjoJS0R+Ve8
5+
3quC80Bdq9uDQgvZpPCDAl36bmGtAgMBAAECgYEApxMSQy1Ic6+7rl00wpX2XRPu
6+
a+14ktHpJT17xtpsyBv1iMC3PpGs6KGnC/fxN2oY4YiyVT1Ifa2S4qDpgaKdcQZ3
7+
O81bMWKkpVTALLOJ6IYGj6M5YdiZUKcHmor+fXM+APylLbt9UPHd6PSflHgNyHLU
8+
6IbAFnK5NZS+xp6pk/ECQQD7QQoFEoS7ks/ZZ+DaVuHRFNPyRQkKTEWkS27gPfCC
9+
HYvRsU8LCf5jUB7FXJIwYYzK8jk27ykSPrsx6kjwvSZfAkEA5/EIS5wekTCIylJc
10+
B28DKuwtSsu7JjZxo9votRAEsfAc/9/digU1tkRs63SuWOwtTN5nSXJNULcKeRKo
11+
KIn7cwJBANvNQSvA0JebzvN9mcrI2RJlKym11TvKD960ExJffWkG2gufFuwsWPye
12+
2dyEqGtk25urnfv966tHb9IyCI96mfcCQQCUnfwrvoBTld7AjR9M4BQOh8DJwVtM
13+
s+wDC6DDi90GSw254q7ohkgRXyzPfjdM4SBxtbxG8oeZ5X8/bvXy698DAkEAuyMk
14+
I1wrQYNPMqhrX5xt/Soxw+nTGDBQClCG7YbJlmgGGbw/pm/XpLbq/inovjSwi0Nd
15+
g3DBgBh/yox3J/PB5g==
16+
-----END PRIVATE KEY-----
Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion" ID="pfx1ff1da4a-010e-428c-16eb-75f31f16567a" Version="2.0" IssueInstant="2014-02-19T01:37:01Z" Destination="http://localhost:8080/java-saml-jspsample/acs.jsp" InResponseTo="ONELOGIN_5fe9d6e499b2f0913206aab3f7191729049bb807"><saml:Issuer>https://pitbulk.no-ip.org/simplesaml/saml2/idp/metadata.php</saml:Issuer><samlp:Status><samlp:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></samlp:Status><saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxf94cd805-c22b-8198-6eff-194096928ec5" Version="2.0" IssueInstant="2014-02-19T01:37:01Z"><saml:Issuer>https://pitbulk.no-ip.org/simplesaml/saml2/idp/metadata.php</saml:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
  <ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
    <ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
  <ds:Reference URI="#pfxf94cd805-c22b-8198-6eff-194096928ec5"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>xarsZtmYNTXSrLhO/kzu1sAs268=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>V0eLv4EwqYtCGtJ3LN5IS5stlGYj0E4+ctG8G8SqKD4UlDkfQ+OZ9Y1rkK463W5Mh35LqYurn3YjM09tyCjWm3trC3Gc7C9gsmwEYbuOJ8RoriatNGtCVHRZE9XQ7k9lgzgHMIqQOwJFpo0v0P2t+A/cwW05c0p17d1tGet/HP4=</ds:SignatureValue>
<ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIICgTCCAeoCCQCbOlrWDdX7FTANBgkqhkiG9w0BAQUFADCBhDELMAkGA1UEBhMCTk8xGDAWBgNVBAgTD0FuZHJlYXMgU29sYmVyZzEMMAoGA1UEBxMDRm9vMRAwDgYDVQQKEwdVTklORVRUMRgwFgYDVQQDEw9mZWlkZS5lcmxhbmcubm8xITAfBgkqhkiG9w0BCQEWEmFuZHJlYXNAdW5pbmV0dC5ubzAeFw0wNzA2MTUxMjAxMzVaFw0wNzA4MTQxMjAxMzVaMIGEMQswCQYDVQQGEwJOTzEYMBYGA1UECBMPQW5kcmVhcyBTb2xiZXJnMQwwCgYDVQQHEwNGb28xEDAOBgNVBAoTB1VOSU5FVFQxGDAWBgNVBAMTD2ZlaWRlLmVybGFuZy5ubzEhMB8GCSqGSIb3DQEJARYSYW5kcmVhc0B1bmluZXR0Lm5vMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDivbhR7P516x/S3BqKxupQe0LONoliupiBOesCO3SHbDrl3+q9IbfnfmE04rNuMcPsIxB161TdDpIesLCn7c8aPHISKOtPlAeTZSnb8QAu7aRjZq3+PbrP5uW3TcfCGPtKTytHOge/OlJbo078dVhXQ14d1EDwXJW1rRXuUt4C8QIDAQABMA0GCSqGSIb3DQEBBQUAA4GBACDVfp86HObqY+e8BUoWQ9+VMQx1ASDohBjwOsg2WykUqRXF+dLfcUH9dWR63CtZIKFDbStNomPnQz7nbK+onygwBspVEbnHuUihZq3ZUdmumQqCw4Uvs/1Uvq3orOo/WJVhTyvLgFVK2QarQ4/67OZfHd7R+POBXhophSMv1ZOo</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml:Subject><saml:NameID SPNameQualifier="http://localhost:8080/java-saml-jspsample/metadata.jsp" Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">492882615acf31c8096b627245d76ae53036c090</saml:NameID><saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml:SubjectConfirmationData NotOnOrAfter="2023-08-23T06:57:01Z" Recipient="http://localhost:8080/java-saml-jspsample/acs.jsp" InResponseTo="ONELOGIN_5fe9d6e499b2f0913206aab3f7191729049bb807"/></saml:SubjectConfirmation></saml:Subject><saml:Conditions NotBefore="2014-02-19T01:36:31Z" NotOnOrAfter="2023-08-23T06:57:01Z"><saml:AudienceRestriction><saml:Audience>http://localhost:8080/java-saml-jspsample/metadata.jsp</saml:Audience></saml:AudienceRestriction></saml:Conditions><saml:AuthnStatement AuthnInstant="2014-02-19T01:37:01Z" SessionNotOnOrAfter="2023-08-23T06:57:01Z" SessionIndex="_6273d77b8cde0c333ec79d22a9fa0003b9fe2d75cb"><saml:AuthnContext><saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:Password</saml:AuthnContextClassRef></saml:AuthnContext></saml:AuthnStatement><saml:AttributeStatement><saml:Attribute Name="uid" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">smartin</saml:AttributeValue></saml:Attribute><saml:Attribute Name="mail" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">smartin@yaco.es</saml:AttributeValue></saml:Attribute><saml:Attribute Name="cn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">Sixto3</saml:AttributeValue></saml:Attribute><saml:Attribute Name="sn" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">Martin2</saml:AttributeValue></saml:Attribute><saml:Attribute Name="eduPersonAffiliation" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic"><saml:AttributeValue xsi:type="xs:string">user</saml:AttributeValue><saml:AttributeValue xsi:type="xs:string">admin</saml:AttributeValue></saml:Attribute></saml:AttributeStatement></saml:Assertion><saml:Assertion xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xs="http://www.w3.org/2001/XMLSchema" ID="pfxf22cd805-c22b-8198-6eff-194096928a21" Version="2.0" IssueInstant="2014-02-19T01:37:01Z"><saml:Issuer>https://pitbulk.no-ip.org/simplesaml/saml2/idp/metadata.php</saml:Issuer><saml:Subject><saml:NameID SPNameQualifier="http://localhost:8080/java-saml-jspsample/metadata.jsp" Format="urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress">wrong_value</saml:NameID><saml:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml:SubjectConfirmationData NotOnOrAfter="2023-08-23T06:57:01Z" Recipient="http://localhost:8080/java-saml-jspsample/acs.jsp" InResponseTo="ONELOGIN_5fe9d6e499b2f0913206aab3f7191729049bb807"/></saml:SubjectConfirmation></saml:Subject><saml:Conditions NotBefore="2014-02-19T01:36:31Z" NotOnOrAfter="2023-08-23T06:57:01Z"><saml:AudienceRestriction><saml:Audience>http://localhost:8080/java-saml-jspsample/metadata.jsp</saml:Audience></saml:AudienceRestriction></saml:Conditions><saml:AuthnStatement AuthnInstant="2014-02-19T01:37:01Z" SessionNotOnOrAfter="2023-08-23T06:57:01Z" SessionIndex="_6273d77b8cde0c333ec79d22a9fa0003b9fe2d75cb"><saml:AuthnContext><saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:Password</saml:AuthnContextClassRef></saml:AuthnContext></saml:AuthnStatement></saml:Assertion></samlp:Response>

0 commit comments

Comments
 (0)