diff options
author | crupest <crupest@outlook.com> | 2021-02-12 22:39:57 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-02-12 22:39:57 +0800 |
commit | c3d0a5f88de0fbdf6bc584548832017087ab1248 (patch) | |
tree | c1c992987263897fb1c091c5129c6d1f1e64073d /BackEnd/Timeline.Tests/XUnitHelper.cs | |
parent | e232e31de839dc0c0de691c5856f29dcb92cf0fc (diff) | |
parent | 5849d34d9fcf1ccfb7fe5cc0842765129f7198b4 (diff) | |
download | timeline-c3d0a5f88de0fbdf6bc584548832017087ab1248.tar.gz timeline-c3d0a5f88de0fbdf6bc584548832017087ab1248.tar.bz2 timeline-c3d0a5f88de0fbdf6bc584548832017087ab1248.zip |
Merge pull request #267 from crupest/backend
春节大换血 Spring festival big change.
Diffstat (limited to 'BackEnd/Timeline.Tests/XUnitHelper.cs')
-rw-r--r-- | BackEnd/Timeline.Tests/XUnitHelper.cs | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/BackEnd/Timeline.Tests/XUnitHelper.cs b/BackEnd/Timeline.Tests/XUnitHelper.cs new file mode 100644 index 00000000..a2812ad3 --- /dev/null +++ b/BackEnd/Timeline.Tests/XUnitHelper.cs @@ -0,0 +1,44 @@ +using System;
+using System.Collections.Generic;
+using System.Linq;
+
+namespace Timeline.Tests
+{
+ public static class XUnitHelper
+ {
+ public static IEnumerable<object?[]> ComposeTestData(params IEnumerable<object?[]>[] testDatas)
+ {
+ return ComposeTestData(new ArraySegment<IEnumerable<object?[]>>(testDatas));
+ }
+
+ public static IEnumerable<object?[]> ComposeTestData(ArraySegment<IEnumerable<object?[]>> testDatas)
+ {
+ if (testDatas.Count == 0)
+ throw new ArgumentException("Test data list can't be empty.", nameof(testDatas));
+
+ if (testDatas.Count == 1)
+ {
+ foreach (var d in testDatas[0])
+ yield return d;
+ }
+ else
+ {
+ foreach (var head in testDatas[0])
+ foreach (var rest in ComposeTestData(testDatas.Slice(1)))
+ yield return head.Concat(rest).ToArray();
+ }
+ }
+
+ public static IEnumerable<object?[]> AppendTestData(this IEnumerable<object?[]> origin, params IEnumerable<object?>[] toAppend)
+ {
+ IEnumerable<object?[]> result = origin;
+
+ foreach (var oneToAppend in toAppend)
+ {
+ result = ComposeTestData(result, oneToAppend.Select(testData => new object?[] { testData }));
+ }
+
+ return result;
+ }
+ }
+}
|