diff options
Diffstat (limited to 'src')
24 files changed, 1275 insertions, 9 deletions
diff --git a/src/internal/SetBuildNumber/Directory.Packages.props.pp b/src/internal/SetBuildNumber/Directory.Packages.props.pp index f77fcffa..d06990fe 100644 --- a/src/internal/SetBuildNumber/Directory.Packages.props.pp +++ b/src/internal/SetBuildNumber/Directory.Packages.props.pp | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | 19 | ||
| 20 | <PackageVersion Include="WixToolset.Data" Version="{packageversion}" /> | 20 | <PackageVersion Include="WixToolset.Data" Version="{packageversion}" /> |
| 21 | <PackageVersion Include="WixToolset.Extensibility" Version="{packageversion}" /> | 21 | <PackageVersion Include="WixToolset.Extensibility" Version="{packageversion}" /> |
| 22 | <PackageVersion Include="WixToolset.Versioning" Version="{packageversion}" /> | ||
| 22 | 23 | ||
| 23 | <PackageVersion Include="WixToolset.Burn" Version="{packageversion}" /> | 24 | <PackageVersion Include="WixToolset.Burn" Version="{packageversion}" /> |
| 24 | <PackageVersion Include="WixToolset.Dnc.HostGenerator" Version="{packageversion}" /> | 25 | <PackageVersion Include="WixToolset.Dnc.HostGenerator" Version="{packageversion}" /> |
diff --git a/src/libs/WixToolset.Versioning/WixToolset.Versioning.csproj b/src/libs/WixToolset.Versioning/WixToolset.Versioning.csproj new file mode 100644 index 00000000..2c23f391 --- /dev/null +++ b/src/libs/WixToolset.Versioning/WixToolset.Versioning.csproj | |||
| @@ -0,0 +1,14 @@ | |||
| 1 | <?xml version="1.0" encoding="utf-8"?> | ||
| 2 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | ||
| 3 | |||
| 4 | <Project Sdk="Microsoft.NET.Sdk"> | ||
| 5 | <PropertyGroup> | ||
| 6 | <TargetFrameworks>netstandard2.0</TargetFrameworks> | ||
| 7 | <TargetFrameworks Condition=" '$(Configuration)'=='Release' ">$(TargetFrameworks);net472</TargetFrameworks> | ||
| 8 | <LangVersion>7.3</LangVersion> | ||
| 9 | <Description>WiX Toolset Versioning</Description> | ||
| 10 | <DebugType>embedded</DebugType> | ||
| 11 | <PublishRepositoryUrl>true</PublishRepositoryUrl> | ||
| 12 | <CreateDocumentationFile>true</CreateDocumentationFile> | ||
| 13 | </PropertyGroup> | ||
| 14 | </Project> | ||
diff --git a/src/api/wix/WixToolset.Data/WixVersion.cs b/src/libs/WixToolset.Versioning/WixVersion.cs index a0de7a10..7333701f 100644 --- a/src/api/wix/WixToolset.Data/WixVersion.cs +++ b/src/libs/WixToolset.Versioning/WixVersion.cs | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. |
| 2 | 2 | ||
| 3 | namespace WixToolset.Data | 3 | namespace WixToolset.Versioning |
| 4 | { | 4 | { |
| 5 | using System; | 5 | using System; |
| 6 | using System.Collections.Generic; | 6 | using System.Collections.Generic; |
| @@ -11,13 +11,12 @@ namespace WixToolset.Data | |||
| 11 | /// large numbers and semantic versions with 4-part versions with | 11 | /// large numbers and semantic versions with 4-part versions with |
| 12 | /// or without leading "v" indicators. | 12 | /// or without leading "v" indicators. |
| 13 | /// </summary> | 13 | /// </summary> |
| 14 | [CLSCompliant(false)] | 14 | public class WixVersion : IComparable, IComparable<WixVersion>, IEquatable<WixVersion> |
| 15 | public class WixVersion | ||
| 16 | { | 15 | { |
| 17 | /// <summary> | 16 | /// <summary> |
| 18 | /// Gets the prefix of the version if present when parsed. Usually, 'v' or 'V'. | 17 | /// Gets the prefix of the version if present when parsed. Usually, 'v' or 'V'. |
| 19 | /// </summary> | 18 | /// </summary> |
| 20 | public char? Prefix { get; set; } | 19 | public char? Prefix { get; set; } |
| 21 | 20 | ||
| 22 | /// <summary> | 21 | /// <summary> |
| 23 | /// Gets or sets the major version. | 22 | /// Gets or sets the major version. |
| @@ -75,6 +74,63 @@ namespace WixToolset.Data | |||
| 75 | public string Metadata { get; set; } | 74 | public string Metadata { get; set; } |
| 76 | 75 | ||
| 77 | /// <summary> | 76 | /// <summary> |
| 77 | /// Compare to another WixVersion. | ||
| 78 | /// </summary> | ||
| 79 | /// <param name="version">WixVersion to compare.</param> | ||
| 80 | /// <returns>A comparison between versions.</returns> | ||
| 81 | public int CompareTo(WixVersion version) | ||
| 82 | { | ||
| 83 | return WixVersionComparer.Default.Compare(this, version); | ||
| 84 | } | ||
| 85 | |||
| 86 | /// <summary> | ||
| 87 | /// Compare to another object. | ||
| 88 | /// </summary> | ||
| 89 | /// <param name="version">Object to compare.</param> | ||
| 90 | /// <returns>A comparison between objects.</returns> | ||
| 91 | public int CompareTo(object version) | ||
| 92 | { | ||
| 93 | return WixVersionComparer.Default.Compare(this, version as WixVersion); | ||
| 94 | } | ||
| 95 | |||
| 96 | /// <summary> | ||
| 97 | /// Returns a value indicating whether the current System.Version object is equal to a specified object. | ||
| 98 | /// </summary> | ||
| 99 | /// <param name="version">An WixVersion to compare with the current WixVersion object, or null.</param> | ||
| 100 | /// <returns> | ||
| 101 | /// true if the current WixVersion object and obj are both WixVersion objects, | ||
| 102 | /// and every component of the current System.Version object matches the corresponding | ||
| 103 | /// component of obj; otherwise, false. | ||
| 104 | /// </returns> | ||
| 105 | public bool Equals(WixVersion version) | ||
| 106 | { | ||
| 107 | return WixVersionComparer.Default.Equals(this, version); | ||
| 108 | } | ||
| 109 | |||
| 110 | /// <summary> | ||
| 111 | /// Returns a value indicating whether the current WixVersion object is equal to a specified object. | ||
| 112 | /// </summary> | ||
| 113 | /// <param name="obj">An object to compare with the current WixVersion object, or null.</param> | ||
| 114 | /// <returns> | ||
| 115 | /// true if the current WixVersion object and obj are both WixVersion objects, | ||
| 116 | /// and every component of the current System.Version object matches the corresponding | ||
| 117 | /// component of obj; otherwise, false. | ||
| 118 | /// </returns> | ||
| 119 | public override bool Equals(object obj) | ||
| 120 | { | ||
| 121 | return WixVersionComparer.Default.Equals(this, obj as WixVersion); | ||
| 122 | } | ||
| 123 | |||
| 124 | /// <summary> | ||
| 125 | /// Returns a hash code for the current WixVersion object. | ||
| 126 | /// </summary> | ||
| 127 | /// <returns>A 32-bit signed integer hash code.</returns> | ||
| 128 | public override int GetHashCode() | ||
| 129 | { | ||
| 130 | return WixVersionComparer.Default.GetHashCode(this); | ||
| 131 | } | ||
| 132 | |||
| 133 | /// <summary> | ||
| 78 | /// Parse a string value into a <c>WixVersion</c>. The returned version may be invalid. | 134 | /// Parse a string value into a <c>WixVersion</c>. The returned version may be invalid. |
| 79 | /// </summary> | 135 | /// </summary> |
| 80 | /// <param name="parse">String value to parse into a version.</param> | 136 | /// <param name="parse">String value to parse into a version.</param> |
| @@ -331,5 +387,77 @@ namespace WixToolset.Data | |||
| 331 | 387 | ||
| 332 | return true; | 388 | return true; |
| 333 | } | 389 | } |
| 390 | |||
| 391 | /// <summary> | ||
| 392 | /// Determines whether two specified WixVersion objects are equal. | ||
| 393 | /// </summary> | ||
| 394 | /// <param name="v1">The first WixVersion object.</param> | ||
| 395 | /// <param name="v2">The second WixVersion object.</param> | ||
| 396 | /// <returns>true if v1 equals v2; otherwise, false.</returns> | ||
| 397 | public static bool operator ==(WixVersion v1, WixVersion v2) | ||
| 398 | { | ||
| 399 | return WixVersionComparer.Default.Equals(v1, v2); | ||
| 400 | } | ||
| 401 | |||
| 402 | /// <summary> | ||
| 403 | /// Determines whether two specified System.Version objects are not equal. | ||
| 404 | /// </summary> | ||
| 405 | /// <param name="v1">The first WixVersion object.</param> | ||
| 406 | /// <param name="v2">The second WixVersion object.</param> | ||
| 407 | /// <returns>true if v1 does not equal v2; otherwise, false.</returns> | ||
| 408 | public static bool operator !=(WixVersion v1, WixVersion v2) | ||
| 409 | { | ||
| 410 | return !WixVersionComparer.Default.Equals(v1, v2); | ||
| 411 | } | ||
| 412 | |||
| 413 | /// <summary> | ||
| 414 | /// Determines whether the first specified System.Version object is less than the second specified System.Version object. | ||
| 415 | /// </summary> | ||
| 416 | /// <param name="v1">The first WixVersion object.</param> | ||
| 417 | /// <param name="v2">The second WixVersion object.</param> | ||
| 418 | /// <returns>true if v1 is less than v2; otherwise, false.</returns> | ||
| 419 | /// <exception cref="ArgumentNullException">v1 is null.</exception> | ||
| 420 | public static bool operator <(WixVersion v1, WixVersion v2) | ||
| 421 | { | ||
| 422 | return WixVersionComparer.Default.Compare(v1, v2) == -1; | ||
| 423 | } | ||
| 424 | |||
| 425 | /// <summary> | ||
| 426 | /// Determines whether the first specified System.Version object is greater than the second specified System.Version object. | ||
| 427 | /// </summary> | ||
| 428 | /// <param name="v1">The first WixVersion object.</param> | ||
| 429 | /// <param name="v2">The second WixVersion object.</param> | ||
| 430 | /// <returns>true if v1 is greater than v2; otherwise, false.</returns> | ||
| 431 | public static bool operator >(WixVersion v1, WixVersion v2) | ||
| 432 | { | ||
| 433 | return WixVersionComparer.Default.Compare(v1, v2) == 1; | ||
| 434 | } | ||
| 435 | |||
| 436 | /// <summary> | ||
| 437 | /// Determines whether the first specified System.Version object is less than or equal to the second System.Version object. | ||
| 438 | /// </summary> | ||
| 439 | /// <param name="v1">The first WixVersion object.</param> | ||
| 440 | /// <param name="v2">The second WixVersion object.</param> | ||
| 441 | /// <returns>true if v1 is less than or equal to v2; otherwise, false.</returns> | ||
| 442 | /// <exception cref="ArgumentNullException">v1 is null.</exception> | ||
| 443 | public static bool operator <=(WixVersion v1, WixVersion v2) | ||
| 444 | { | ||
| 445 | var result = WixVersionComparer.Default.Compare(v1, v2); | ||
| 446 | |||
| 447 | return result == 0 || result == -1; | ||
| 448 | } | ||
| 449 | |||
| 450 | /// <summary> | ||
| 451 | /// Determines whether the first specified System.Version object is greater than or equal to the second specified System.Version object. | ||
| 452 | /// </summary> | ||
| 453 | /// <param name="v1">The first WixVersion object.</param> | ||
| 454 | /// <param name="v2">The second WixVersion object.</param> | ||
| 455 | /// <returns>true if v1 is greater than or equal to v2; otherwise, false.</returns> | ||
| 456 | public static bool operator >=(WixVersion v1, WixVersion v2) | ||
| 457 | { | ||
| 458 | var result = WixVersionComparer.Default.Compare(v1, v2); | ||
| 459 | |||
| 460 | return result == 0 || result == 1; | ||
| 461 | } | ||
| 334 | } | 462 | } |
| 335 | } | 463 | } |
diff --git a/src/libs/WixToolset.Versioning/WixVersionComparer.cs b/src/libs/WixToolset.Versioning/WixVersionComparer.cs new file mode 100644 index 00000000..be203634 --- /dev/null +++ b/src/libs/WixToolset.Versioning/WixVersionComparer.cs | |||
| @@ -0,0 +1,253 @@ | |||
| 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
| 2 | |||
| 3 | namespace WixToolset.Versioning | ||
| 4 | { | ||
| 5 | using System; | ||
| 6 | using System.Collections.Generic; | ||
| 7 | |||
| 8 | /// <summary> | ||
| 9 | /// WixVersion comparer. | ||
| 10 | /// </summary> | ||
| 11 | public class WixVersionComparer : IEqualityComparer<WixVersion>, IComparer<WixVersion> | ||
| 12 | { | ||
| 13 | /// <summary> | ||
| 14 | /// Default WixVersion comparer. | ||
| 15 | /// </summary> | ||
| 16 | public static readonly WixVersionComparer Default = new WixVersionComparer(); | ||
| 17 | |||
| 18 | /// <inheritdoc /> | ||
| 19 | public int Compare(WixVersion x, WixVersion y) | ||
| 20 | { | ||
| 21 | if ((object)x == y) | ||
| 22 | { | ||
| 23 | return 0; | ||
| 24 | } | ||
| 25 | |||
| 26 | if (x is null) | ||
| 27 | { | ||
| 28 | return -1; | ||
| 29 | } | ||
| 30 | |||
| 31 | if (y is null) | ||
| 32 | { | ||
| 33 | return 1; | ||
| 34 | } | ||
| 35 | |||
| 36 | var result = x.Major.CompareTo(y.Major); | ||
| 37 | if (result != 0) | ||
| 38 | { | ||
| 39 | return result; | ||
| 40 | } | ||
| 41 | |||
| 42 | result = x.Minor.CompareTo(y.Minor); | ||
| 43 | if (result != 0) | ||
| 44 | { | ||
| 45 | return result; | ||
| 46 | } | ||
| 47 | |||
| 48 | result = x.Patch.CompareTo(y.Patch); | ||
| 49 | if (result != 0) | ||
| 50 | { | ||
| 51 | return result; | ||
| 52 | } | ||
| 53 | |||
| 54 | result = x.Revision.CompareTo(y.Revision); | ||
| 55 | if (result != 0) | ||
| 56 | { | ||
| 57 | return result; | ||
| 58 | } | ||
| 59 | |||
| 60 | var xLabelCount = x.Labels?.Length ?? 0; | ||
| 61 | var yLabelCount = y.Labels?.Length ?? 0; | ||
| 62 | var maxLabelCount = Math.Max(xLabelCount, yLabelCount); | ||
| 63 | |||
| 64 | if (xLabelCount > 0) | ||
| 65 | { | ||
| 66 | if (yLabelCount == 0) | ||
| 67 | { | ||
| 68 | return -1; | ||
| 69 | } | ||
| 70 | } | ||
| 71 | else if (yLabelCount > 0) | ||
| 72 | { | ||
| 73 | return 1; | ||
| 74 | } | ||
| 75 | |||
| 76 | for (var i = 0; i < maxLabelCount; ++i) | ||
| 77 | { | ||
| 78 | var xLabel = i < xLabelCount ? x.Labels[i] : null; | ||
| 79 | var yLabel = i < yLabelCount ? y.Labels[i] : null; | ||
| 80 | |||
| 81 | result = CompareReleaseLabel(xLabel, yLabel); | ||
| 82 | if (result != 0) | ||
| 83 | { | ||
| 84 | return result; | ||
| 85 | } | ||
| 86 | } | ||
| 87 | |||
| 88 | var compareMetadata = false; | ||
| 89 | |||
| 90 | if (x.Invalid) | ||
| 91 | { | ||
| 92 | if (!y.Invalid) | ||
| 93 | { | ||
| 94 | return -1; | ||
| 95 | } | ||
| 96 | else | ||
| 97 | { | ||
| 98 | compareMetadata = true; | ||
| 99 | } | ||
| 100 | } | ||
| 101 | else if (y.Invalid) | ||
| 102 | { | ||
| 103 | return 1; | ||
| 104 | } | ||
| 105 | |||
| 106 | if (compareMetadata) | ||
| 107 | { | ||
| 108 | result = String.Compare(x.Metadata, y.Metadata, StringComparison.OrdinalIgnoreCase); | ||
| 109 | } | ||
| 110 | |||
| 111 | return (result == 0) ? 0 : (result < 0) ? -1 : 1; | ||
| 112 | } | ||
| 113 | |||
| 114 | /// <inheritdoc /> | ||
| 115 | public bool Equals(WixVersion x, WixVersion y) | ||
| 116 | { | ||
| 117 | if ((object)x == y) | ||
| 118 | { | ||
| 119 | return true; | ||
| 120 | } | ||
| 121 | |||
| 122 | if (x is null) | ||
| 123 | { | ||
| 124 | return false; | ||
| 125 | } | ||
| 126 | |||
| 127 | if (y is null) | ||
| 128 | { | ||
| 129 | return false; | ||
| 130 | } | ||
| 131 | |||
| 132 | if (x.Major != y.Major) | ||
| 133 | { | ||
| 134 | return false; | ||
| 135 | } | ||
| 136 | |||
| 137 | if (x.Minor != y.Minor) | ||
| 138 | { | ||
| 139 | return false; | ||
| 140 | } | ||
| 141 | |||
| 142 | if (x.Patch != y.Patch) | ||
| 143 | { | ||
| 144 | return false; | ||
| 145 | } | ||
| 146 | |||
| 147 | if (x.Revision != y.Revision) | ||
| 148 | { | ||
| 149 | return false; | ||
| 150 | } | ||
| 151 | |||
| 152 | var labelCount = x.Labels?.Length ?? 0; | ||
| 153 | if (labelCount != (y.Labels?.Length ?? 0)) | ||
| 154 | { | ||
| 155 | return false; | ||
| 156 | } | ||
| 157 | |||
| 158 | for (var i = 0; i < labelCount; ++i) | ||
| 159 | { | ||
| 160 | var result = CompareReleaseLabel(x.Labels[i], y.Labels[i]); | ||
| 161 | if (result != 0) | ||
| 162 | { | ||
| 163 | return false; | ||
| 164 | } | ||
| 165 | } | ||
| 166 | |||
| 167 | if (x.Invalid) | ||
| 168 | { | ||
| 169 | if (y.Invalid) | ||
| 170 | { | ||
| 171 | return String.Equals(x.Metadata, y.Metadata, StringComparison.OrdinalIgnoreCase); | ||
| 172 | } | ||
| 173 | else | ||
| 174 | { | ||
| 175 | return false; | ||
| 176 | } | ||
| 177 | } | ||
| 178 | else if (y.Invalid) | ||
| 179 | { | ||
| 180 | return false; | ||
| 181 | } | ||
| 182 | |||
| 183 | return true; | ||
| 184 | } | ||
| 185 | |||
| 186 | /// <inheritdoc /> | ||
| 187 | public int GetHashCode(WixVersion version) | ||
| 188 | { | ||
| 189 | var hash = 23L; | ||
| 190 | hash = hash * 37 + (version.Prefix ?? '\0'); | ||
| 191 | hash = hash * 37 + version.Major; | ||
| 192 | hash = hash * 37 + version.Minor; | ||
| 193 | hash = hash * 37 + version.Patch; | ||
| 194 | hash = hash * 37 + version.Revision; | ||
| 195 | hash = hash * 37 + (version.Invalid ? 1 : 0); | ||
| 196 | hash = hash * 37 + (version.HasMajor ? 1 : 0); | ||
| 197 | hash = hash * 37 + (version.HasMinor ? 1 : 0); | ||
| 198 | hash = hash * 37 + (version.HasPatch ? 1 : 0); | ||
| 199 | hash = hash * 37 + (version.HasRevision ? 1 : 0); | ||
| 200 | |||
| 201 | if (version.Labels != null) | ||
| 202 | { | ||
| 203 | foreach (var label in version.Labels) | ||
| 204 | { | ||
| 205 | hash = hash * 37 + label.Label.GetHashCode(); | ||
| 206 | } | ||
| 207 | } | ||
| 208 | |||
| 209 | hash = hash * 37 + version.Metadata?.GetHashCode() ?? 0; | ||
| 210 | |||
| 211 | return unchecked((int)hash); | ||
| 212 | } | ||
| 213 | |||
| 214 | private static int CompareReleaseLabel(WixVersionLabel l1, WixVersionLabel l2) | ||
| 215 | { | ||
| 216 | if (l1 == l2) | ||
| 217 | { | ||
| 218 | return 0; | ||
| 219 | } | ||
| 220 | else if (l2 == null) | ||
| 221 | { | ||
| 222 | return 1; | ||
| 223 | } | ||
| 224 | else if (l1 == null) | ||
| 225 | { | ||
| 226 | return -1; | ||
| 227 | } | ||
| 228 | |||
| 229 | if (l1.Numeric.HasValue) | ||
| 230 | { | ||
| 231 | if (l2.Numeric.HasValue) | ||
| 232 | { | ||
| 233 | return l1.Numeric.Value.CompareTo(l2.Numeric.Value); | ||
| 234 | } | ||
| 235 | else | ||
| 236 | { | ||
| 237 | return -1; | ||
| 238 | } | ||
| 239 | } | ||
| 240 | else | ||
| 241 | { | ||
| 242 | if (l2.Numeric.HasValue) | ||
| 243 | { | ||
| 244 | return 1; | ||
| 245 | } | ||
| 246 | else | ||
| 247 | { | ||
| 248 | return String.Compare(l1.Label, l2.Label, StringComparison.OrdinalIgnoreCase); | ||
| 249 | } | ||
| 250 | } | ||
| 251 | } | ||
| 252 | } | ||
| 253 | } | ||
diff --git a/src/libs/WixToolset.Versioning/WixVersionLabel.cs b/src/libs/WixToolset.Versioning/WixVersionLabel.cs new file mode 100644 index 00000000..c5dcb875 --- /dev/null +++ b/src/libs/WixToolset.Versioning/WixVersionLabel.cs | |||
| @@ -0,0 +1,40 @@ | |||
| 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
| 2 | |||
| 3 | namespace WixToolset.Versioning | ||
| 4 | { | ||
| 5 | /// <summary> | ||
| 6 | /// Label in a <c>WixVersion</c>. | ||
| 7 | /// </summary> | ||
| 8 | public class WixVersionLabel | ||
| 9 | { | ||
| 10 | /// <summary> | ||
| 11 | /// Creates a string only version label. | ||
| 12 | /// </summary> | ||
| 13 | /// <param name="label">String value for version label.</param> | ||
| 14 | public WixVersionLabel(string label) | ||
| 15 | { | ||
| 16 | this.Label = label; | ||
| 17 | } | ||
| 18 | |||
| 19 | /// <summary> | ||
| 20 | /// Creates a string version label with numeric value. | ||
| 21 | /// </summary> | ||
| 22 | /// <param name="label">String value for version label.</param> | ||
| 23 | /// <param name="numeric">Numeric value for the version label.</param> | ||
| 24 | public WixVersionLabel(string label, uint? numeric) | ||
| 25 | { | ||
| 26 | this.Label = label; | ||
| 27 | this.Numeric = numeric; | ||
| 28 | } | ||
| 29 | |||
| 30 | /// <summary> | ||
| 31 | /// Gets the string label value. | ||
| 32 | /// </summary> | ||
| 33 | public string Label { get; set; } | ||
| 34 | |||
| 35 | /// <summary> | ||
| 36 | /// Gets the optional numeric label value. | ||
| 37 | /// </summary> | ||
| 38 | public uint? Numeric { get; set; } | ||
| 39 | } | ||
| 40 | } | ||
diff --git a/src/libs/dutil/WixToolset.DUtil/dutil.v3.ncrunchproject b/src/libs/dutil/WixToolset.DUtil/dutil.v3.ncrunchproject new file mode 100644 index 00000000..319cd523 --- /dev/null +++ b/src/libs/dutil/WixToolset.DUtil/dutil.v3.ncrunchproject | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | <ProjectConfiguration> | ||
| 2 | <Settings> | ||
| 3 | <IgnoreThisComponentCompletely>True</IgnoreThisComponentCompletely> | ||
| 4 | </Settings> | ||
| 5 | </ProjectConfiguration> \ No newline at end of file | ||
diff --git a/src/libs/dutil/test/DUtilUnitTest/DUtilUnitTest.v3.ncrunchproject b/src/libs/dutil/test/DUtilUnitTest/DUtilUnitTest.v3.ncrunchproject new file mode 100644 index 00000000..319cd523 --- /dev/null +++ b/src/libs/dutil/test/DUtilUnitTest/DUtilUnitTest.v3.ncrunchproject | |||
| @@ -0,0 +1,5 @@ | |||
| 1 | <ProjectConfiguration> | ||
| 2 | <Settings> | ||
| 3 | <IgnoreThisComponentCompletely>True</IgnoreThisComponentCompletely> | ||
| 4 | </Settings> | ||
| 5 | </ProjectConfiguration> \ No newline at end of file | ||
diff --git a/src/libs/libs.cmd b/src/libs/libs.cmd index e3107fbc..e9402701 100644 --- a/src/libs/libs.cmd +++ b/src/libs/libs.cmd | |||
| @@ -3,18 +3,42 @@ | |||
| 3 | 3 | ||
| 4 | @set _C=Debug | 4 | @set _C=Debug |
| 5 | @set _L=%~dp0..\..\build\logs | 5 | @set _L=%~dp0..\..\build\logs |
| 6 | |||
| 6 | :parse_args | 7 | :parse_args |
| 7 | @if /i "%1"=="release" set _C=Release | 8 | @if /i "%1"=="release" set _C=Release |
| 9 | @if /i "%1"=="inc" set _INC=1 | ||
| 10 | @if /i "%1"=="clean" set _CLEAN=1 | ||
| 8 | @if not "%1"=="" shift & goto parse_args | 11 | @if not "%1"=="" shift & goto parse_args |
| 9 | 12 | ||
| 10 | @set _B=%~dp0..\..\build\libs\%_C% | 13 | @set _B=%~dp0..\..\build\libs\%_C% |
| 11 | 14 | ||
| 15 | :: Clean | ||
| 16 | |||
| 17 | @if "%_INC%"=="" call :clean | ||
| 18 | @if NOT "%_CLEAN%"=="" goto :end | ||
| 19 | |||
| 12 | @echo Building libs %_C% | 20 | @echo Building libs %_C% |
| 13 | 21 | ||
| 14 | msbuild -Restore libs_t.proj -p:Configuration=%_C% -nologo -m -warnaserror -bl:%_L%\libs_build.binlog || exit /b | 22 | msbuild -Restore libs_t.proj -p:Configuration=%_C% -nologo -m -warnaserror -bl:%_L%\libs_build.binlog || exit /b |
| 15 | 23 | ||
| 24 | dotnet test %_B%\net6.0\WixToolsetTest.Versioning.dll --nologo -l "trx;LogFileName=%_L%\TestResults\WixToolsetTest.Versioning.trx" || exit /b | ||
| 16 | dotnet test %_B%\x86\DUtilUnitTest.dll --nologo -l "trx;LogFileName=%_L%\TestResults\DutilUnitTest32.trx" || exit /b | 25 | dotnet test %_B%\x86\DUtilUnitTest.dll --nologo -l "trx;LogFileName=%_L%\TestResults\DutilUnitTest32.trx" || exit /b |
| 17 | dotnet test %_B%\x64\DUtilUnitTest.dll --nologo -l "trx;LogFileName=%_L%\TestResults\DutilUnitTest64.trx" || exit /b | 26 | dotnet test %_B%\x64\DUtilUnitTest.dll --nologo -l "trx;LogFileName=%_L%\TestResults\DutilUnitTest64.trx" || exit /b |
| 18 | 27 | ||
| 28 | @goto :end | ||
| 29 | |||
| 30 | :clean | ||
| 31 | @rd /s/q "..\..\build\libs" 2> nul | ||
| 32 | @del "..\..\build\artifacts\WixToolset.DUtil.*.nupkg" 2> nul | ||
| 33 | @del "..\..\build\artifacts\WixToolset.Versioning.*.nupkg" 2> nul | ||
| 34 | @del "..\..\build\artifacts\WixToolset.WcaUtil.*.nupkg" 2> nul | ||
| 35 | @del "%_L%\TestResults\WixToolsetTest.Versioning.trx" 2> nul | ||
| 36 | @del "%_L%\TestResults\DutilUnitTest*.trx" 2> nul | ||
| 37 | @rd /s/q "%USERPROFILE%\.nuget\packages\wixtoolset.dutil" 2> nul | ||
| 38 | @rd /s/q "%USERPROFILE%\.nuget\packages\wixtoolset.versioning" 2> nul | ||
| 39 | @rd /s/q "%USERPROFILE%\.nuget\packages\wixtoolset.wcautil" 2> nul | ||
| 40 | @exit /b | ||
| 41 | |||
| 42 | :end | ||
| 19 | @popd | 43 | @popd |
| 20 | @endlocal | 44 | @endlocal |
diff --git a/src/libs/libs.sln b/src/libs/libs.sln index e0a4a149..1c9c10d1 100644 --- a/src/libs/libs.sln +++ b/src/libs/libs.sln | |||
| @@ -1,7 +1,7 @@ | |||
| 1 |  | 1 |  |
| 2 | Microsoft Visual Studio Solution File, Format Version 12.00 | 2 | Microsoft Visual Studio Solution File, Format Version 12.00 |
| 3 | # Visual Studio Version 16 | 3 | # Visual Studio Version 17 |
| 4 | VisualStudioVersion = 16.6.30114.105 | 4 | VisualStudioVersion = 17.3.32922.545 |
| 5 | MinimumVisualStudioVersion = 10.0.40219.1 | 5 | MinimumVisualStudioVersion = 10.0.40219.1 |
| 6 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "dutil", "dutil\WixToolset.DUtil\dutil.vcxproj", "{1244E671-F108-4334-BA52-8A7517F26ECD}" | 6 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "dutil", "dutil\WixToolset.DUtil\dutil.vcxproj", "{1244E671-F108-4334-BA52-8A7517F26ECD}" |
| 7 | EndProject | 7 | EndProject |
| @@ -9,6 +9,10 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "DUtilUnitTest", "dutil\test | |||
| 9 | EndProject | 9 | EndProject |
| 10 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "wcautil", "wcautil\WixToolset.WcaUtil\wcautil.vcxproj", "{5B3714B6-3A76-463E-8595-D48DA276C512}" | 10 | Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "wcautil", "wcautil\WixToolset.WcaUtil\wcautil.vcxproj", "{5B3714B6-3A76-463E-8595-D48DA276C512}" |
| 11 | EndProject | 11 | EndProject |
| 12 | Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WixToolset.Versioning", "WixToolset.Versioning\WixToolset.Versioning.csproj", "{7B14B536-4205-4186-B9FD-0765B84F2075}" | ||
| 13 | EndProject | ||
| 14 | Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "WixToolsetTest.Versioning", "test\WixToolsetTest.Versioning\WixToolsetTest.Versioning.csproj", "{3D510701-FF05-4E3B-BB99-BDB97963C3F8}" | ||
| 15 | EndProject | ||
| 12 | Global | 16 | Global |
| 13 | GlobalSection(SolutionConfigurationPlatforms) = preSolution | 17 | GlobalSection(SolutionConfigurationPlatforms) = preSolution |
| 14 | Debug|Any CPU = Debug|Any CPU | 18 | Debug|Any CPU = Debug|Any CPU |
| @@ -59,6 +63,38 @@ Global | |||
| 59 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x64.Build.0 = Release|x64 | 63 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x64.Build.0 = Release|x64 |
| 60 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x86.ActiveCfg = Release|Win32 | 64 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x86.ActiveCfg = Release|Win32 |
| 61 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x86.Build.0 = Release|Win32 | 65 | {5B3714B6-3A76-463E-8595-D48DA276C512}.Release|x86.Build.0 = Release|Win32 |
| 66 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||
| 67 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||
| 68 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|ARM64.ActiveCfg = Debug|Any CPU | ||
| 69 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|ARM64.Build.0 = Debug|Any CPU | ||
| 70 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|x64.ActiveCfg = Debug|Any CPU | ||
| 71 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|x64.Build.0 = Debug|Any CPU | ||
| 72 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|x86.ActiveCfg = Debug|Any CPU | ||
| 73 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Debug|x86.Build.0 = Debug|Any CPU | ||
| 74 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||
| 75 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|Any CPU.Build.0 = Release|Any CPU | ||
| 76 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|ARM64.ActiveCfg = Release|Any CPU | ||
| 77 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|ARM64.Build.0 = Release|Any CPU | ||
| 78 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|x64.ActiveCfg = Release|Any CPU | ||
| 79 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|x64.Build.0 = Release|Any CPU | ||
| 80 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|x86.ActiveCfg = Release|Any CPU | ||
| 81 | {7B14B536-4205-4186-B9FD-0765B84F2075}.Release|x86.Build.0 = Release|Any CPU | ||
| 82 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||
| 83 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||
| 84 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|ARM64.ActiveCfg = Debug|Any CPU | ||
| 85 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|ARM64.Build.0 = Debug|Any CPU | ||
| 86 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|x64.ActiveCfg = Debug|Any CPU | ||
| 87 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|x64.Build.0 = Debug|Any CPU | ||
| 88 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|x86.ActiveCfg = Debug|Any CPU | ||
| 89 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Debug|x86.Build.0 = Debug|Any CPU | ||
| 90 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||
| 91 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|Any CPU.Build.0 = Release|Any CPU | ||
| 92 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|ARM64.ActiveCfg = Release|Any CPU | ||
| 93 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|ARM64.Build.0 = Release|Any CPU | ||
| 94 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|x64.ActiveCfg = Release|Any CPU | ||
| 95 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|x64.Build.0 = Release|Any CPU | ||
| 96 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|x86.ActiveCfg = Release|Any CPU | ||
| 97 | {3D510701-FF05-4E3B-BB99-BDB97963C3F8}.Release|x86.Build.0 = Release|Any CPU | ||
| 62 | EndGlobalSection | 98 | EndGlobalSection |
| 63 | GlobalSection(SolutionProperties) = preSolution | 99 | GlobalSection(SolutionProperties) = preSolution |
| 64 | HideSolutionNode = FALSE | 100 | HideSolutionNode = FALSE |
diff --git a/src/libs/libs.v3.ncrunchsolution b/src/libs/libs.v3.ncrunchsolution new file mode 100644 index 00000000..10420ac9 --- /dev/null +++ b/src/libs/libs.v3.ncrunchsolution | |||
| @@ -0,0 +1,6 @@ | |||
| 1 | <SolutionConfiguration> | ||
| 2 | <Settings> | ||
| 3 | <AllowParallelTestExecution>True</AllowParallelTestExecution> | ||
| 4 | <SolutionConfigured>True</SolutionConfigured> | ||
| 5 | </Settings> | ||
| 6 | </SolutionConfiguration> \ No newline at end of file | ||
diff --git a/src/libs/libs_t.proj b/src/libs/libs_t.proj index 8c35f1c3..5c23cbf7 100644 --- a/src/libs/libs_t.proj +++ b/src/libs/libs_t.proj | |||
| @@ -2,5 +2,7 @@ | |||
| 2 | <ItemGroup> | 2 | <ItemGroup> |
| 3 | <ProjectReference Include="dutil\dutil_t.proj" /> | 3 | <ProjectReference Include="dutil\dutil_t.proj" /> |
| 4 | <ProjectReference Include="wcautil\wcautil_t.proj" /> | 4 | <ProjectReference Include="wcautil\wcautil_t.proj" /> |
| 5 | <ProjectReference Include="WixToolset.Versioning\WixToolset.Versioning.csproj" Targets="Pack" /> | ||
| 6 | <ProjectReference Include="test\WixToolsetTest.Versioning\WixToolsetTest.Versioning.csproj" /> | ||
| 5 | </ItemGroup> | 7 | </ItemGroup> |
| 6 | </Project> | 8 | </Project> |
diff --git a/src/libs/test/WixToolsetTest.Versioning/VerUtilTestsFixture.cs b/src/libs/test/WixToolsetTest.Versioning/VerUtilTestsFixture.cs new file mode 100644 index 00000000..3dff28c6 --- /dev/null +++ b/src/libs/test/WixToolsetTest.Versioning/VerUtilTestsFixture.cs | |||
| @@ -0,0 +1,683 @@ | |||
| 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | ||
| 2 | |||
| 3 | namespace WixToolsetTest.Versioning | ||
| 4 | { | ||
| 5 | using System; | ||
| 6 | using WixToolset.Versioning; | ||
| 7 | using Xunit; | ||
| 8 | |||
| 9 | public class VerUtilTestsFixture | ||
| 10 | { | ||
| 11 | [Fact] | ||
| 12 | public void VerCompareVersionsTreatsMissingRevisionAsZero() | ||
| 13 | { | ||
| 14 | var version1 = WixVersion.Parse("1.2.3.4"); | ||
| 15 | var version2 = WixVersion.Parse("1.2.3"); | ||
| 16 | var version3 = WixVersion.Parse("1.2.3.0"); | ||
| 17 | |||
| 18 | Assert.Null(version1.Prefix); | ||
| 19 | Assert.Equal(1U, version1.Major); | ||
| 20 | Assert.Equal(2U, version1.Minor); | ||
| 21 | Assert.Equal(3U, version1.Patch); | ||
| 22 | Assert.Equal(4U, version1.Revision); | ||
| 23 | Assert.Null(version1.Labels); | ||
| 24 | Assert.Null(version1.Metadata); | ||
| 25 | Assert.False(version1.Invalid); | ||
| 26 | Assert.True(version1.HasMajor); | ||
| 27 | Assert.True(version1.HasMinor); | ||
| 28 | Assert.True(version1.HasPatch); | ||
| 29 | Assert.True(version1.HasRevision); | ||
| 30 | |||
| 31 | Assert.Null(version2.Prefix); | ||
| 32 | Assert.Equal(1U, version2.Major); | ||
| 33 | Assert.Equal(2U, version2.Minor); | ||
| 34 | Assert.Equal(3U, version2.Patch); | ||
| 35 | Assert.Equal(0U, version2.Revision); | ||
| 36 | Assert.Null(version2.Labels); | ||
| 37 | Assert.Null(version2.Metadata); | ||
| 38 | Assert.False(version2.Invalid); | ||
| 39 | Assert.True(version2.HasMajor); | ||
| 40 | Assert.True(version2.HasMinor); | ||
| 41 | Assert.True(version2.HasPatch); | ||
| 42 | Assert.False(version2.HasRevision); | ||
| 43 | |||
| 44 | Assert.Null(version3.Prefix); | ||
| 45 | Assert.Equal(1U, version3.Major); | ||
| 46 | Assert.Equal(2U, version3.Minor); | ||
| 47 | Assert.Equal(3U, version3.Patch); | ||
| 48 | Assert.Equal(0U, version3.Revision); | ||
| 49 | Assert.Null(version3.Labels); | ||
| 50 | Assert.Null(version3.Metadata); | ||
| 51 | Assert.False(version3.Invalid); | ||
| 52 | Assert.True(version3.HasMajor); | ||
| 53 | Assert.True(version3.HasMinor); | ||
| 54 | Assert.True(version3.HasPatch); | ||
| 55 | Assert.True(version3.HasRevision); | ||
| 56 | |||
| 57 | Assert.Equal(1, version1.CompareTo(version2)); | ||
| 58 | Assert.Equal(0, version3.CompareTo(version2)); | ||
| 59 | } | ||
| 60 | |||
| 61 | [Fact] | ||
| 62 | public void VerCompareVersionsTreatsNumericReleaseLabelsAsNumbers() | ||
| 63 | { | ||
| 64 | var version1 = WixVersion.Parse("1.0-2.0"); | ||
| 65 | var version2 = WixVersion.Parse("1.0-19"); | ||
| 66 | |||
| 67 | Assert.Null(version1.Prefix); | ||
| 68 | Assert.Equal(1U, version1.Major); | ||
| 69 | Assert.Equal(0U, version1.Minor); | ||
| 70 | Assert.Equal(0U, version1.Patch); | ||
| 71 | Assert.Equal(0U, version1.Revision); | ||
| 72 | Assert.Equal(2, version1.Labels.Length); | ||
| 73 | |||
| 74 | Assert.Equal(2U, version1.Labels[0].Numeric); | ||
| 75 | Assert.Equal("2", version1.Labels[0].Label); | ||
| 76 | |||
| 77 | Assert.Equal(0U, version1.Labels[1].Numeric); | ||
| 78 | Assert.Equal("0", version1.Labels[1].Label); | ||
| 79 | |||
| 80 | Assert.Null(version1.Metadata); | ||
| 81 | Assert.False(version1.Invalid); | ||
| 82 | Assert.True(version1.HasMajor); | ||
| 83 | Assert.True(version1.HasMinor); | ||
| 84 | Assert.False(version1.HasPatch); | ||
| 85 | Assert.False(version1.HasRevision); | ||
| 86 | |||
| 87 | |||
| 88 | Assert.Null(version2.Prefix); | ||
| 89 | Assert.Equal(1U, version2.Major); | ||
| 90 | Assert.Equal(0U, version2.Minor); | ||
| 91 | Assert.Equal(0U, version2.Patch); | ||
| 92 | Assert.Equal(0U, version2.Revision); | ||
| 93 | Assert.Single(version2.Labels); | ||
| 94 | |||
| 95 | Assert.Equal(19U, version2.Labels[0].Numeric); | ||
| 96 | Assert.Equal("19", version2.Labels[0].Label); | ||
| 97 | |||
| 98 | Assert.Null(version2.Metadata); | ||
| 99 | Assert.False(version2.Invalid); | ||
| 100 | Assert.True(version2.HasMajor); | ||
| 101 | Assert.True(version2.HasMinor); | ||
| 102 | Assert.False(version2.HasPatch); | ||
| 103 | Assert.False(version2.HasRevision); | ||
| 104 | |||
| 105 | TestVerutilCompareParsedVersions(version1, version2, -1); | ||
| 106 | } | ||
| 107 | |||
| 108 | [Fact] | ||
| 109 | public void VerCompareVersionsHandlesNormallyInvalidVersions() | ||
| 110 | { | ||
| 111 | var version1 = WixVersion.Parse("10.-4.0"); | ||
| 112 | var version2 = WixVersion.Parse("10.-2.0"); | ||
| 113 | var version3 = WixVersion.Parse("0"); | ||
| 114 | var version4 = WixVersion.Parse(""); | ||
| 115 | var version5 = WixVersion.Parse("10-2"); | ||
| 116 | var version6 = WixVersion.Parse("10-4.@"); | ||
| 117 | |||
| 118 | |||
| 119 | Assert.Null(version1.Prefix); | ||
| 120 | Assert.Equal(10U, version1.Major); | ||
| 121 | Assert.Equal(0U, version1.Minor); | ||
| 122 | Assert.Equal(0U, version1.Patch); | ||
| 123 | Assert.Equal(0U, version1.Revision); | ||
| 124 | Assert.Null(version1.Labels); | ||
| 125 | Assert.Equal("-4.0", version1.Metadata); | ||
| 126 | Assert.True(version1.Invalid); | ||
| 127 | Assert.True(version1.HasMajor); | ||
| 128 | Assert.False(version1.HasMinor); | ||
| 129 | Assert.False(version1.HasPatch); | ||
| 130 | Assert.False(version1.HasRevision); | ||
| 131 | |||
| 132 | |||
| 133 | Assert.Null(version2.Prefix); | ||
| 134 | Assert.Equal(10U, version2.Major); | ||
| 135 | Assert.Equal(0U, version2.Minor); | ||
| 136 | Assert.Equal(0U, version2.Patch); | ||
| 137 | Assert.Equal(0U, version2.Revision); | ||
| 138 | Assert.Null(version2.Labels); | ||
| 139 | Assert.Equal("-2.0", version2.Metadata); | ||
| 140 | Assert.True(version2.Invalid); | ||
| 141 | Assert.True(version2.HasMajor); | ||
| 142 | Assert.False(version2.HasMinor); | ||
| 143 | Assert.False(version2.HasPatch); | ||
| 144 | Assert.False(version2.HasRevision); | ||
| 145 | |||
| 146 | |||
| 147 | Assert.Null(version3.Prefix); | ||
| 148 | Assert.Equal(0U, version3.Major); | ||
| 149 | Assert.Equal(0U, version3.Minor); | ||
| 150 | Assert.Equal(0U, version3.Patch); | ||
| 151 | Assert.Equal(0U, version3.Revision); | ||
| 152 | Assert.Null(version3.Labels); | ||
| 153 | Assert.Null(version3.Metadata); | ||
| 154 | Assert.False(version3.Invalid); | ||
| 155 | Assert.True(version3.HasMajor); | ||
| 156 | Assert.False(version3.HasMinor); | ||
| 157 | Assert.False(version3.HasPatch); | ||
| 158 | Assert.False(version3.HasRevision); | ||
| 159 | |||
| 160 | Assert.Null(version4.Prefix); | ||
| 161 | Assert.Equal(0U, version4.Major); | ||
| 162 | Assert.Equal(0U, version4.Minor); | ||
| 163 | Assert.Equal(0U, version4.Patch); | ||
| 164 | Assert.Equal(0U, version4.Revision); | ||
| 165 | Assert.Null(version4.Labels); | ||
| 166 | Assert.Equal(String.Empty, version4.Metadata); | ||
| 167 | Assert.True(version4.Invalid); | ||
| 168 | Assert.False(version4.HasMajor); | ||
| 169 | Assert.False(version4.HasMinor); | ||
| 170 | Assert.False(version4.HasPatch); | ||
| 171 | Assert.False(version4.HasRevision); | ||
| 172 | |||
| 173 | Assert.Null(version5.Prefix); | ||
| 174 | Assert.Equal(10U, version5.Major); | ||
| 175 | Assert.Equal(0U, version5.Minor); | ||
| 176 | Assert.Equal(0U, version5.Patch); | ||
| 177 | Assert.Equal(0U, version5.Revision); | ||
| 178 | Assert.Single(version5.Labels); | ||
| 179 | Assert.Equal(2U, version5.Labels[0].Numeric); | ||
| 180 | Assert.Equal("2", version5.Labels[0].Label); | ||
| 181 | |||
| 182 | Assert.Null(version5.Metadata); | ||
| 183 | Assert.False(version5.Invalid); | ||
| 184 | Assert.True(version5.HasMajor); | ||
| 185 | Assert.False(version5.HasMinor); | ||
| 186 | Assert.False(version5.HasPatch); | ||
| 187 | Assert.False(version5.HasRevision); | ||
| 188 | |||
| 189 | Assert.Null(version6.Prefix); | ||
| 190 | Assert.Equal(10U, version6.Major); | ||
| 191 | Assert.Equal(0U, version6.Minor); | ||
| 192 | Assert.Equal(0U, version6.Patch); | ||
| 193 | Assert.Equal(0U, version6.Revision); | ||
| 194 | Assert.Single(version6.Labels); | ||
| 195 | Assert.Equal(4U, version6.Labels[0].Numeric); | ||
| 196 | Assert.Equal("4", version6.Labels[0].Label); | ||
| 197 | |||
| 198 | Assert.Equal("@", version6.Metadata); | ||
| 199 | Assert.True(version6.Invalid); | ||
| 200 | Assert.True(version6.HasMajor); | ||
| 201 | Assert.False(version6.HasMinor); | ||
| 202 | Assert.False(version6.HasPatch); | ||
| 203 | Assert.False(version6.HasRevision); | ||
| 204 | |||
| 205 | TestVerutilCompareParsedVersions(version1, version2, 1); | ||
| 206 | TestVerutilCompareParsedVersions(version3, version4, 1); | ||
| 207 | TestVerutilCompareParsedVersions(version5, version6, -1); | ||
| 208 | } | ||
| 209 | |||
| 210 | [Fact] | ||
| 211 | public void VerCompareVersionsTreatsHyphenAsVersionSeparator() | ||
| 212 | { | ||
| 213 | var version1 = WixVersion.Parse("0.0.1-a"); | ||
| 214 | var version2 = WixVersion.Parse("0-2"); | ||
| 215 | var version3 = WixVersion.Parse("1-2"); | ||
| 216 | |||
| 217 | |||
| 218 | Assert.Null(version1.Prefix); | ||
| 219 | Assert.Equal(0U, version1.Major); | ||
| 220 | Assert.Equal(0U, version1.Minor); | ||
| 221 | Assert.Equal(1U, version1.Patch); | ||
| 222 | Assert.Equal(0U, version1.Revision); | ||
| 223 | Assert.Single(version1.Labels); | ||
| 224 | Assert.Null(version1.Labels[0].Numeric); | ||
| 225 | Assert.Equal("a", version1.Labels[0].Label); | ||
| 226 | |||
| 227 | Assert.Null(version1.Metadata); | ||
| 228 | Assert.False(version1.Invalid); | ||
| 229 | Assert.True(version1.HasMajor); | ||
| 230 | Assert.True(version1.HasMinor); | ||
| 231 | Assert.True(version1.HasPatch); | ||
| 232 | Assert.False(version1.HasRevision); | ||
| 233 | |||
| 234 | Assert.Null(version2.Prefix); | ||
| 235 | Assert.Equal(0U, version2.Major); | ||
| 236 | Assert.Equal(0U, version2.Minor); | ||
| 237 | Assert.Equal(0U, version2.Patch); | ||
| 238 | Assert.Equal(0U, version2.Revision); | ||
| 239 | Assert.Single(version2.Labels); | ||
| 240 | Assert.Equal(2U, version2.Labels[0].Numeric); | ||
| 241 | Assert.Equal("2", version2.Labels[0].Label); | ||
| 242 | |||
| 243 | Assert.Null(version2.Metadata); | ||
| 244 | Assert.False(version2.Invalid); | ||
| 245 | Assert.True(version2.HasMajor); | ||
| 246 | Assert.False(version2.HasMinor); | ||
| 247 | Assert.False(version2.HasPatch); | ||
| 248 | Assert.False(version2.HasRevision); | ||
| 249 | |||
| 250 | Assert.Null(version3.Prefix); | ||
| 251 | Assert.Equal(1U, version3.Major); | ||
| 252 | Assert.Equal(0U, version3.Minor); | ||
| 253 | Assert.Equal(0U, version3.Patch); | ||
| 254 | Assert.Equal(0U, version3.Revision); | ||
| 255 | Assert.Single(version3.Labels); | ||
| 256 | Assert.Equal(2U, version3.Labels[0].Numeric); | ||
| 257 | Assert.Equal("2", version3.Labels[0].Label); | ||
| 258 | |||
| 259 | Assert.Null(version3.Metadata); | ||
| 260 | Assert.False(version3.Invalid); | ||
| 261 | Assert.True(version3.HasMajor); | ||
| 262 | Assert.False(version3.HasMinor); | ||
| 263 | Assert.False(version3.HasPatch); | ||
| 264 | Assert.False(version3.HasRevision); | ||
| 265 | |||
| 266 | TestVerutilCompareParsedVersions(version1, version2, 1); | ||
| 267 | TestVerutilCompareParsedVersions(version1, version3, -1); | ||
| 268 | } | ||
| 269 | |||
| 270 | [Fact] | ||
| 271 | public void VerCompareVersionsIgnoresLeadingZeroes() | ||
| 272 | { | ||
| 273 | var version1 = WixVersion.Parse("0.01-a.1"); | ||
| 274 | var version2 = WixVersion.Parse("0.1.0-a.1"); | ||
| 275 | var version3 = WixVersion.Parse("0.1-a.b.0"); | ||
| 276 | var version4 = WixVersion.Parse("0.1.0-a.b.000"); | ||
| 277 | |||
| 278 | Assert.Null(version1.Prefix); | ||
| 279 | Assert.Equal(0U, version1.Major); | ||
| 280 | Assert.Equal(1U, version1.Minor); | ||
| 281 | Assert.Equal(0U, version1.Patch); | ||
| 282 | Assert.Equal(0U, version1.Revision); | ||
| 283 | Assert.Equal(2, version1.Labels.Length); | ||
| 284 | Assert.Null(version1.Labels[0].Numeric); | ||
| 285 | Assert.Equal("a", version1.Labels[0].Label); | ||
| 286 | Assert.Equal(1U, version1.Labels[1].Numeric); | ||
| 287 | Assert.Equal("1", version1.Labels[1].Label); | ||
| 288 | |||
| 289 | Assert.Null(version1.Metadata); | ||
| 290 | Assert.False(version1.Invalid); | ||
| 291 | Assert.True(version1.HasMajor); | ||
| 292 | Assert.True(version1.HasMinor); | ||
| 293 | Assert.False(version1.HasPatch); | ||
| 294 | Assert.False(version1.HasRevision); | ||
| 295 | |||
| 296 | Assert.Null(version2.Prefix); | ||
| 297 | Assert.Equal(0U, version2.Major); | ||
| 298 | Assert.Equal(1U, version2.Minor); | ||
| 299 | Assert.Equal(0U, version2.Patch); | ||
| 300 | Assert.Equal(0U, version2.Revision); | ||
| 301 | Assert.Equal(2, version2.Labels.Length); | ||
| 302 | |||
| 303 | Assert.Null(version2.Labels[0].Numeric); | ||
| 304 | Assert.Equal("a", version2.Labels[0].Label); | ||
| 305 | Assert.Equal(1U, version2.Labels[1].Numeric); | ||
| 306 | Assert.Equal("1", version2.Labels[1].Label); | ||
| 307 | |||
| 308 | Assert.Null(version2.Metadata); | ||
| 309 | Assert.False(version2.Invalid); | ||
| 310 | Assert.True(version2.HasMajor); | ||
| 311 | Assert.True(version2.HasMinor); | ||
| 312 | Assert.True(version2.HasPatch); | ||
| 313 | Assert.False(version2.HasRevision); | ||
| 314 | |||
| 315 | Assert.Null(version3.Prefix); | ||
| 316 | Assert.Equal(0U, version3.Major); | ||
| 317 | Assert.Equal(1U, version3.Minor); | ||
| 318 | Assert.Equal(0U, version3.Patch); | ||
| 319 | Assert.Equal(0U, version3.Revision); | ||
| 320 | Assert.Equal(3, version3.Labels.Length); | ||
| 321 | Assert.Null(version3.Labels[0].Numeric); | ||
| 322 | Assert.Equal("a", version3.Labels[0].Label); | ||
| 323 | Assert.Null(version3.Labels[1].Numeric); | ||
| 324 | Assert.Equal("b", version3.Labels[1].Label); | ||
| 325 | Assert.Equal(0U, version3.Labels[2].Numeric); | ||
| 326 | Assert.Equal("0", version3.Labels[2].Label); | ||
| 327 | |||
| 328 | Assert.Null(version3.Metadata); | ||
| 329 | Assert.False(version3.Invalid); | ||
| 330 | Assert.True(version3.HasMajor); | ||
| 331 | Assert.True(version3.HasMinor); | ||
| 332 | Assert.False(version3.HasPatch); | ||
| 333 | Assert.False(version3.HasRevision); | ||
| 334 | |||
| 335 | Assert.Null(version4.Prefix); | ||
| 336 | Assert.Equal(0U, version4.Major); | ||
| 337 | Assert.Equal(1U, version4.Minor); | ||
| 338 | Assert.Equal(0U, version4.Patch); | ||
| 339 | Assert.Equal(0U, version4.Revision); | ||
| 340 | Assert.Equal(3, version4.Labels.Length); | ||
| 341 | Assert.Null(version4.Labels[0].Numeric); | ||
| 342 | Assert.Equal("a", version4.Labels[0].Label); | ||
| 343 | Assert.Null(version4.Labels[1].Numeric); | ||
| 344 | Assert.Equal("b", version4.Labels[1].Label); | ||
| 345 | Assert.Equal(0U, version4.Labels[2].Numeric); | ||
| 346 | Assert.Equal("000", version4.Labels[2].Label); | ||
| 347 | |||
| 348 | Assert.Null(version4.Metadata); | ||
| 349 | Assert.False(version4.Invalid); | ||
| 350 | Assert.True(version4.HasMajor); | ||
| 351 | Assert.True(version4.HasMinor); | ||
| 352 | Assert.True(version4.HasPatch); | ||
| 353 | Assert.False(version4.HasRevision); | ||
| 354 | |||
| 355 | TestVerutilCompareParsedVersions(version1, version2, 0); | ||
| 356 | TestVerutilCompareParsedVersions(version3, version4, 0); | ||
| 357 | } | ||
| 358 | |||
| 359 | [Fact] | ||
| 360 | public void VerCompareVersionsTreatsUnexpectedContentAsMetadata() | ||
| 361 | { | ||
| 362 | var version1 = WixVersion.Parse("1.2.3+abcd"); | ||
| 363 | var version2 = WixVersion.Parse("1.2.3.abcd"); | ||
| 364 | var version3 = WixVersion.Parse("1.2.3.-abcd"); | ||
| 365 | |||
| 366 | Assert.Null(version1.Prefix); | ||
| 367 | Assert.Equal(1U, version1.Major); | ||
| 368 | Assert.Equal(2U, version1.Minor); | ||
| 369 | Assert.Equal(3U, version1.Patch); | ||
| 370 | Assert.Equal(0U, version1.Revision); | ||
| 371 | Assert.Null(version1.Labels); | ||
| 372 | Assert.Equal("abcd", version1.Metadata); | ||
| 373 | Assert.False(version1.Invalid); | ||
| 374 | Assert.True(version1.HasMajor); | ||
| 375 | Assert.True(version1.HasMinor); | ||
| 376 | Assert.True(version1.HasPatch); | ||
| 377 | Assert.False(version1.HasRevision); | ||
| 378 | |||
| 379 | Assert.Null(version2.Prefix); | ||
| 380 | Assert.Equal(1U, version2.Major); | ||
| 381 | Assert.Equal(2U, version2.Minor); | ||
| 382 | Assert.Equal(3U, version2.Patch); | ||
| 383 | Assert.Equal(0U, version2.Revision); | ||
| 384 | Assert.Null(version2.Labels); | ||
| 385 | Assert.Equal("abcd", version2.Metadata); | ||
| 386 | Assert.True(version2.Invalid); | ||
| 387 | Assert.True(version2.HasMajor); | ||
| 388 | Assert.True(version2.HasMinor); | ||
| 389 | Assert.True(version2.HasPatch); | ||
| 390 | Assert.False(version2.HasRevision); | ||
| 391 | |||
| 392 | |||
| 393 | Assert.Null(version3.Prefix); | ||
| 394 | Assert.Equal(1U, version3.Major); | ||
| 395 | Assert.Equal(2U, version3.Minor); | ||
| 396 | Assert.Equal(3U, version3.Patch); | ||
| 397 | Assert.Equal(0U, version3.Revision); | ||
| 398 | Assert.Null(version3.Labels); | ||
| 399 | Assert.Equal("-abcd", version3.Metadata); | ||
| 400 | Assert.True(version3.Invalid); | ||
| 401 | Assert.True(version3.HasMajor); | ||
| 402 | Assert.True(version3.HasMinor); | ||
| 403 | Assert.True(version3.HasPatch); | ||
| 404 | Assert.False(version3.HasRevision); | ||
| 405 | |||
| 406 | TestVerutilCompareParsedVersions(version1, version2, 1); | ||
| 407 | TestVerutilCompareParsedVersions(version1, version3, 1); | ||
| 408 | TestVerutilCompareParsedVersions(version2, version3, 1); | ||
| 409 | } | ||
| 410 | |||
| 411 | [Fact] | ||
| 412 | public void VerCompareVersionsIgnoresLeadingV() | ||
| 413 | { | ||
| 414 | var version1 = WixVersion.Parse("10.20.30.40"); | ||
| 415 | var version2 = WixVersion.Parse("v10.20.30.40"); | ||
| 416 | var version3 = WixVersion.Parse("V10.20.30.40"); | ||
| 417 | var version4 = WixVersion.Parse("v10.20.30.40-abc"); | ||
| 418 | var version5 = WixVersion.Parse("vvv"); | ||
| 419 | |||
| 420 | Assert.Null(version1.Prefix); | ||
| 421 | Assert.Equal(10U, version1.Major); | ||
| 422 | Assert.Equal(20U, version1.Minor); | ||
| 423 | Assert.Equal(30U, version1.Patch); | ||
| 424 | Assert.Equal(40U, version1.Revision); | ||
| 425 | Assert.Null(version1.Labels); | ||
| 426 | Assert.Null(version1.Metadata); | ||
| 427 | Assert.False(version1.Invalid); | ||
| 428 | Assert.True(version1.HasMajor); | ||
| 429 | Assert.True(version1.HasMinor); | ||
| 430 | Assert.True(version1.HasPatch); | ||
| 431 | Assert.True(version1.HasRevision); | ||
| 432 | |||
| 433 | Assert.Equal('v', version2.Prefix); | ||
| 434 | Assert.Equal(10U, version2.Major); | ||
| 435 | Assert.Equal(20U, version2.Minor); | ||
| 436 | Assert.Equal(30U, version2.Patch); | ||
| 437 | Assert.Equal(40U, version2.Revision); | ||
| 438 | Assert.Null(version2.Labels); | ||
| 439 | Assert.Null(version2.Metadata); | ||
| 440 | Assert.False(version2.Invalid); | ||
| 441 | Assert.True(version2.HasMajor); | ||
| 442 | Assert.True(version2.HasMinor); | ||
| 443 | Assert.True(version2.HasPatch); | ||
| 444 | Assert.True(version2.HasRevision); | ||
| 445 | |||
| 446 | Assert.Equal('V', version3.Prefix); | ||
| 447 | Assert.Equal(10U, version3.Major); | ||
| 448 | Assert.Equal(20U, version3.Minor); | ||
| 449 | Assert.Equal(30U, version3.Patch); | ||
| 450 | Assert.Equal(40U, version3.Revision); | ||
| 451 | Assert.Null(version3.Labels); | ||
| 452 | Assert.Null(version3.Metadata); | ||
| 453 | Assert.False(version3.Invalid); | ||
| 454 | Assert.True(version3.HasMajor); | ||
| 455 | Assert.True(version3.HasMinor); | ||
| 456 | Assert.True(version3.HasPatch); | ||
| 457 | Assert.True(version3.HasRevision); | ||
| 458 | |||
| 459 | Assert.Equal('v', version4.Prefix); | ||
| 460 | Assert.Equal(10U, version4.Major); | ||
| 461 | Assert.Equal(20U, version4.Minor); | ||
| 462 | Assert.Equal(30U, version4.Patch); | ||
| 463 | Assert.Equal(40U, version4.Revision); | ||
| 464 | Assert.Single(version4.Labels); | ||
| 465 | Assert.Null(version4.Labels[0].Numeric); | ||
| 466 | Assert.Equal("abc", version4.Labels[0].Label); | ||
| 467 | |||
| 468 | Assert.Null(version4.Metadata); | ||
| 469 | Assert.False(version4.Invalid); | ||
| 470 | Assert.True(version4.HasMajor); | ||
| 471 | Assert.True(version4.HasMinor); | ||
| 472 | Assert.True(version4.HasPatch); | ||
| 473 | Assert.True(version4.HasRevision); | ||
| 474 | |||
| 475 | Assert.Null(version5.Prefix); | ||
| 476 | Assert.Equal(0U, version5.Major); | ||
| 477 | Assert.Equal(0U, version5.Minor); | ||
| 478 | Assert.Equal(0U, version5.Patch); | ||
| 479 | Assert.Equal(0U, version5.Revision); | ||
| 480 | Assert.Null(version5.Labels); | ||
| 481 | Assert.Equal("vvv", version5.Metadata); | ||
| 482 | Assert.True(version5.Invalid); | ||
| 483 | Assert.False(version5.HasMajor); | ||
| 484 | Assert.False(version5.HasMinor); | ||
| 485 | Assert.False(version5.HasPatch); | ||
| 486 | Assert.False(version5.HasRevision); | ||
| 487 | |||
| 488 | TestVerutilCompareParsedVersions(version1, version2, 0); | ||
| 489 | TestVerutilCompareParsedVersions(version1, version3, 0); | ||
| 490 | TestVerutilCompareParsedVersions(version1, version4, 1); | ||
| 491 | } | ||
| 492 | |||
| 493 | [Fact] | ||
| 494 | public void VerCompareVersionsHandlesTooLargeNumbers() | ||
| 495 | { | ||
| 496 | var version1 = WixVersion.Parse("4294967295.4294967295.4294967295.4294967295"); | ||
| 497 | var version2 = WixVersion.Parse("4294967296.4294967296.4294967296.4294967296"); | ||
| 498 | |||
| 499 | Assert.Null(version1.Prefix); | ||
| 500 | Assert.Equal(4294967295, version1.Major); | ||
| 501 | Assert.Equal(4294967295, version1.Minor); | ||
| 502 | Assert.Equal(4294967295, version1.Patch); | ||
| 503 | Assert.Equal(4294967295, version1.Revision); | ||
| 504 | Assert.Null(version1.Labels); | ||
| 505 | Assert.Null(version1.Metadata); | ||
| 506 | Assert.False(version1.Invalid); | ||
| 507 | Assert.True(version1.HasMajor); | ||
| 508 | Assert.True(version1.HasMinor); | ||
| 509 | Assert.True(version1.HasPatch); | ||
| 510 | Assert.True(version1.HasRevision); | ||
| 511 | |||
| 512 | Assert.Null(version2.Prefix); | ||
| 513 | Assert.Equal(0U, version2.Major); | ||
| 514 | Assert.Equal(0U, version2.Minor); | ||
| 515 | Assert.Equal(0U, version2.Patch); | ||
| 516 | Assert.Equal(0U, version2.Revision); | ||
| 517 | Assert.Null(version2.Labels); | ||
| 518 | Assert.Equal("4294967296.4294967296.4294967296.4294967296", version2.Metadata); | ||
| 519 | Assert.True(version2.Invalid); | ||
| 520 | Assert.False(version2.HasMajor); | ||
| 521 | Assert.False(version2.HasMinor); | ||
| 522 | Assert.False(version2.HasPatch); | ||
| 523 | Assert.False(version2.HasRevision); | ||
| 524 | |||
| 525 | TestVerutilCompareParsedVersions(version1, version2, 1); | ||
| 526 | } | ||
| 527 | |||
| 528 | [Fact] | ||
| 529 | public void VerCompareVersionsIgnoresMetadataForValidVersions() | ||
| 530 | { | ||
| 531 | var version1 = WixVersion.Parse("1.2.3+abc"); | ||
| 532 | var version2 = WixVersion.Parse("1.2.3+xyz"); | ||
| 533 | |||
| 534 | Assert.Null(version1.Prefix); | ||
| 535 | Assert.Equal(1U, version1.Major); | ||
| 536 | Assert.Equal(2U, version1.Minor); | ||
| 537 | Assert.Equal(3U, version1.Patch); | ||
| 538 | Assert.Equal(0U, version1.Revision); | ||
| 539 | Assert.Null(version1.Labels); | ||
| 540 | Assert.Equal("abc", version1.Metadata); | ||
| 541 | Assert.False(version1.Invalid); | ||
| 542 | Assert.True(version1.HasMajor); | ||
| 543 | Assert.True(version1.HasMinor); | ||
| 544 | Assert.True(version1.HasPatch); | ||
| 545 | Assert.False(version1.HasRevision); | ||
| 546 | |||
| 547 | |||
| 548 | Assert.Null(version2.Prefix); | ||
| 549 | Assert.Equal(1U, version2.Major); | ||
| 550 | Assert.Equal(2U, version2.Minor); | ||
| 551 | Assert.Equal(3U, version2.Patch); | ||
| 552 | Assert.Equal(0U, version2.Revision); | ||
| 553 | Assert.Null(version2.Labels); | ||
| 554 | Assert.Equal("xyz", version2.Metadata); | ||
| 555 | Assert.False(version2.Invalid); | ||
| 556 | Assert.True(version2.HasMajor); | ||
| 557 | Assert.True(version2.HasMinor); | ||
| 558 | Assert.True(version2.HasPatch); | ||
| 559 | Assert.False(version2.HasRevision); | ||
| 560 | |||
| 561 | TestVerutilCompareParsedVersions(version1, version2, 0); | ||
| 562 | } | ||
| 563 | |||
| 564 | [Fact] | ||
| 565 | public void VerParseVersionTreatsTrailingDotsAsInvalid() | ||
| 566 | { | ||
| 567 | var version1 = WixVersion.Parse("."); | ||
| 568 | var version2 = WixVersion.Parse("1."); | ||
| 569 | var version3 = WixVersion.Parse("2.1."); | ||
| 570 | var version4 = WixVersion.Parse("3.2.1."); | ||
| 571 | var version5 = WixVersion.Parse("4.3.2.1."); | ||
| 572 | var version6 = WixVersion.Parse("5-."); | ||
| 573 | var version7 = WixVersion.Parse("6-a."); | ||
| 574 | |||
| 575 | Assert.Null(version1.Prefix); | ||
| 576 | Assert.Equal(0U, version1.Major); | ||
| 577 | Assert.Equal(0U, version1.Minor); | ||
| 578 | Assert.Equal(0U, version1.Patch); | ||
| 579 | Assert.Equal(0U, version1.Revision); | ||
| 580 | Assert.Null(version1.Labels); | ||
| 581 | Assert.Equal(".", version1.Metadata); | ||
| 582 | Assert.True(version1.Invalid); | ||
| 583 | Assert.False(version1.HasMajor); | ||
| 584 | Assert.False(version1.HasMinor); | ||
| 585 | Assert.False(version1.HasPatch); | ||
| 586 | Assert.False(version1.HasRevision); | ||
| 587 | |||
| 588 | |||
| 589 | Assert.Null(version2.Prefix); | ||
| 590 | Assert.Equal(1U, version2.Major); | ||
| 591 | Assert.Equal(0U, version2.Minor); | ||
| 592 | Assert.Equal(0U, version2.Patch); | ||
| 593 | Assert.Equal(0U, version2.Revision); | ||
| 594 | Assert.Null(version2.Labels); | ||
| 595 | Assert.Empty(version2.Metadata); | ||
| 596 | Assert.True(version2.Invalid); | ||
| 597 | Assert.True(version2.HasMajor); | ||
| 598 | Assert.False(version2.HasMinor); | ||
| 599 | Assert.False(version2.HasPatch); | ||
| 600 | Assert.False(version2.HasRevision); | ||
| 601 | |||
| 602 | |||
| 603 | Assert.Null(version3.Prefix); | ||
| 604 | Assert.Equal(2U, version3.Major); | ||
| 605 | Assert.Equal(1U, version3.Minor); | ||
| 606 | Assert.Equal(0U, version3.Patch); | ||
| 607 | Assert.Equal(0U, version3.Revision); | ||
| 608 | Assert.Null(version3.Labels); | ||
| 609 | Assert.Empty(version3.Metadata); | ||
| 610 | Assert.True(version3.Invalid); | ||
| 611 | Assert.True(version3.HasMajor); | ||
| 612 | Assert.True(version3.HasMinor); | ||
| 613 | Assert.False(version3.HasPatch); | ||
| 614 | Assert.False(version3.HasRevision); | ||
| 615 | |||
| 616 | Assert.Null(version4.Prefix); | ||
| 617 | Assert.Equal(3U, version4.Major); | ||
| 618 | Assert.Equal(2U, version4.Minor); | ||
| 619 | Assert.Equal(1U, version4.Patch); | ||
| 620 | Assert.Equal(0U, version4.Revision); | ||
| 621 | Assert.Null(version4.Labels); | ||
| 622 | Assert.Empty(version4.Metadata); | ||
| 623 | Assert.True(version4.Invalid); | ||
| 624 | Assert.True(version4.HasMajor); | ||
| 625 | Assert.True(version4.HasMinor); | ||
| 626 | Assert.True(version4.HasPatch); | ||
| 627 | Assert.False(version4.HasRevision); | ||
| 628 | |||
| 629 | Assert.Null(version5.Prefix); | ||
| 630 | Assert.Equal(4U, version5.Major); | ||
| 631 | Assert.Equal(3U, version5.Minor); | ||
| 632 | Assert.Equal(2U, version5.Patch); | ||
| 633 | Assert.Equal(1U, version5.Revision); | ||
| 634 | Assert.Null(version5.Labels); | ||
| 635 | Assert.Empty(version5.Metadata); | ||
| 636 | Assert.True(version5.Invalid); | ||
| 637 | Assert.True(version5.HasMajor); | ||
| 638 | Assert.True(version5.HasMinor); | ||
| 639 | Assert.True(version5.HasPatch); | ||
| 640 | Assert.True(version5.HasRevision); | ||
| 641 | |||
| 642 | Assert.Null(version6.Prefix); | ||
| 643 | Assert.Equal(5U, version6.Major); | ||
| 644 | Assert.Equal(0U, version6.Minor); | ||
| 645 | Assert.Equal(0U, version6.Patch); | ||
| 646 | Assert.Equal(0U, version6.Revision); | ||
| 647 | Assert.Null(version6.Labels); | ||
| 648 | Assert.Equal(".", version6.Metadata); | ||
| 649 | Assert.True(version6.Invalid); | ||
| 650 | Assert.True(version6.HasMajor); | ||
| 651 | Assert.False(version6.HasMinor); | ||
| 652 | Assert.False(version6.HasPatch); | ||
| 653 | Assert.False(version6.HasRevision); | ||
| 654 | |||
| 655 | Assert.Null(version7.Prefix); | ||
| 656 | Assert.Equal(6U, version7.Major); | ||
| 657 | Assert.Equal(0U, version7.Minor); | ||
| 658 | Assert.Equal(0U, version7.Patch); | ||
| 659 | Assert.Equal(0U, version7.Revision); | ||
| 660 | Assert.Single(version7.Labels); | ||
| 661 | Assert.Null(version7.Labels[0].Numeric); | ||
| 662 | Assert.Equal("a", version7.Labels[0].Label); | ||
| 663 | Assert.Empty(version7.Metadata); | ||
| 664 | Assert.True(version7.Invalid); | ||
| 665 | Assert.True(version7.HasMajor); | ||
| 666 | Assert.False(version7.HasMinor); | ||
| 667 | Assert.False(version7.HasPatch); | ||
| 668 | Assert.False(version7.HasRevision); | ||
| 669 | } | ||
| 670 | |||
| 671 | private static void TestVerutilCompareParsedVersions(WixVersion version1, WixVersion version2, int expectedResult) | ||
| 672 | { | ||
| 673 | var result = version1.CompareTo(version2); | ||
| 674 | Assert.Equal(expectedResult, result); | ||
| 675 | |||
| 676 | result = version2.CompareTo(version1); | ||
| 677 | Assert.Equal(expectedResult, -result); | ||
| 678 | |||
| 679 | var equal = version1.Equals(version2); | ||
| 680 | Assert.Equal(expectedResult == 0, equal); | ||
| 681 | } | ||
| 682 | } | ||
| 683 | } | ||
diff --git a/src/libs/test/WixToolsetTest.Versioning/WixToolsetTest.Versioning.csproj b/src/libs/test/WixToolsetTest.Versioning/WixToolsetTest.Versioning.csproj new file mode 100644 index 00000000..0ac65fec --- /dev/null +++ b/src/libs/test/WixToolsetTest.Versioning/WixToolsetTest.Versioning.csproj | |||
| @@ -0,0 +1,17 @@ | |||
| 1 | <?xml version="1.0" encoding="utf-8"?> | ||
| 2 | <!-- Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. --> | ||
| 3 | |||
| 4 | <Project Sdk="Microsoft.NET.Sdk"> | ||
| 5 | <PropertyGroup> | ||
| 6 | <TargetFramework>net6.0</TargetFramework> | ||
| 7 | <IsWixTestProject>true</IsWixTestProject> | ||
| 8 | </PropertyGroup> | ||
| 9 | |||
| 10 | <ItemGroup> | ||
| 11 | <ProjectReference Include="..\..\WixToolset.Versioning\WixToolset.Versioning.csproj" /> | ||
| 12 | </ItemGroup> | ||
| 13 | |||
| 14 | <ItemGroup> | ||
| 15 | <PackageReference Include="WixBuildTools.TestSupport" /> | ||
| 16 | </ItemGroup> | ||
| 17 | </Project> | ||
diff --git a/src/api/wix/test/WixToolsetTest.Data/WixVerFixture.cs b/src/libs/test/WixToolsetTest.Versioning/WixVerFixture.cs index 56c72896..9026cba6 100644 --- a/src/api/wix/test/WixToolsetTest.Data/WixVerFixture.cs +++ b/src/libs/test/WixToolsetTest.Versioning/WixVerFixture.cs | |||
| @@ -1,10 +1,10 @@ | |||
| 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. | 1 | // Copyright (c) .NET Foundation and contributors. All rights reserved. Licensed under the Microsoft Reciprocal License. See LICENSE.TXT file in the project root for full license information. |
| 2 | 2 | ||
| 3 | namespace WixToolsetTest.Data | 3 | namespace WixToolsetTest.Versioning |
| 4 | { | 4 | { |
| 5 | using System; | 5 | using System; |
| 6 | using System.Linq; | 6 | using System.Linq; |
| 7 | using WixToolset.Data; | 7 | using WixToolset.Versioning; |
| 8 | using Xunit; | 8 | using Xunit; |
| 9 | 9 | ||
| 10 | public class WixVerFixture | 10 | public class WixVerFixture |
| @@ -404,5 +404,48 @@ namespace WixToolsetTest.Data | |||
| 404 | Assert.Equal(String.Empty, version.Metadata); | 404 | Assert.Equal(String.Empty, version.Metadata); |
| 405 | Assert.True(version.Invalid); | 405 | Assert.True(version.Invalid); |
| 406 | } | 406 | } |
| 407 | |||
| 408 | [Fact] | ||
| 409 | public void CanCompareVersions() | ||
| 410 | { | ||
| 411 | var version1 = WixVersion.Parse("1"); | ||
| 412 | var version10 = WixVersion.Parse("1.0"); | ||
| 413 | var version100 = WixVersion.Parse("1.0.0"); | ||
| 414 | var version2 = WixVersion.Parse("2.0.0"); | ||
| 415 | var version201 = WixVersion.Parse("2.0.1"); | ||
| 416 | var version2a = WixVersion.Parse("2-a"); | ||
| 417 | var version2b = WixVersion.Parse("2-b"); | ||
| 418 | var versionInvalid3a = WixVersion.Parse("3.-a"); | ||
| 419 | var versionInvalid3b = WixVersion.Parse("3.-b"); | ||
| 420 | |||
| 421 | Assert.Equal(version1, version1); | ||
| 422 | Assert.Equal(version1, version10); | ||
| 423 | Assert.True(version1 == version10); | ||
| 424 | Assert.True(version1 == version100); | ||
| 425 | Assert.True(version1 <= version10); | ||
| 426 | Assert.True(version1 >= version10); | ||
| 427 | Assert.False(version1 != version10); | ||
| 428 | Assert.False(version1 < version10); | ||
| 429 | Assert.False(version1 < version100); | ||
| 430 | Assert.False(version1 > version10); | ||
| 431 | Assert.False(version1 > version100); | ||
| 432 | |||
| 433 | Assert.NotEqual(version1, version2); | ||
| 434 | Assert.True(version1 < version2); | ||
| 435 | Assert.False(version1 > version2); | ||
| 436 | |||
| 437 | Assert.True(version2 > version2a); | ||
| 438 | Assert.True(version2 != version2a); | ||
| 439 | Assert.False(version2 < version2a); | ||
| 440 | |||
| 441 | Assert.True(version2 < version201); | ||
| 442 | |||
| 443 | Assert.True(version2a < version2b); | ||
| 444 | Assert.False(version2a > version2b); | ||
| 445 | |||
| 446 | Assert.True(versionInvalid3a < versionInvalid3b); | ||
| 447 | |||
| 448 | Assert.True(version1 < versionInvalid3a); | ||
| 449 | } | ||
| 407 | } | 450 | } |
| 408 | } | 451 | } |
diff --git a/src/testresultfilelist.txt b/src/testresultfilelist.txt index 87de7c4e..59584e64 100644 --- a/src/testresultfilelist.txt +++ b/src/testresultfilelist.txt | |||
| @@ -20,4 +20,5 @@ build/logs/TestResults/WixToolsetTest.ManagedHost.trx | |||
| 20 | build/logs/TestResults/WixToolsetTest.Mba.Core.trx | 20 | build/logs/TestResults/WixToolsetTest.Mba.Core.trx |
| 21 | build/logs/TestResults/WixToolsetTest.MsiE2E.trx | 21 | build/logs/TestResults/WixToolsetTest.MsiE2E.trx |
| 22 | build/logs/TestResults/WixToolsetTest.Sdk.trx | 22 | build/logs/TestResults/WixToolsetTest.Sdk.trx |
| 23 | build/logs/TestResults/WixToolsetTest.Versioning.trx | ||
| 23 | build/logs/TestResults/WixToolsetTest.WixE2ETests.trx \ No newline at end of file | 24 | build/logs/TestResults/WixToolsetTest.WixE2ETests.trx \ No newline at end of file |
diff --git a/src/wix/WixToolset.Core.Burn/Bind/BindBundleCommand.cs b/src/wix/WixToolset.Core.Burn/Bind/BindBundleCommand.cs index d001bf50..6ae3520f 100644 --- a/src/wix/WixToolset.Core.Burn/Bind/BindBundleCommand.cs +++ b/src/wix/WixToolset.Core.Burn/Bind/BindBundleCommand.cs | |||
| @@ -17,6 +17,7 @@ namespace WixToolset.Core.Burn | |||
| 17 | using WixToolset.Extensibility; | 17 | using WixToolset.Extensibility; |
| 18 | using WixToolset.Extensibility.Data; | 18 | using WixToolset.Extensibility.Data; |
| 19 | using WixToolset.Extensibility.Services; | 19 | using WixToolset.Extensibility.Services; |
| 20 | using WixToolset.Versioning; | ||
| 20 | 21 | ||
| 21 | /// <summary> | 22 | /// <summary> |
| 22 | /// Binds a this.bundle. | 23 | /// Binds a this.bundle. |
diff --git a/src/wix/WixToolset.Core.Burn/Bundles/CreateBundleExeCommand.cs b/src/wix/WixToolset.Core.Burn/Bundles/CreateBundleExeCommand.cs index 4aed18da..aa4730fb 100644 --- a/src/wix/WixToolset.Core.Burn/Bundles/CreateBundleExeCommand.cs +++ b/src/wix/WixToolset.Core.Burn/Bundles/CreateBundleExeCommand.cs | |||
| @@ -15,6 +15,7 @@ namespace WixToolset.Core.Burn.Bundles | |||
| 15 | using WixToolset.Dtf.Resources; | 15 | using WixToolset.Dtf.Resources; |
| 16 | using WixToolset.Extensibility.Data; | 16 | using WixToolset.Extensibility.Data; |
| 17 | using WixToolset.Extensibility.Services; | 17 | using WixToolset.Extensibility.Services; |
| 18 | using WixToolset.Versioning; | ||
| 18 | 19 | ||
| 19 | internal class CreateBundleExeCommand | 20 | internal class CreateBundleExeCommand |
| 20 | { | 21 | { |
diff --git a/src/wix/WixToolset.Core.Burn/WixToolset.Core.Burn.csproj b/src/wix/WixToolset.Core.Burn/WixToolset.Core.Burn.csproj index 754af45e..d56ed326 100644 --- a/src/wix/WixToolset.Core.Burn/WixToolset.Core.Burn.csproj +++ b/src/wix/WixToolset.Core.Burn/WixToolset.Core.Burn.csproj | |||
| @@ -15,7 +15,6 @@ | |||
| 15 | </PropertyGroup> | 15 | </PropertyGroup> |
| 16 | 16 | ||
| 17 | <ItemGroup> | 17 | <ItemGroup> |
| 18 | <ProjectReference Include="..\WixToolset.Core\WixToolset.Core.csproj" /> | ||
| 19 | <ProjectReference Include="..\WixToolset.Core.Native\WixToolset.Core.Native.csproj" /> | 18 | <ProjectReference Include="..\WixToolset.Core.Native\WixToolset.Core.Native.csproj" /> |
| 20 | </ItemGroup> | 19 | </ItemGroup> |
| 21 | 20 | ||
| @@ -24,5 +23,6 @@ | |||
| 24 | <PackageReference Include="WixToolset.Data" /> | 23 | <PackageReference Include="WixToolset.Data" /> |
| 25 | <PackageReference Include="WixToolset.Dtf.Resources" /> | 24 | <PackageReference Include="WixToolset.Dtf.Resources" /> |
| 26 | <PackageReference Include="WixToolset.Extensibility" /> | 25 | <PackageReference Include="WixToolset.Extensibility" /> |
| 26 | <PackageReference Include="WixToolset.Versioning" /> | ||
| 27 | </ItemGroup> | 27 | </ItemGroup> |
| 28 | </Project> | 28 | </Project> |
diff --git a/src/wix/WixToolset.Core.WindowsInstaller/Bind/ProcessPackageSoftwareTagsCommand.cs b/src/wix/WixToolset.Core.WindowsInstaller/Bind/ProcessPackageSoftwareTagsCommand.cs index 67815fcf..1348f163 100644 --- a/src/wix/WixToolset.Core.WindowsInstaller/Bind/ProcessPackageSoftwareTagsCommand.cs +++ b/src/wix/WixToolset.Core.WindowsInstaller/Bind/ProcessPackageSoftwareTagsCommand.cs | |||
| @@ -11,6 +11,7 @@ namespace WixToolset.Core.WindowsInstaller.Bind | |||
| 11 | using WixToolset.Data.Symbols; | 11 | using WixToolset.Data.Symbols; |
| 12 | using WixToolset.Extensibility.Data; | 12 | using WixToolset.Extensibility.Data; |
| 13 | using WixToolset.Extensibility.Services; | 13 | using WixToolset.Extensibility.Services; |
| 14 | using WixToolset.Versioning; | ||
| 14 | 15 | ||
| 15 | internal class ProcessPackageSoftwareTagsCommand | 16 | internal class ProcessPackageSoftwareTagsCommand |
| 16 | { | 17 | { |
diff --git a/src/wix/WixToolset.Core.WindowsInstaller/WixToolset.Core.WindowsInstaller.csproj b/src/wix/WixToolset.Core.WindowsInstaller/WixToolset.Core.WindowsInstaller.csproj index fa4ae68c..1f01fff9 100644 --- a/src/wix/WixToolset.Core.WindowsInstaller/WixToolset.Core.WindowsInstaller.csproj +++ b/src/wix/WixToolset.Core.WindowsInstaller/WixToolset.Core.WindowsInstaller.csproj | |||
| @@ -19,6 +19,7 @@ | |||
| 19 | <ItemGroup> | 19 | <ItemGroup> |
| 20 | <PackageReference Include="WixToolset.Data" /> | 20 | <PackageReference Include="WixToolset.Data" /> |
| 21 | <PackageReference Include="WixToolset.Extensibility" /> | 21 | <PackageReference Include="WixToolset.Extensibility" /> |
| 22 | <PackageReference Include="WixToolset.Versioning" /> | ||
| 22 | </ItemGroup> | 23 | </ItemGroup> |
| 23 | 24 | ||
| 24 | <ItemGroup> | 25 | <ItemGroup> |
diff --git a/src/wix/WixToolset.Core/Common.cs b/src/wix/WixToolset.Core/Common.cs index c838463d..f581e1a4 100644 --- a/src/wix/WixToolset.Core/Common.cs +++ b/src/wix/WixToolset.Core/Common.cs | |||
| @@ -14,6 +14,7 @@ namespace WixToolset.Core | |||
| 14 | using WixToolset.Data; | 14 | using WixToolset.Data; |
| 15 | using WixToolset.Extensibility; | 15 | using WixToolset.Extensibility; |
| 16 | using WixToolset.Extensibility.Services; | 16 | using WixToolset.Extensibility.Services; |
| 17 | using WixToolset.Versioning; | ||
| 17 | 18 | ||
| 18 | /// <summary> | 19 | /// <summary> |
| 19 | /// Common Wix utility methods and types. | 20 | /// Common Wix utility methods and types. |
diff --git a/src/wix/WixToolset.Core/ExtensibilityServices/BackendHelper.cs b/src/wix/WixToolset.Core/ExtensibilityServices/BackendHelper.cs index 4a5cc607..43f7aa01 100644 --- a/src/wix/WixToolset.Core/ExtensibilityServices/BackendHelper.cs +++ b/src/wix/WixToolset.Core/ExtensibilityServices/BackendHelper.cs | |||
| @@ -8,6 +8,7 @@ namespace WixToolset.Core.ExtensibilityServices | |||
| 8 | using WixToolset.Data; | 8 | using WixToolset.Data; |
| 9 | using WixToolset.Extensibility.Data; | 9 | using WixToolset.Extensibility.Data; |
| 10 | using WixToolset.Extensibility.Services; | 10 | using WixToolset.Extensibility.Services; |
| 11 | using WixToolset.Versioning; | ||
| 11 | 12 | ||
| 12 | internal class BackendHelper : LayoutServices, IBackendHelper | 13 | internal class BackendHelper : LayoutServices, IBackendHelper |
| 13 | { | 14 | { |
diff --git a/src/wix/WixToolset.Core/ExtensibilityServices/ParseHelper.cs b/src/wix/WixToolset.Core/ExtensibilityServices/ParseHelper.cs index 5f4ac726..0ec5b514 100644 --- a/src/wix/WixToolset.Core/ExtensibilityServices/ParseHelper.cs +++ b/src/wix/WixToolset.Core/ExtensibilityServices/ParseHelper.cs | |||
| @@ -15,6 +15,7 @@ namespace WixToolset.Core.ExtensibilityServices | |||
| 15 | using WixToolset.Extensibility; | 15 | using WixToolset.Extensibility; |
| 16 | using WixToolset.Extensibility.Data; | 16 | using WixToolset.Extensibility.Data; |
| 17 | using WixToolset.Extensibility.Services; | 17 | using WixToolset.Extensibility.Services; |
| 18 | using WixToolset.Versioning; | ||
| 18 | 19 | ||
| 19 | internal class ParseHelper : IParseHelper | 20 | internal class ParseHelper : IParseHelper |
| 20 | { | 21 | { |
diff --git a/src/wix/WixToolset.Core/WixToolset.Core.csproj b/src/wix/WixToolset.Core/WixToolset.Core.csproj index f2ee3a2c..42b0c0c7 100644 --- a/src/wix/WixToolset.Core/WixToolset.Core.csproj +++ b/src/wix/WixToolset.Core/WixToolset.Core.csproj | |||
| @@ -17,6 +17,7 @@ | |||
| 17 | <ItemGroup> | 17 | <ItemGroup> |
| 18 | <PackageReference Include="WixToolset.Data" /> | 18 | <PackageReference Include="WixToolset.Data" /> |
| 19 | <PackageReference Include="WixToolset.Extensibility" /> | 19 | <PackageReference Include="WixToolset.Extensibility" /> |
| 20 | <PackageReference Include="WixToolset.Versioning" /> | ||
| 20 | </ItemGroup> | 21 | </ItemGroup> |
| 21 | 22 | ||
| 22 | <ItemGroup> | 23 | <ItemGroup> |
