Skip to content

Commit 0b7d7c0

Browse files
committed
Update test cases with schema validation tests
Signed-off-by: Ivan Kanakarakis <[email protected]>
1 parent 63fca12 commit 0b7d7c0

12 files changed

+191
-34
lines changed

tests/eidas_response.xml

+63
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,63 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<saml2p:Response xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol" xmlns:xs="http://www.w3.org/2001/XMLSchema" Destination="https://eidas-connector.at/post" ID="_5a15625de8618920748123042db52367" InResponseTo="_171ccc6b39b1e8f6e762c2e4ee4ded3a" IssueInstant="2015-04-30T19:27:20.159Z" Version="2.0">
3+
<saml2:Issuer xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">https://eidas-service.eu</saml2:Issuer>
4+
<ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
5+
<ds:SignedInfo>
6+
<ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
7+
<ds:SignatureMethod Algorithm="http://www.w3.org/2007/05/xmldsig-more#sha256-rsa-MGF1"/>
8+
<ds:Reference URI="#_5a15625de8618920748123042db52367">
9+
<ds:Transforms>
10+
<ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
11+
<ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#">
12+
<ec:InclusiveNamespaces xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#" PrefixList="xs"/>
13+
</ds:Transform>
14+
</ds:Transforms>
15+
<ds:DigestMethod Algorithm="http://www.w3.org/2001/04/xmlenc#sha256"/>
16+
<ds:DigestValue>t5V4hqAh4Nxjd49H/rC+N9tN/dNHBNuCOco1v1GYfFc=</ds:DigestValue>
17+
</ds:Reference>
18+
</ds:SignedInfo>
19+
<ds:SignatureValue>fQ==</ds:SignatureValue>
20+
<ds:KeyInfo>
21+
<ds:X509Data>
22+
<ds:X509Certificate>fQ==</ds:X509Certificate>
23+
</ds:X509Data>
24+
</ds:KeyInfo>
25+
</ds:Signature>
26+
<saml2p:Status>
27+
<saml2p:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/>
28+
</saml2p:Status>
29+
<saml2:Assertion xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:eidas="http://eidas.europa.eu/attributes/naturalperson" ID="_47482789069732322d02d825c9a2fafa" IssueInstant="2015-04-30T19:27:20.159Z" Version="2.0">
30+
<saml2:Issuer Format="urn:oasis:names:tc:saml2:2.0:nameid-format:entity">https://eidas-service.eu</saml2:Issuer>
31+
<saml2:Subject>
32+
<saml2:NameID Format="urn:oasis:names:tc:saml2:2.0:nameid-format:persistent">ES/AT/02635542Y</saml2:NameID>
33+
<saml2:SubjectConfirmation Method="urn:oasis:names:tc:saml2:2.0:cm:bearer">
34+
<saml2:SubjectConfirmationData InResponseTo="_171ccc6b39b1e8f6e762c2e4ee4ded3a" NotOnOrAfter="2015-04-30T19:32:20.157Z" Recipient="https://eidas-connector.eu/post"/>
35+
</saml2:SubjectConfirmation>
36+
</saml2:Subject>
37+
<saml2:Conditions NotBefore="2015-04-30T19:27:20.159Z" NotOnOrAfter="2015-04-30T19:32:20.157Z">
38+
<saml2:AudienceRestriction>
39+
<saml2:Audience>https://eidas-connector.eu/post</saml2:Audience>
40+
</saml2:AudienceRestriction>
41+
</saml2:Conditions>
42+
<saml2:AuthnStatement AuthnInstant="2015-04-30T19:27:20.159Z" SessionIndex="_5eeb319253e2d7d125e3dcc72806209a">
43+
<saml2:AuthnContext>
44+
<saml2:AuthnContextClassRef>http://eidas.europa.eu/LoA/high</saml2:AuthnContextClassRef>
45+
</saml2:AuthnContext>
46+
</saml2:AuthnStatement>
47+
<saml2:AttributeStatement>
48+
<saml2:Attribute FriendlyName="PersonIdentifier" Name="http://eidas.europa.eu/attributes/naturalperson/PersonIdentifier" NameFormat="urn:oasis:names:tc:saml2:2.0:attrname-format:uri">
49+
<saml2:AttributeValue xsi:type="eidas:PersonIdentifierType">ES/AT/02635542Y</saml2:AttributeValue>
50+
</saml2:Attribute>
51+
<saml2:Attribute FriendlyName="FamilyName" Name="http://eidas.europa.eu/attributes/naturalperson/CurrentFamilyName" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:uri">
52+
<saml2:AttributeValue xsi:type="eidas:CurrentFamilyNameType">Onasis</saml2:AttributeValue>
53+
<saml2:AttributeValue eidas:LatinScript="false" xsi:type="eidas:CurrentFamilyNameType">Ωνάσης</saml2:AttributeValue>
54+
</saml2:Attribute>
55+
<saml2:Attribute FriendlyName="FirstName" Name="http://eidas.europa.eu/attributes/naturalperson/CurrentGivenName" NameFormat="urn:oasis:names:tc:saml2:2.0:attrname-format:uri">
56+
<saml2:AttributeValue xsi:type="eidas:CurrentGivenNameType">Sarah</saml2:AttributeValue>
57+
</saml2:Attribute>
58+
<saml2:Attribute FriendlyName="DateOfBirth" Name="http://eidas.europa.eu/attributes/naturalperson/DateOfBirth" NameFormat="urn:oasis:names:tc:saml2:2.0:attrname-format:uri">
59+
<saml2:AttributeValue xsi:type="eidas:DateOfBirthType">1970-05-28</saml2:AttributeValue>
60+
</saml2:Attribute>
61+
</saml2:AttributeStatement>
62+
</saml2:Assertion>
63+
</saml2p:Response>

tests/encrypted_attribute_statement.xml

+2-2
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@
33
xmlns:ns1="http://www.w3.org/2001/04/xmlenc#"
44
xmlns:ns2="http://www.w3.org/2000/09/xmldsig#">
55
<ns0:EncryptedAttribute >
6-
<ns1:EncryptedData ID="_dcf9eb6ed26d9332d940130e0cae1ba1"
6+
<ns1:EncryptedData Id="_dcf9eb6ed26d9332d940130e0cae1ba1"
77
Type="http://www.w3.org/2001/04/xmlenc#Element">
88
<ns1:EncryptionMethod
99
Algorithm="http://www.w3.org/2001/04/xmlenc#tripledes-cbc"/>
@@ -24,7 +24,7 @@
2424
</ns1:CipherValue>
2525
</ns1:CipherData>
2626
</ns1:EncryptedData>
27-
<ns1:EncryptedKey ID="_1234">
27+
<ns1:EncryptedKey Id="_1234">
2828
<ns1:EncryptionMethod
2929
Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-1_5"/>
3030
<ns2:KeyInfo>

tests/idp_example.xml

+1-2
Original file line numberDiff line numberDiff line change
@@ -3,8 +3,7 @@
33
xmlns:ns1="http://www.w3.org/2000/09/xmldsig#"
44
entityID="http://localhost:8088/idp.xml"
55
validUntil="2036-04-12T06:06:13Z">
6-
<ns0:IDPSSODescriptor WantAuthnRequestsOnlyWithValidCert="false"
7-
WantAuthnRequestsSigned="false"
6+
<ns0:IDPSSODescriptor WantAuthnRequestsSigned="false"
87
protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
98
<ns0:KeyDescriptor use="encryption">
109
<ns1:KeyInfo>

tests/invalid_metadata_file.xml

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
this content is invalid
1+
<root>this content is invalid for a metadata file</root>

tests/metadata.xml

+7-11
Original file line numberDiff line numberDiff line change
@@ -1,9 +1,9 @@
11
<?xml version='1.0' encoding='UTF-8'?>
2-
<ns0:EntitiesDescriptor name="urn:mace:example.com:saml:test"
2+
<ns0:EntitiesDescriptor Name="urn:mace:example.com:saml:test"
33
validUntil="2036-12-04T17:31:07Z"
44
xmlns:ns0="urn:oasis:names:tc:SAML:2.0:metadata">
55
<ns0:EntityDescriptor entityID="urn:mace:example.com:saml:roland:sp">
6-
<ns0:SPSSODescriptor AuthnRequestsSigned="False" WantAssertionsSigned="True"
6+
<ns0:SPSSODescriptor AuthnRequestsSigned="false" WantAssertionsSigned="true"
77
protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
88
<ns0:KeyDescriptor>
99
<ns1:KeyInfo xmlns:ns1="http://www.w3.org/2000/09/xmldsig#">
@@ -34,11 +34,9 @@
3434
Location="http://localhost:8087/" index="0"/>
3535
</ns0:SPSSODescriptor>
3636
<ns0:Organization>
37-
<ns0:OrganizationURL xml:lang="en">http://www.example.com/
38-
</ns0:OrganizationURL>
3937
<ns0:OrganizationName xml:lang="en">Example Co</ns0:OrganizationName>
40-
<ns0:OrganizationDisplayName xml:lang="en">Example Co
41-
</ns0:OrganizationDisplayName>
38+
<ns0:OrganizationDisplayName xml:lang="en">Example Co</ns0:OrganizationDisplayName>
39+
<ns0:OrganizationURL xml:lang="en">http://www.example.com/</ns0:OrganizationURL>
4240
</ns0:Organization>
4341
<ns0:ContactPerson contactType="technical">
4442
<ns0:GivenName>Roland</ns0:GivenName>
@@ -47,7 +45,7 @@
4745
</ns0:ContactPerson>
4846
</ns0:EntityDescriptor>
4947
<ns0:EntityDescriptor entityID="urn:mace:example.com:saml:roland:idp">
50-
<ns0:IDPSSODescriptor WantAuthnRequestsSigned="True"
48+
<ns0:IDPSSODescriptor WantAuthnRequestsSigned="true"
5149
protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
5250
<ns0:KeyDescriptor>
5351
<ns1:KeyInfo xmlns:ns1="http://www.w3.org/2000/09/xmldsig#">
@@ -78,11 +76,9 @@
7876
Location="http://localhost:8088/sso/"/>
7977
</ns0:IDPSSODescriptor>
8078
<ns0:Organization>
81-
<ns0:OrganizationURL xml:lang="en">http://www.example.com/
82-
</ns0:OrganizationURL>
8379
<ns0:OrganizationName xml:lang="en">Example Co</ns0:OrganizationName>
84-
<ns0:OrganizationDisplayName xml:lang="en">Example Co
85-
</ns0:OrganizationDisplayName>
80+
<ns0:OrganizationDisplayName xml:lang="en">Example Co</ns0:OrganizationDisplayName>
81+
<ns0:OrganizationURL xml:lang="en">http://www.example.com/</ns0:OrganizationURL>
8682
</ns0:Organization>
8783
<ns0:ContactPerson contactType="technical">
8884
<ns0:GivenName>Roland</ns0:GivenName>

tests/metasp.xml

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
<?xml version="1.0" encoding="UTF-8"?>
2-
<ns0:EntitiesDescriptor xmlns:ns0="urn:oasis:names:tc:SAML:2.0:metadata" name="urn:mace:umu.se:saml:test" validUntil="2036-12-01T09:22:16Z">
2+
<ns0:EntitiesDescriptor xmlns:ns0="urn:oasis:names:tc:SAML:2.0:metadata" Name="urn:mace:umu.se:saml:test" validUntil="2036-12-01T09:22:16Z">
33
<ns0:EntityDescriptor entityID="urn:mace:umu.se:saml:roland:sp">
4-
<ns0:SPSSODescriptor AuthnRequestsSigned="False" WantAssertionsSigned="True" protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
4+
<ns0:SPSSODescriptor AuthnRequestsSigned="false" WantAssertionsSigned="true" protocolSupportEnumeration="urn:oasis:names:tc:SAML:2.0:protocol">
55
<ns0:KeyDescriptor>
66
<ns1:KeyInfo xmlns:ns1="http://www.w3.org/2000/09/xmldsig#">
77
<ns1:X509Data>

tests/saml_false_signed.xml

+3-3
Original file line numberDiff line numberDiff line change
@@ -64,15 +64,15 @@ OmuMZY0K6ERY4fNVnGEAoUZeieehC6/ljmfk14xCAlE=</ns2:SignatureValue>
6464
</ns1:AuthnStatement>
6565
<ns1:AttributeStatement>
6666
<ns1:Attribute Name="uid" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
67-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
67+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
6868
student
6969
</ns1:AttributeValue>
7070
</ns1:Attribute>
7171
<ns1:Attribute Name="eduPersonAffiliation" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
72-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
72+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
7373
member
7474
</ns1:AttributeValue>
75-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
75+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
7676
student
7777
</ns1:AttributeValue>
7878
</ns1:Attribute>

tests/saml_signed.xml

+5-5
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ OmuMZY0K6ERY4fNVnGEAoUZeieehC6/ljmfk14xCAlE=</ns2:SignatureValue>
4444
</ns2:X509Data>
4545
</ns2:KeyInfo>
4646
</ns2:Signature>
47-
<ns1:Subject>
47+
<ns1:Subject>
4848
<ns1:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:transient" SPNameQualifier="xenosmilus.umdc.umu.se">
4949
_cddc88563d433f556d4cc70c3162deabddea3b5019
5050
</ns1:NameID>
@@ -58,21 +58,21 @@ OmuMZY0K6ERY4fNVnGEAoUZeieehC6/ljmfk14xCAlE=</ns2:SignatureValue>
5858
</ns1:AudienceRestriction>
5959
</ns1:Conditions>
6060
<ns1:AuthnStatement AuthnInstant="2009-09-25T18:12:39Z" SessionIndex="_788db107b9bb1b6ab94f00deebbfe3d92c999b3041">
61-
<ns1:AuthnContext>
61+
<ns1:AuthnContext>
6262
<ns1:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:Password</ns1:AuthnContextClassRef>
6363
</ns1:AuthnContext>
6464
</ns1:AuthnStatement>
6565
<ns1:AttributeStatement>
6666
<ns1:Attribute Name="uid" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
67-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
67+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
6868
student
6969
</ns1:AttributeValue>
7070
</ns1:Attribute>
7171
<ns1:Attribute Name="eduPersonAffiliation" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
72-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
72+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
7373
member
7474
</ns1:AttributeValue>
75-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
75+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
7676
student
7777
</ns1:AttributeValue>
7878
</ns1:Attribute>

tests/saml_unsigned.xml

+5-5
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66
</ns0:Status>
77
<ns1:Assertion xmlns:ns1="urn:oasis:names:tc:SAML:2.0:assertion" ID="pfx9e022535-4b38-cc7f-41ec-9a01bcd2936d" IssueInstant="2009-10-25T18:12:39Z" Version="2.0">
88
<ns1:Issuer>http://xenosmilus.umdc.umu.se/simplesaml/saml2/idp/metadata.php</ns1:Issuer>
9-
<ns1:Subject>
9+
<ns1:Subject>
1010
<ns1:NameID Format="urn:oasis:names:tc:SAML:2.0:nameid-format:transient" SPNameQualifier="xenosmilus.umdc.umu.se">
1111
_cddc88563d433f556d4cc70c3162deabddea3b5019
1212
</ns1:NameID>
@@ -20,21 +20,21 @@
2020
</ns1:AudienceRestriction>
2121
</ns1:Conditions>
2222
<ns1:AuthnStatement AuthnInstant="2009-10-25T18:12:39Z" SessionIndex="_788db107b9bb1b6ab94f00deebbfe3d92c999b3041">
23-
<ns1:AuthnContext>
23+
<ns1:AuthnContext>
2424
<ns1:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:Password</ns1:AuthnContextClassRef>
2525
</ns1:AuthnContext>
2626
</ns1:AuthnStatement>
2727
<ns1:AttributeStatement>
2828
<ns1:Attribute Name="uid" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
29-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
29+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
3030
student
3131
</ns1:AttributeValue>
3232
</ns1:Attribute>
3333
<ns1:Attribute Name="eduPersonAffiliation" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:basic">
34-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
34+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
3535
member
3636
</ns1:AttributeValue>
37-
<ns1:AttributeValue xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
37+
<ns1:AttributeValue xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:ns2="http://www.w3.org/2001/XMLSchema-instance" ns2:type="xs:string">
3838
student
3939
</ns1:AttributeValue>
4040
</ns1:Attribute>

tests/test_30_mdstore.py

+11-1
Original file line numberDiff line numberDiff line change
@@ -167,6 +167,10 @@
167167
"class": "saml2.mdstore.MetaDataFile",
168168
"metadata": [(full_path("idp_uiinfo.xml"),)],
169169
}],
170+
"16": [{
171+
"class": "saml2.mdstore.MetaDataFile",
172+
"metadata": [(full_path("empty_metadata_file.xml"),)],
173+
}],
170174
}
171175

172176

@@ -182,9 +186,15 @@ def _fix_valid_until(xmlstring):
182186

183187

184188
def test_invalid_metadata():
189+
mds = MetadataStore(ATTRCONV, sec_config, disable_ssl_certificate_validation=True)
190+
mds.imp(METADATACONF["14"])
191+
assert mds.entities() == 0
192+
193+
194+
def test_empty_metadata():
185195
mds = MetadataStore(ATTRCONV, sec_config, disable_ssl_certificate_validation=True)
186196
with raises(SAMLError):
187-
mds.imp(METADATACONF["14"])
197+
mds.imp(METADATACONF["16"])
188198

189199

190200
def test_swami_1():

tests/test_schema_validator.py

+89
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,89 @@
1+
from pathutils import full_path as expand_full_path
2+
3+
from pytest import raises
4+
from pytest import mark
5+
6+
from saml2.xml.schema import validate as validate_doc_with_schema
7+
from saml2.xml.schema import XMLSchemaError
8+
9+
10+
@mark.parametrize("doc", ["invalid_metadata_file.xml", "empty_metadata_file.xml"])
11+
def test_invalid_saml_metadata_doc(doc):
12+
with raises(XMLSchemaError):
13+
validate_doc_with_schema(expand_full_path(doc))
14+
15+
16+
@mark.parametrize(
17+
"doc",
18+
[
19+
"InCommon-metadata.xml",
20+
"idp.xml",
21+
"idp_2.xml",
22+
"idp_aa.xml",
23+
"idp_all.xml",
24+
"idp_example.xml",
25+
"idp_soap.xml",
26+
"entity_cat_re.xml",
27+
"entity_cat_re_nren.xml",
28+
"entity_cat_rs.xml",
29+
"entity_cat_sfs_hei.xml",
30+
"entity_esi_and_coco_sp.xml",
31+
"entity_no_friendly_name_sp.xml",
32+
"extended.xml",
33+
"idp_slo_redirect.xml",
34+
"idp_uiinfo.xml",
35+
"metadata.aaitest.xml",
36+
"metadata.xml",
37+
"metadata_cert.xml",
38+
"metadata_example.xml",
39+
"metadata_sp_1.xml",
40+
"metadata_sp_1_no_encryption.xml",
41+
"metadata_sp_2.xml",
42+
"metasp.xml",
43+
"pdp_meta.xml",
44+
"servera.xml",
45+
"sp.xml",
46+
"sp_slo_redirect.xml",
47+
# XXX "swamid-1.0.xml",
48+
# XXX "swamid-2.0.xml",
49+
# TODO include the fed namespace
50+
# TODO see https://docs.oasis-open.org/wsfed/federation/v1.2/os/ws-federation-1.2-spec-os.html
51+
"urn-mace-swami.se-swamid-test-1.0-metadata.xml",
52+
"uu.xml",
53+
"vo_metadata.xml",
54+
],
55+
)
56+
def test_valid_saml_metadata_doc(doc):
57+
result = validate_doc_with_schema(expand_full_path(doc))
58+
assert result == None
59+
60+
61+
@mark.parametrize(
62+
"doc",
63+
[
64+
"attribute_response.xml",
65+
"okta_response.xml",
66+
"simplesamlphp_authnresponse.xml",
67+
"saml2_response.xml",
68+
"saml_false_signed.xml",
69+
"saml_hok.xml",
70+
"saml_hok_invalid.xml",
71+
"saml_signed.xml",
72+
"saml_unsigned.xml",
73+
],
74+
)
75+
def test_valid_saml_response_doc(doc):
76+
result = validate_doc_with_schema(expand_full_path(doc))
77+
assert result == None
78+
79+
80+
@mark.parametrize("doc", ["encrypted_attribute_statement.xml"])
81+
def test_valid_saml_partial_doc(doc):
82+
result = validate_doc_with_schema(expand_full_path(doc))
83+
assert result == None
84+
85+
86+
@mark.parametrize("doc", ["eidas_response.xml"])
87+
def test_valid_eidas_saml_response_doc(doc):
88+
result = validate_doc_with_schema(expand_full_path(doc))
89+
assert result == None

tests/vo_metadata.xml

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,11 @@
11
<?xml version='1.0' encoding='UTF-8'?>
22
<ns0:EntitiesDescriptor
3-
name="urn:mace:example.com:votest"
3+
Name="urn:mace:example.com:votest"
44
validUntil="2036-11-28T09:10:09Z"
55
xmlns:ns0="urn:oasis:names:tc:SAML:2.0:metadata">
66
<ns0:EntityDescriptor
77
entityID="urn:mace:example.com:it:tek">
8-
<ns0:AffiliationDescriptor
8+
<ns0:AffiliationDescriptor
99
affiliationOwnerID="http://vo.example.org/vo">
1010
<ns0:AffiliateMember>
1111
urn:mace:example.com:saml:aa

0 commit comments

Comments
 (0)