summaryrefslogtreecommitdiff
path: root/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues
diff options
context:
space:
mode:
Diffstat (limited to 'ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues')
-rw-r--r--ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue1954.cs178
-rw-r--r--ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue920.cs59
2 files changed, 237 insertions, 0 deletions
diff --git a/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue1954.cs b/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue1954.cs
new file mode 100644
index 0000000..0fc4b55
--- /dev/null
+++ b/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue1954.cs
@@ -0,0 +1,178 @@
+// Copyright 2009-2022 Josh Close
+// This file is a part of CsvHelper and is dual licensed under MS-PL and Apache 2.0.
+// See LICENSE.txt for details or visit http://www.opensource.org/licenses/ms-pl.html for MS-PL and http://opensource.org/licenses/Apache-2.0 for Apache 2.0.
+// https://github.com/JoshClose/CsvHelper
+using CsvHelper.Configuration;
+using CsvHelper.Configuration.Attributes;
+using System.Globalization;
+using System.IO;
+using System.Linq;
+using Xunit;
+
+namespace CsvHelper.Tests.Issues
+{
+ public class Issue1954
+ {
+ [Fact]
+ public void Test1()
+ {
+ var data = @"field1, field2, field3
+1, 2, ""test""
+3, 4, ""TEST""";
+
+ var opts = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = ",",
+ TrimOptions = TrimOptions.Trim,
+ BufferSize = 44
+ };
+
+ using (var sr = new StringReader(data))
+ using (var csv = new CsvReader(sr, opts))
+ {
+ var records = csv.GetRecords<Row>().ToArray();
+
+ Assert.Equal(2, records.Length);
+
+ Assert.Equal(1, records[0].Field1);
+ Assert.Equal(2, records[0].Field2);
+ Assert.Equal("test", records[0].Field3);
+
+ Assert.Equal(3, records[1].Field1);
+ Assert.Equal(4, records[1].Field2);
+ Assert.Equal("TEST", records[1].Field3);
+ }
+ }
+
+ [Fact]
+ public void Test2()
+ {
+ var data = @"field1, field2, field3
+1, 2, ""test""
+3, 4, ""TEST""";
+
+ var opts = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = ",",
+ TrimOptions = TrimOptions.Trim,
+ BufferSize = 45
+ };
+
+ using (var sr = new StringReader(data))
+ using (var csv = new CsvReader(sr, opts))
+ {
+ var records = csv.GetRecords<Row>().ToArray();
+
+ Assert.Equal(2, records.Length);
+
+ Assert.Equal(1, records[0].Field1);
+ Assert.Equal(2, records[0].Field2);
+ Assert.Equal("test", records[0].Field3);
+
+ Assert.Equal(3, records[1].Field1);
+ Assert.Equal(4, records[1].Field2);
+ Assert.Equal("TEST", records[1].Field3);
+ }
+ }
+
+ [Fact]
+ public void Test3()
+ {
+ var data = @"field1, field2, field3
+1, 2, ""test""
+3, 4, ""TEST""";
+
+ var opts = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = ",",
+ TrimOptions = TrimOptions.Trim,
+ BufferSize = 44
+ };
+
+ using (var sr = new StringReader(data))
+ using (var csv = new CsvReader(sr, opts))
+ {
+ var records = csv.GetRecords<Row>().ToArray();
+
+ Assert.Equal(2, records.Length);
+
+ Assert.Equal(1, records[0].Field1);
+ Assert.Equal(2, records[0].Field2);
+ Assert.Equal("test", records[0].Field3);
+
+ Assert.Equal(3, records[1].Field1);
+ Assert.Equal(4, records[1].Field2);
+ Assert.Equal("TEST", records[1].Field3);
+ }
+ }
+
+ [Fact]
+ public void Test4()
+ {
+ var data = @"field1, field2, field3
+1, 2, ""test""
+3, 4,""TEST""";
+
+ var opts = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = ",",
+ TrimOptions = TrimOptions.Trim,
+ BufferSize = 44
+ };
+
+ using (var sr = new StringReader(data))
+ using (var csv = new CsvReader(sr, opts))
+ {
+ var records = csv.GetRecords<Row>().ToArray();
+
+ Assert.Equal(2, records.Length);
+
+ Assert.Equal(1, records[0].Field1);
+ Assert.Equal(2, records[0].Field2);
+ Assert.Equal("test", records[0].Field3);
+
+ Assert.Equal(3, records[1].Field1);
+ Assert.Equal(4, records[1].Field2);
+ Assert.Equal("TEST", records[1].Field3);
+ }
+ }
+
+ [Fact]
+ public void Test5()
+ {
+ var data = @"field1, field2, field3
+1, 2, ""test""
+3, 4, TEST";
+
+ var opts = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ Delimiter = ",",
+ TrimOptions = TrimOptions.Trim,
+ BufferSize = 44
+ };
+
+ using (var sr = new StringReader(data))
+ using (var csv = new CsvReader(sr, opts))
+ {
+ var records = csv.GetRecords<Row>().ToArray();
+
+ Assert.Equal(2, records.Length);
+
+ Assert.Equal(1, records[0].Field1);
+ Assert.Equal(2, records[0].Field2);
+ Assert.Equal("test", records[0].Field3);
+
+ Assert.Equal(3, records[1].Field1);
+ Assert.Equal(4, records[1].Field2);
+ Assert.Equal("TEST", records[1].Field3);
+ }
+ }
+
+ private class Row
+ {
+ [Name("field1")] public int Field1 { get; set; }
+ [Name("field2")] public int Field2 { get; set; }
+ [Name("field3")] public string Field3 { get; set; }
+ }
+ }
+}
diff --git a/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue920.cs b/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue920.cs
new file mode 100644
index 0000000..1ae38db
--- /dev/null
+++ b/ThirdParty/CsvHelper-master/tests/CsvHelper.Tests/Issues/Issue920.cs
@@ -0,0 +1,59 @@
+// Copyright 2009-2022 Josh Close
+// This file is a part of CsvHelper and is dual licensed under MS-PL and Apache 2.0.
+// See LICENSE.txt for details or visit http://www.opensource.org/licenses/ms-pl.html for MS-PL and http://opensource.org/licenses/Apache-2.0 for Apache 2.0.
+// https://github.com/JoshClose/CsvHelper
+using CsvHelper.Configuration;
+using Xunit;
+using System.Globalization;
+using System.IO;
+using System.Linq;
+using System.Reflection;
+
+namespace CsvHelper.Tests.Issues
+{
+
+ public class Issue920
+ {
+ [Fact]
+ public void Test1()
+ {
+ var config = new CsvConfiguration(CultureInfo.InvariantCulture)
+ {
+ GetConstructor = args =>
+ args.ClassType.GetConstructors(BindingFlags.NonPublic | BindingFlags.Instance)
+ .OrderBy(c => c.GetParameters().Length)
+ .First(),
+ IncludePrivateMembers = true,
+ };
+ using (var stream = new MemoryStream())
+ using (var writer = new StreamWriter(stream))
+ using (var reader = new StreamReader(stream))
+ using (var csv = new CsvReader(reader, config))
+ {
+ writer.WriteLine("A,B");
+ writer.WriteLine("1,one");
+ writer.WriteLine("2,two");
+ writer.Flush();
+ stream.Position = 0;
+
+ var records = csv.GetRecords<Sample>().ToList();
+
+ Assert.Equal(2, records.Count);
+ }
+ }
+
+ private class Sample
+ {
+ public int A { get; private set; }
+ public string B { get; private set; }
+
+ private Sample() { }
+
+ public Sample(int a, string b)
+ {
+ A = a;
+ B = b;
+ }
+ }
+ }
+}