Path constraints perform tests on paths, without reference to any actual files or directories. This allows testing paths that are created by an application for reference or later use, without any effect on the environment.
Path constraints are intended to work across multiple file systems, and convert paths to a canonical form before comparing them.
It is usually not necessary to know the file system of the paths in order to compare them. Where necessary, the programmer may use the IgnoreCase and RespectCase modifiers to provide behavior other than the system default.
Tests that two paths are equivalent.
SamePathConstraint( string expectedPath )
Is.SamePath( string expectedPath )
...IgnoreCase ...RespectCase
Assert.That( "/folder1/./junk/../folder2", Is.SamePath( "/folder1/folder2" ) ); Assert.That( "/folder1/./junk/../folder2/x", Is.Not.SamePath( "/folder1/folder2" ) ); Assert.That( @"C:\folder1\folder2", Is.SamePath( @"C:\Folder1\Folder2" ).IgnoreCase ); Assert.That( "/folder1/folder2", Is.Not.SamePath( "/Folder1/Folder2" ).RespectCase );
Tests that one path is under another path.
SubPathConstraint( string expectedPath )
Is.SubPath( string expectedPath )
...IgnoreCase ...RespectCase
Assert.That( "/folder1/./junk/../folder2", Is.SubPath( "/folder1/folder2" ) ); Assert.That( "/folder1/junk/folder2", Is.Not.SubPath( "/folder1/folder2" ) ); Assert.That( @"C:\folder1\folder2\folder3", Is.SubPath( @"C:\Folder1\Folder2/Folder3" ).IgnoreCase ); Assert.That( "/folder1/folder2/folder3", Is.Not.SubPath( "/Folder1/Folder2/Folder3" ).RespectCase );
Tests that one path is equivalent another path or that it is under it.
SamePathOrUnderConstraint( string expectedPath )
Is.SamePathOrUnder( string expectedPath )
...IgnoreCase ...RespectCase
Assert.That( "/folder1/./junk/../folder2", Is.SamePathOrUnder( "/folder1/folder2" ) ); Assert.That( "/folder1/junk/../folder2/./folder3", Is.SamePathOrUnder( "/folder1/folder2" ) ); Assert.That( "/folder1/junk/folder2/folder3", Is.Not.SamePathOrUnder( "/folder1/folder2" ) ); Assert.That( @"C:\folder1\folder2\folder3", Is.SamePathOrUnder( @"C:\Folder1\Folder2" ).IgnoreCase ); Assert.That( "/folder1/folder2/folder3", Is.Not.SamePathOrUnder( "/Folder1/Folder2" ).RespectCase );