diff options
author | Andrij Abyzov <aabyzov@slb.com> | 2021-03-04 00:43:32 +0100 |
---|---|---|
committer | Rob Mensching <rob@firegiant.com> | 2021-03-05 07:38:37 -0800 |
commit | 722ffb41bb83879d3e086b6faffd45ee38c5a5b6 (patch) | |
tree | 5c4a3f6170b7bcedff029423533d66e02e0ed6e4 /src/test | |
parent | 816bfd180f132a9b07aaa573f5ac0f5948195764 (diff) | |
download | wix-722ffb41bb83879d3e086b6faffd45ee38c5a5b6.tar.gz wix-722ffb41bb83879d3e086b6faffd45ee38c5a5b6.tar.bz2 wix-722ffb41bb83879d3e086b6faffd45ee38c5a5b6.zip |
Create unit test for WixVariable resolution issue #6376
Diffstat (limited to 'src/test')
6 files changed, 105 insertions, 0 deletions
diff --git a/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.en-us.wxl b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.en-us.wxl new file mode 100644 index 00000000..38c12ac1 --- /dev/null +++ b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.en-us.wxl | |||
@@ -0,0 +1,11 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | ||
2 | |||
3 | <!-- | ||
4 | This file contains the declaration of all the localizable strings. | ||
5 | --> | ||
6 | <WixLocalization xmlns="http://wixtoolset.org/schemas/v4/wxl" Culture="en-US"> | ||
7 | |||
8 | <String Id="DowngradeError">A newer version of [ProductName] is already installed.</String> | ||
9 | <String Id="FeatureTitle">MsiPackage</String> | ||
10 | |||
11 | </WixLocalization> | ||
diff --git a/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.wxs b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.wxs new file mode 100644 index 00000000..e1cf7394 --- /dev/null +++ b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/Package.wxs | |||
@@ -0,0 +1,21 @@ | |||
1 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
2 | <Package Name="MsiPackage" Codepage="1252" Language="1033" Version="1.0.0.0" Manufacturer="Example Corporation" UpgradeCode="047730a5-30fe-4a62-a520-da9381b8226a" Compressed="no" InstallerVersion="200" Scope="perMachine"> | ||
3 | |||
4 | |||
5 | <MajorUpgrade DowngradeErrorMessage="!(loc.DowngradeError)" /> | ||
6 | |||
7 | <Feature Id="ProductFeature" Title="!(loc.FeatureTitle)"> | ||
8 | <ComponentGroupRef Id="ProductComponents" /> | ||
9 | </Feature> | ||
10 | |||
11 | <WixVariable Id="TestFile" Value="test2.txt" /> | ||
12 | </Package> | ||
13 | |||
14 | <Fragment> | ||
15 | <Directory Id="TARGETDIR" Name="SourceDir"> | ||
16 | <Directory Id="ProgramFilesFolder"> | ||
17 | <Directory Id="INSTALLFOLDER" Name="MsiPackage" /> | ||
18 | </Directory> | ||
19 | </Directory> | ||
20 | </Fragment> | ||
21 | </Wix> | ||
diff --git a/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/PackageComponents.wxs b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/PackageComponents.wxs new file mode 100644 index 00000000..df867923 --- /dev/null +++ b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/PackageComponents.wxs | |||
@@ -0,0 +1,14 @@ | |||
1 | <?xml version="1.0" encoding="utf-8"?> | ||
2 | <Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"> | ||
3 | <Fragment> | ||
4 | <Binary Id="Test.txt" SourceFile="!(wix.TestFile=test.txt)" /> | ||
5 | <ComponentGroup Id="ProductComponents" Directory="INSTALLFOLDER"> | ||
6 | <Component> | ||
7 | <File Source="test.txt" /> | ||
8 | </Component> | ||
9 | <Component Id="Shared.dll" Shared="yes"> | ||
10 | <File Name="Shared.dll" Source="test.txt" /> | ||
11 | </Component> | ||
12 | </ComponentGroup> | ||
13 | </Fragment> | ||
14 | </Wix> | ||
diff --git a/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test.txt b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test.txt new file mode 100644 index 00000000..cd0db0e1 --- /dev/null +++ b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test.txt | |||
@@ -0,0 +1 @@ | |||
This is test.txt. \ No newline at end of file | |||
diff --git a/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test2.txt b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test2.txt new file mode 100644 index 00000000..eab3a9b5 --- /dev/null +++ b/src/test/WixToolsetTest.CoreIntegration/TestData/WixVariableOverride/data/test2.txt | |||
@@ -0,0 +1 @@ | |||
This is test2.txt. \ No newline at end of file | |||
diff --git a/src/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs b/src/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs index 6ae2c0b8..52460843 100644 --- a/src/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs +++ b/src/test/WixToolsetTest.CoreIntegration/WixlibFixture.cs | |||
@@ -144,6 +144,63 @@ namespace WixToolsetTest.CoreIntegration | |||
144 | } | 144 | } |
145 | } | 145 | } |
146 | 146 | ||
147 | [Fact(Skip = "https://github.com/wixtoolset/issues/issues/6376")] | ||
148 | public void CanOverridePathWixVariable() | ||
149 | { | ||
150 | var folder = TestData.Get(@"TestData\WixVariableOverride"); | ||
151 | |||
152 | using (var fs = new DisposableFileSystem()) | ||
153 | { | ||
154 | var baseFolder = fs.GetFolder(); | ||
155 | var intermediateFolder = Path.Combine(baseFolder, "obj"); | ||
156 | var wixlibPath = Path.Combine(intermediateFolder, @"test.wixlib"); | ||
157 | |||
158 | var result = WixRunner.Execute(new[] | ||
159 | { | ||
160 | "build", | ||
161 | Path.Combine(folder, "PackageComponents.wxs"), | ||
162 | "-bf", | ||
163 | "-bindpath", Path.Combine(folder, "data"), | ||
164 | "-intermediateFolder", intermediateFolder, | ||
165 | "-o", wixlibPath, | ||
166 | }); | ||
167 | |||
168 | result.AssertSuccess(); | ||
169 | |||
170 | var wixlib = Intermediate.Load(wixlibPath); | ||
171 | |||
172 | Assert.True(wixlib.HasLevel(IntermediateLevels.Compiled)); | ||
173 | Assert.True(wixlib.HasLevel(IntermediateLevels.Combined)); | ||
174 | Assert.False(wixlib.HasLevel(IntermediateLevels.Linked)); | ||
175 | Assert.False(wixlib.HasLevel(IntermediateLevels.Resolved)); | ||
176 | |||
177 | result = WixRunner.Execute(new[] | ||
178 | { | ||
179 | "build", | ||
180 | Path.Combine(folder, "Package.wxs"), | ||
181 | "-loc", Path.Combine(folder, "Package.en-us.wxl"), | ||
182 | "-lib", Path.Combine(intermediateFolder, @"test.wixlib"), | ||
183 | "-bindpath", Path.Combine(folder, "data"), | ||
184 | "-intermediateFolder", intermediateFolder, | ||
185 | "-o", Path.Combine(baseFolder, @"bin\test.msi") | ||
186 | }); | ||
187 | |||
188 | result.AssertSuccess(); | ||
189 | |||
190 | var intermediate = Intermediate.Load(Path.Combine(baseFolder, @"bin\test.wixpdb")); | ||
191 | |||
192 | Assert.False(intermediate.HasLevel(IntermediateLevels.Compiled)); | ||
193 | Assert.False(intermediate.HasLevel(IntermediateLevels.Combined)); | ||
194 | Assert.True(intermediate.HasLevel(IntermediateLevels.Linked)); | ||
195 | Assert.True(intermediate.HasLevel(IntermediateLevels.Resolved)); | ||
196 | |||
197 | var section = intermediate.Sections.Single(); | ||
198 | |||
199 | var wixFile = section.Symbols.OfType<BinarySymbol>().First(); | ||
200 | Assert.Equal(Path.Combine(folder, @"data\test2.txt"), wixFile.Data.Path); | ||
201 | } | ||
202 | } | ||
203 | |||
147 | [Fact] | 204 | [Fact] |
148 | public void CanBuildWithExtensionUsingWixlib() | 205 | public void CanBuildWithExtensionUsingWixlib() |
149 | { | 206 | { |