| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- //
- // SamlAuthorizationDecisionStatementTest.cs
- //
- // Author:
- // Atsushi Enomoto <[email protected]>
- //
- // Copyright (C) 2006 Novell, Inc. http://www.novell.com
- //
- // Permission is hereby granted, free of charge, to any person obtaining
- // a copy of this software and associated documentation files (the
- // "Software"), to deal in the Software without restriction, including
- // without limitation the rights to use, copy, modify, merge, publish,
- // distribute, sublicense, and/or sell copies of the Software, and to
- // permit persons to whom the Software is furnished to do so, subject to
- // the following conditions:
- //
- // The above copyright notice and this permission notice shall be
- // included in all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
- // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
- // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
- // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- //
- using System;
- using System.Globalization;
- using System.IO;
- using System.IdentityModel.Claims;
- using System.IdentityModel.Selectors;
- using System.IdentityModel.Tokens;
- using System.Xml;
- using NUnit.Framework;
- namespace MonoTests.System.IdentityModel.Tokens
- {
- [TestFixture]
- public class SamlAuthorizationDecisionStatementTest
- {
- XmlDictionaryWriter CreateWriter (StringWriter sw)
- {
- return XmlDictionaryWriter.CreateDictionaryWriter (XmlWriter.Create (sw));
- }
- XmlDictionaryReader CreateReader (string xml)
- {
- return XmlDictionaryReader.CreateDictionaryReader (XmlReader.Create (new StringReader (xml)));
- }
- [Test]
- public void DefaultValues ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- Assert.AreEqual (default (SamlAccessDecision), a.AccessDecision, "#1");
- Assert.IsNull (a.Evidence, "#2");
- Assert.IsNull (a.Resource, "#3");
- Assert.IsNull (a.SamlSubject, "#4");
- Assert.AreEqual (0, a.SamlActions.Count, "#5");
- }
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void ConstructorNullSubject ()
- {
- new SamlAuthorizationDecisionStatement (null, "resource", default (SamlAccessDecision), null);
- }
- [Test]
- [ExpectedException (typeof (SecurityTokenException))] // ???? it is inconsistent behavior with others...
- public void ConstructorNullResource ()
- {
- new SamlAuthorizationDecisionStatement (
- new SamlSubject (), null, default (SamlAccessDecision), new SamlAction [0]);
- }
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void ConstructorNullActions ()
- {
- new SamlAuthorizationDecisionStatement (
- new SamlSubject (), "resource", default (SamlAccessDecision), null);
- }
- [Test]
- [ExpectedException (typeof (ArgumentException))]
- public void ConstructorActionsContainNull ()
- {
- new SamlAuthorizationDecisionStatement (
- new SamlSubject (), "resource", default (SamlAccessDecision), new SamlAction [] {null});
- }
- [Test]
- [ExpectedException (typeof (ArgumentException))]
- public void SetResourceEmpty ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- a.Resource = String.Empty;
- }
- [Test]
- public void SetEvidenceNull ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- a.Evidence = null;
- }
- [Test]
- [ExpectedException (typeof (SecurityTokenException))]
- public void WriteXmlNoSubject ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- StringWriter sw = new StringWriter ();
- using (XmlDictionaryWriter dw = CreateWriter (sw)) {
- a.WriteXml (dw, new SamlSerializer (), null);
- }
- }
- [Test]
- [ExpectedException (typeof (SecurityTokenException))]
- public void WriteXmlNoResource ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- a.SamlSubject = new SamlSubject ("myFormat", "myQualifier", "myName");
- StringWriter sw = new StringWriter ();
- using (XmlDictionaryWriter dw = CreateWriter (sw)) {
- a.WriteXml (dw, new SamlSerializer (), null);
- }
- }
- [Test]
- [ExpectedException (typeof (SecurityTokenException))]
- public void WriteXmlNoAction ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- a.SamlSubject = new SamlSubject ("myFormat", "myQualifier", "myName");
- a.Resource = "resource";
- StringWriter sw = new StringWriter ();
- using (XmlDictionaryWriter dw = CreateWriter (sw)) {
- a.WriteXml (dw, new SamlSerializer (), null);
- }
- }
- [Test]
- public void WriteXml1 ()
- {
- SamlAuthorizationDecisionStatement a = new SamlAuthorizationDecisionStatement ();
- a.SamlSubject = new SamlSubject ("myFormat", "myQualifier", "myName");
- a.Resource = "resource";
- a.SamlActions.Add (new SamlAction ("myAction"));
- a.Evidence = new SamlEvidence (new string [] {"myID"});
- StringWriter sw = new StringWriter ();
- using (XmlDictionaryWriter dw = CreateWriter (sw)) {
- a.WriteXml (dw, new SamlSerializer (), null);
- }
- Assert.AreEqual (String.Format ("<?xml version=\"1.0\" encoding=\"utf-16\"?><saml:AuthorizationDecisionStatement Decision=\"Permit\" Resource=\"resource\" xmlns:saml=\"{0}\"><saml:Subject><saml:NameIdentifier Format=\"myFormat\" NameQualifier=\"myQualifier\">myName</saml:NameIdentifier></saml:Subject><saml:Action>myAction</saml:Action><saml:Evidence><saml:AssertionIDReference>myID</saml:AssertionIDReference></saml:Evidence></saml:AuthorizationDecisionStatement>", SamlConstants.Namespace), sw.ToString ());
- }
- [Test]
- public void ReadXml1 ()
- {
- SamlSerializer ser = new SamlSerializer ();
- string xml = String.Format ("<saml:AuthorizationDecisionStatement Decision=\"Deny\" Resource=\"resource\" xmlns:saml=\"{0}\"><saml:Subject><saml:NameIdentifier Format=\"myFormat\" NameQualifier=\"myQualifier\">myName</saml:NameIdentifier></saml:Subject><saml:Action>myAction</saml:Action><saml:Evidence><saml:AssertionIDReference>myID</saml:AssertionIDReference></saml:Evidence></saml:AuthorizationDecisionStatement>", SamlConstants.Namespace);
- XmlDictionaryReader reader = CreateReader (xml);
- reader.MoveToContent ();
- SamlAuthorizationDecisionStatement s =
- new SamlAuthorizationDecisionStatement ();
- s.ReadXml (reader, ser, null, null);
- Assert.AreEqual (SamlAccessDecision.Deny, s.AccessDecision, "#1");
- Assert.IsNotNull (s.SamlSubject, "#2");
- Assert.AreEqual (1, s.SamlActions.Count, "#3");
- Assert.AreEqual ("myAction", s.SamlActions [0].Action, "#4");
- Assert.IsNotNull (s.Evidence, "#5");
- Assert.AreEqual (1, s.Evidence.AssertionIdReferences.Count, "#6");
- Assert.AreEqual ("myID", s.Evidence.AssertionIdReferences [0], "#7");
- Assert.AreEqual ("resource", s.Resource, "#8");
- }
- }
- }
|