Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

254 lines
7.0 KiB
C#

//
// FileStreamCas.cs -CAS unit tests for System.IO.FileStream
//
// 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.IO;
using System.Reflection;
using System.Security;
using System.Security.Permissions;
using System.Threading;
namespace MonoCasTests.System.IO {
[TestFixture]
[Category ("CAS")]
public class FileStreamCas {
private MonoTests.System.IO.FileStreamTest fst;
private const int timeout = 30000;
private string message;
private string readfile;
private string writefile;
static ManualResetEvent reset;
[TestFixtureSetUp]
public void FixtureSetUp ()
{
// this occurs with a "clean" stack (full trust)
fst = new MonoTests.System.IO.FileStreamTest ();
reset = new ManualResetEvent (false);
readfile = Path.GetTempFileName ();
writefile = Path.GetTempFileName ();
}
[TestFixtureTearDown]
public void FixtureTearDown ()
{
reset.Close ();
if (File.Exists (readfile))
File.Delete (readfile);
if (File.Exists (writefile))
File.Delete (writefile);
}
[SetUp]
public void SetUp ()
{
if (!SecurityManager.SecurityEnabled)
Assert.Ignore ("SecurityManager.SecurityEnabled is OFF");
}
// Partial Trust Tests - i.e. call "normal" unit with reduced privileges
[Test]
[ExpectedException (typeof (SecurityException))]
public void PartialTrust_DenyUnrestricted_Failure ()
{
try {
// SetUp/TearDown requires FileIOPermission
fst.SetUp ();
// so does the call but that's the test ;-)
CallRestricted (fst);
}
finally {
fst.TearDown ();
}
}
[PermissionSet (SecurityAction.Deny, Unrestricted = true)]
private void CallRestricted (MonoTests.System.IO.FileStreamTest fst)
{
fst.TestDefaultProperties ();
}
[Test]
[FileIOPermission (SecurityAction.PermitOnly, Unrestricted = true)]
public void PartialTrust_PermitOnly_FileIOPermission_Success ()
{
fst.SetUp ();
fst.TestCtr ();
fst.CtorAccess1Read2Read ();
fst.Write ();
fst.Length ();
fst.Flush ();
fst.TestDefaultProperties ();
fst.TestLock ();
fst.Seek ();
fst.TestSeek ();
fst.TestClose ();
fst.PositionAfterSetLength ();
fst.ReadBytePastEndOfStream ();
fst.TearDown ();
}
[Test]
[FileIOPermission (SecurityAction.PermitOnly, Unrestricted = true)]
[SecurityPermission (SecurityAction.PermitOnly, UnmanagedCode = true)]
public void PartialTrust_PermitOnly_FileIOPermissionUnmanagedCode_Success ()
{
fst.SetUp ();
fst.TestFlushNotOwningHandle ();
fst.TearDown ();
}
// test Demand by denying the required permissions
[Test]
[SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
[ExpectedException (typeof (SecurityException))]
public void Ctor_IntPtrFileAccess ()
{
new FileStream (IntPtr.Zero, FileAccess.Read);
}
[Test]
[SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
[ExpectedException (typeof (SecurityException))]
public void Ctor_IntPtrFileAccessBool ()
{
new FileStream (IntPtr.Zero, FileAccess.Read, false);
}
[Test]
[SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
[ExpectedException (typeof (SecurityException))]
public void Ctor_IntPtrFileAccessBoolInt ()
{
new FileStream (IntPtr.Zero, FileAccess.Read, false, 0);
}
[Test]
[SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
[ExpectedException (typeof (SecurityException))]
public void Ctor_IntPtrFileAccessBoolIntBool ()
{
new FileStream (IntPtr.Zero, FileAccess.Read, false, 0, false);
}
// we use reflection to call FileStream as the Handle property 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, UnmanagedCode = true)]
[ExpectedException (typeof (SecurityException))]
public void Handle ()
{
FileStream fs = File.OpenWrite (Path.GetTempFileName ());
try {
MethodInfo mi = typeof (FileStream).GetProperty ("Handle").GetGetMethod ();
mi.Invoke (fs, null);
}
finally {
fs.Close ();
}
}
// async tests (for stack propagation)
private void ReadCallback (IAsyncResult ar)
{
FileStream s = (FileStream)ar.AsyncState;
s.EndRead (ar);
try {
// can we do something bad here ?
Assert.IsNotNull (Environment.GetEnvironmentVariable ("USERNAME"));
message = "Expected a SecurityException";
}
catch (SecurityException) {
message = null;
reset.Set ();
}
catch (Exception e) {
message = e.ToString ();
}
}
[Test]
[EnvironmentPermission (SecurityAction.Deny, Read = "USERNAME")]
public void AsyncRead ()
{
FileStream fs = new FileStream (readfile, FileMode.OpenOrCreate);
message = "AsyncRead";
reset.Reset ();
IAsyncResult r = fs.BeginRead (new byte[0], 0, 0, new AsyncCallback (ReadCallback), fs);
Assert.IsNotNull (r, "IAsyncResult");
if (!reset.WaitOne (timeout, true))
Assert.Ignore ("Timeout");
Assert.IsNull (message, message);
fs.Close ();
}
private void WriteCallback (IAsyncResult ar)
{
FileStream s = (FileStream)ar.AsyncState;
s.EndWrite (ar);
try {
// can we do something bad here ?
Assert.IsNotNull (Environment.GetEnvironmentVariable ("USERNAME"));
message = "Expected a SecurityException";
}
catch (SecurityException) {
message = null;
reset.Set ();
}
catch (Exception e) {
message = e.ToString ();
}
}
[Test]
[EnvironmentPermission (SecurityAction.Deny, Read = "USERNAME")]
public void AsyncWrite ()
{
FileStream fs = new FileStream (writefile, FileMode.OpenOrCreate);
message = "AsyncWrite";
reset.Reset ();
IAsyncResult r = fs.BeginWrite (new byte[0], 0, 0, new AsyncCallback (WriteCallback), fs);
Assert.IsNotNull (r, "IAsyncResult");
if (!reset.WaitOne (timeout, true))
Assert.Ignore ("Timeout");
Assert.IsNull (message, message);
fs.Close ();
}
}
}