forked from sarbian/ModuleManager
-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathStreamLoggerTest.cs
More file actions
105 lines (92 loc) · 3.12 KB
/
Copy pathStreamLoggerTest.cs
File metadata and controls
105 lines (92 loc) · 3.12 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
/*
This file is part of Module Manager /L
© 2018-2023 LisiasT
© 2013-2018 Sarbian; Blowfish
© 2013 ialdabaoth
Module Manager /L is licensed as follows:
* GPL 3.0 : https://www.gnu.org/licenses/gpl-3.0.txt
Module Manager /L is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
You should have received a copy of the GNU General Public License 3.0
along with Module Manager /L. If not, see <https://www.gnu.org/licenses/>.
*/
using System;
using System.IO;
using Xunit;
using NSubstitute;
using ModuleManager.Logging;
namespace ModuleManagerTests.Logging
{
public class StreamLoggerTest
{
[Fact]
public void TestConstructor__StreamNull()
{
Assert.Throws<ArgumentNullException>(delegate
{
new StreamLogger(null);
});
}
[Fact]
public void TestConstructor__CantWrite()
{
using (MemoryStream stream = new MemoryStream(new byte[0], false))
{
Assert.Throws<ArgumentException>(delegate
{
new StreamLogger(stream);
});
}
}
[Fact]
public void TestLog__AlreadyDisposed()
{
using (MemoryStream stream = new MemoryStream(new byte[0], true))
{
StreamLogger streamLogger = new StreamLogger(stream);
streamLogger.Dispose();
InvalidOperationException ex = Assert.Throws<InvalidOperationException>(delegate
{
streamLogger.Log(Substitute.For<ILogMessage>());
});
Assert.Contains("Object has already been disposed", ex.Message);
}
}
[Fact]
public void TestLog()
{
ILogMessage message = Substitute.For<ILogMessage>();
message.ToLogString().Returns("[OMG wtf] bbq");
byte[] bytes = new byte[15];
using (MemoryStream stream = new MemoryStream(bytes, true))
{
using (StreamLogger streamLogger = new StreamLogger(stream))
{
streamLogger.Log(message);
}
}
using (MemoryStream stream = new MemoryStream(bytes, false))
{
using (StreamReader reader = new StreamReader(stream))
{
string result = reader.ReadToEnd().Trim('\r', '\n', '\0');
Assert.Equal("[OMG wtf] bbq", result);
}
}
}
[Fact]
public void TestLog__MessageNull()
{
using (MemoryStream stream = new MemoryStream(new byte[0], true))
{
StreamLogger streamLogger = new StreamLogger(stream);
ArgumentNullException ex = Assert.Throws<ArgumentNullException>(delegate
{
streamLogger.Log(null);
});
Assert.Equal("message", ex.ParamName);
}
}
}
}