forked from scriptcs/scriptcs
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathFileSystemTests.cs
More file actions
117 lines (97 loc) · 4.16 KB
/
FileSystemTests.cs
File metadata and controls
117 lines (97 loc) · 4.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using Should;
using Xunit;
namespace ScriptCs.Tests
{
public class FileSystemTests
{
public class GetWorkingDirectoryMethod
{
private readonly FileSystem _fileSystem = new FileSystem();
[Fact]
public void ShouldProperlyConstructWorkingDirectoryIfScriptIsRunFromRelativePath()
{
const string PathToMyScriptFolder = @"..\my_script";
try
{
Directory.CreateDirectory(PathToMyScriptFolder);
_fileSystem.GetWorkingDirectory(PathToMyScriptFolder)
.ShouldEqual(Path.GetFullPath(Path.Combine(Environment.CurrentDirectory, PathToMyScriptFolder)));
}
finally
{
if (Directory.Exists(PathToMyScriptFolder))
{
Directory.Delete(PathToMyScriptFolder);
}
}
}
[Fact]
public void ShouldReturnWorkingDirectoryIfPathIsInvalid()
{
var invalidPaths = new List<string> { string.Empty, " ", null };
foreach (var invalidPath in invalidPaths)
{
_fileSystem.GetWorkingDirectory(invalidPath).ShouldEqual(_fileSystem.CurrentDirectory);
}
}
[Fact]
public void ReturnsCorrectWorkingDirectory()
{
var workingPath = string.Format(@".{0}working_dir", Path.DirectorySeparatorChar);
var existingPath = string.Format(@".{0}existing_dir{0}", Path.DirectorySeparatorChar);
var existingFile = string.Format(@".{0}existing_file.txt", Path.DirectorySeparatorChar);
string workingDir = Path.GetFullPath(Path.Combine(Environment.CurrentDirectory, workingPath));
string existingDirectoryPath = Path.GetFullPath(Path.Combine(workingDir, existingPath));
string existingFilePath = Path.GetFullPath(Path.Combine(workingDir, existingFile));
try
{
Directory.CreateDirectory(workingDir);
Directory.CreateDirectory(existingDirectoryPath);
File.Create(existingFilePath).Dispose();
_fileSystem.GetWorkingDirectory(existingDirectoryPath).ShouldEqual(existingDirectoryPath);
_fileSystem.GetWorkingDirectory(existingFilePath).ShouldEqual(
Path.GetFullPath(Path.Combine(Environment.CurrentDirectory, workingDir)));
}
finally
{
if (Directory.Exists(existingDirectoryPath))
{
Directory.Delete(existingDirectoryPath);
}
if (File.Exists(existingFilePath))
{
File.Delete(existingFilePath);
}
if (Directory.Exists(workingDir))
{
Directory.Delete(workingDir);
}
}
}
[Fact]
public void ReturnsCorrectWorkingDirectoryIfPathDoesNotExist()
{
var tempPath = Path.GetTempPath();
var nonExistantFilePath = Path.Combine(tempPath, "i_dont_exist.txt");
_fileSystem.GetWorkingDirectory(nonExistantFilePath)
.ShouldEqual(tempPath.TrimEnd(Path.DirectorySeparatorChar));
}
}
public class SplitLinesMethod
{
private readonly FileSystem _fileSystem = new FileSystem();
[Fact]
public void ReturnsCorrectLines()
{
var fileContentsLin = "using System;\nusing System.IO;";
var fileContentsWin = "using System;\r\nusing System.IO;";
_fileSystem.SplitLines(fileContentsLin).Count().ShouldEqual(2);
_fileSystem.SplitLines(fileContentsWin).Count().ShouldEqual(2);
}
}
}
}