Welcome to mirror list, hosted at ThFree Co, Russian Federation.

IndividualTests.cs « TestCases « Mono.Linker.Tests « test - github.com/mono/linker.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6a7ae9c5630893dcdef29e3b8f24220b46fe2f38 (plain)
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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
using System;
using System.Xml;
using Mono.Cecil;
using Mono.Linker.Tests.Cases.CommandLine.Mvid;
using Mono.Linker.Tests.Cases.References.Individual;
using Mono.Linker.Tests.Cases.Tracing.Individual;
using Mono.Linker.Tests.Extensions;
using Mono.Linker.Tests.TestCasesRunner;
using NUnit.Framework;

namespace Mono.Linker.Tests.TestCases
{
	[TestFixture]
	public class IndividualTests
	{
		[Test]
		public void CanSkipUnresolved ()
		{
			var testcase = CreateIndividualCase (typeof (CanSkipUnresolved));
			var result = Run (testcase);

			// We can't use the ResultChecker on the output because there will be unresolved types/methods
			// Let's just make sure that the output assembly exists.  That's enough to verify that the linker didn't throw due to the
			// missing types/methods
			if (!result.OutputAssemblyPath.Exists ())
				Assert.Fail ($"The linked assembly is missing.  Should have existed at {result.OutputAssemblyPath}");
		}

		[Test]
		public void CanEnableDependenciesDump ()
		{
			var testcase = CreateIndividualCase (typeof (CanEnableDependenciesDump));
			var result = Run (testcase);

			var outputPath = result.OutputAssemblyPath.Parent.Combine (XmlDependencyRecorder.DefaultDependenciesFileName);
			if (!outputPath.Exists ())
				Assert.Fail ($"The dependency dump file is missing.  Expected it to exist at {outputPath}");
		}

		[Test]
		public void CanDumpDependenciesToUncompressedXml ()
		{
			var testcase = CreateIndividualCase (typeof (CanDumpDependenciesToUncompressedXml));
			var result = Run (testcase);

			var outputPath = result.OutputAssemblyPath.Parent.Combine ("linker-dependencies.xml");
			if (!outputPath.Exists ())
				Assert.Fail($"The dependency dump file is missing.  Expected it to exist at {outputPath}");

			// Do a basic check to verify that the contents of the file are uncompressed xml
			using (var reader = new XmlTextReader (outputPath.ToString ())) {
				reader.Read ();
				reader.Read ();
				reader.Read ();
				Assert.That (reader.Name, Is.EqualTo ("dependencies"), $"Expected to be at the dependencies element, but the current node name is `{reader.Name}`");
			}
		}

		[Test]
		public void CanEnableReducedTracing ()
		{
			var testcase = CreateIndividualCase (typeof (CanEnableReducedTracing));
			var result = Run (testcase);

			// Note: This name needs to match what is setup in the test case arguments to the linker
			const string expectedDependenciesFileName = "linker-dependencies.xml";
			var outputPath = result.OutputAssemblyPath.Parent.Combine (expectedDependenciesFileName);
			if (!outputPath.Exists ())
				Assert.Fail($"The dependency dump file is missing.  Expected it to exist at {outputPath}");

			// Let's go a little bit further and make sure it looks like reducing tracking actually worked.
			// This is intentionally a loose assertion.  This test isn't meant to verify how reduced tracing works,
			// it's here to make sure that enabling the option enables the behavior.
			var lineCount = outputPath.ReadAllLines ().Length;

			// When reduced tracing is not enabled there are around 16k of lines in the output file.
			// With reduced tracing there should be less than 65, but to be safe, we'll check for less than 200.
			// Reduced tracing on System.Private.CoreLib.dll produces about 130 lines just for NullableAttribute usages.
			const int expectedMaxLines = 200;
			Assert.That (lineCount, Is.LessThan (expectedMaxLines), $"There were `{lineCount}` lines in the dump file.  This is more than expected max of {expectedMaxLines} and likely indicates reduced tracing was not enabled.  Dump file can be found at: {outputPath}");
		}

		[Test]
		public void DeterministicMvidWorks()
		{
			var testCase = CreateIndividualCase (typeof (DeterministicMvidWorks));
			var result = Run (testCase, out TestRunner runner);

			var originalMvid = GetMvid (result.InputAssemblyPath);
			var firstOutputMvid = GetMvid (result.OutputAssemblyPath);
			Assert.That (firstOutputMvid, Is.Not.EqualTo (originalMvid));
			
			var result2 = runner.Relink(result);
			
			var secondOutputMvid = GetMvid(result2.OutputAssemblyPath);
			Assert.That (secondOutputMvid, Is.Not.EqualTo (originalMvid));
			// The id should match the first output since we relinked the same assembly
			Assert.That (secondOutputMvid, Is.EqualTo (firstOutputMvid));
		}

		[Test]
		public void NewMvidWorks ()
		{
			var testCase = CreateIndividualCase (typeof (NewMvidWorks));
			var result = Run (testCase, out TestRunner runner);

			var originalMvid = GetMvid (result.InputAssemblyPath);
			var firstOutputMvid = GetMvid (result.OutputAssemblyPath);
			Assert.That (firstOutputMvid, Is.Not.EqualTo (originalMvid));
			
			var result2 = runner.Relink (result);
			
			var secondOutputMvid = GetMvid (result2.OutputAssemblyPath);
			Assert.That (secondOutputMvid, Is.Not.EqualTo (originalMvid));
			Assert.That (secondOutputMvid, Is.Not.EqualTo (firstOutputMvid));
		}

		[Test]
		public void RetainMvidWorks ()
		{
			var testCase = CreateIndividualCase (typeof (RetainMvid));
			var result = Run (testCase, out TestRunner runner);

			var originalMvid = GetMvid (result.InputAssemblyPath);
			var firstOutputMvid = GetMvid (result.OutputAssemblyPath);
			Assert.That (firstOutputMvid, Is.EqualTo (originalMvid));
			
			var result2 = runner.Relink (result);
			
			var secondOutputMvid = GetMvid (result2.OutputAssemblyPath);
			Assert.That (secondOutputMvid, Is.EqualTo (originalMvid));
			Assert.That (secondOutputMvid, Is.EqualTo (firstOutputMvid));
		}

		[Test]
		public void DefaultMvidBehavior ()
		{
			var testCase = CreateIndividualCase (typeof (NewMvidWorks));
			var result = Run (testCase, out TestRunner runner);

			var originalMvid = GetMvid (result.InputAssemblyPath);
			var firstOutputMvid = GetMvid (result.OutputAssemblyPath);
			Assert.That (firstOutputMvid, Is.Not.EqualTo (originalMvid));
			
			var result2 = runner.Relink (result);
			
			var secondOutputMvid = GetMvid (result2.OutputAssemblyPath);
			Assert.That (secondOutputMvid, Is.Not.EqualTo (originalMvid));
			Assert.That (secondOutputMvid, Is.Not.EqualTo (firstOutputMvid));
		}

		protected Guid GetMvid (NPath assemblyPath)
		{
			using (var assembly = AssemblyDefinition.ReadAssembly (assemblyPath))
			{
				return assembly.MainModule.Mvid;
			}
		}

		private TestCase CreateIndividualCase (Type testCaseType)
		{
			return TestDatabase.CreateCollector ().CreateIndividualCase (testCaseType);
		}

		protected LinkedTestCaseResult Run (TestCase testCase)
		{
			TestRunner runner;
			return Run (testCase, out runner);
		}
		
		protected virtual LinkedTestCaseResult Run (TestCase testCase, out TestRunner runner)
		{
			runner = new TestRunner (new ObjectFactory ());
			return runner.Run (testCase);
		}
	}
}