81 lines
2.8 KiB
C#
Raw Normal View History

//
// XmlSchemaExceptionCas.cs
// - CAS unit tests for System.Xml.Schema.XmlSchemaException
//
// Author:
// Sebastien Pouliot <sebastien@ximian.com>
//
// Copyright (C) 2005 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 NUnit.Framework;
using System;
using System.Reflection;
using System.Security;
using System.Security.Permissions;
using System.Security.Policy;
using System.Xml.Xsl;
namespace MonoCasTests.System.Xml.Xsl {
[TestFixture]
[Category ("CAS")]
public class XsltArgumentListCas {
private MethodInfo addExtensionObject;
[SetUp]
public void SetUp ()
{
if (!SecurityManager.SecurityEnabled)
Assert.Ignore ("SecurityManager.SecurityEnabled is OFF");
// this executes at fulltrust
addExtensionObject = typeof (XsltArgumentList).GetMethod ("AddExtensionObject",
new Type[2] { typeof (string), typeof (object) });
}
[Test]
[SecurityPermission (SecurityAction.Deny, SkipVerification = true)]
public void AddExtensionObject ()
{
XsltArgumentList xal = new XsltArgumentList ();
xal.AddExtensionObject ("http://www.go-mono.com", new object ());
}
// we use reflection to call XsltArgumentList as it's AddExtensionObject method
// is protected by a LinkDemand (which will be converted into full demand, i.e.
// a stack walk) when reflection is used (i.e. it gets testable).
[Test]
[SecurityPermission (SecurityAction.Deny, SkipVerification = true)]
public void AddExtensionObject_LinkDemand ()
{
// requires FullTrust, so denying anything break the requirements
Assert.IsNotNull (addExtensionObject, "AddExtensionObject");
XsltArgumentList xal = new XsltArgumentList ();
addExtensionObject.Invoke (xal, new object[2] { "http://www.go-mono.com", new object () });
}
}
}