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
|
// 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 System.Globalization;
using System.IO;
using System.Text;
using CsvHelper.Configuration;
using Xunit;
namespace CsvHelper.Tests
{
public class ExcelCompatibilityTests
{
[Fact]
public void Parse_EscapedFieldHasSpaceAfterLastQuote_FieldProcessedLeavingSpaceAtEnd()
{
var s = new StringBuilder();
s.Append("one,\"two\" ,three\r\n"); // one,"two" ,three
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
BadDataFound = null,
};
using (var reader = new StringReader(s.ToString()))
using (var parser = new CsvParser(reader, config))
{
parser.Read();
Assert.Equal(3, parser.Count);
Assert.Equal("one", parser[0]);
Assert.Equal("two ", parser[1]);
Assert.Equal("three", parser[2]);
}
}
[Fact]
public void Parse_EscapedFieldHasSpaceBeforeFirstQuote_FieldIsNotProcessed()
{
var s = new StringBuilder();
s.Append("one, \"two\",three\r\n"); // one, "two",three
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
BadDataFound = null,
};
using (var reader = new StringReader(s.ToString()))
using (var parser = new CsvParser(reader, config))
{
parser.Read();
Assert.Equal(3, parser.Count);
Assert.Equal("one", parser[0]);
Assert.Equal(" \"two\"", parser[1]);
Assert.Equal("three", parser[2]);
}
}
[Fact]
public void Parse_EscapedFieldHasExtraQuoteAfterLastQuote_CharsAfterLastQuoteAreNotProcessed()
{
var s = new StringBuilder();
s.Append("1,\"two\" \"2,3\r\n"); // 1,"two" "2,3
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
BadDataFound = null,
};
using (var reader = new StringReader(s.ToString()))
using (var parser = new CsvParser(reader, config))
{
parser.Read();
Assert.Equal(3, parser.Count);
Assert.Equal("1", parser[0]);
Assert.Equal("two \"2", parser[1]);
Assert.Equal("3", parser[2]);
Assert.False(parser.Read());
}
}
[Fact]
public void Parse_EscapedFieldHasNoEndingQuote_GoesToEndOfFile()
{
var s = new StringBuilder();
s.Append("a,b,\"c\r\n"); // a,b,"c\r\nd,e,f\r\n
s.Append("d,e,f\r\n");
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
BadDataFound = null,
};
using (var reader = new StringReader(s.ToString()))
using (var parser = new CsvParser(reader, config))
{
parser.Read();
Assert.Equal("a", parser[0]);
Assert.Equal("b", parser[1]);
Assert.Equal("c\r\nd,e,f\r\n", parser[2]);
}
}
[Fact]
public void Parse_NonEscapedFieldHasQuotesInIt_IgnoresQuotes()
{
var s = new StringBuilder();
s.Append("1,2\"3\"4,5\r\n"); // 1,2"3"4,5
var config = new CsvConfiguration(CultureInfo.InvariantCulture)
{
BadDataFound = null,
};
using (var reader = new StringReader(s.ToString()))
using (var parser = new CsvParser(reader, config))
{
parser.Read();
Assert.Equal(3, parser.Count);
Assert.Equal("1", parser[0]);
Assert.Equal("2\"3\"4", parser[1]);
Assert.Equal("5", parser[2]);
}
}
}
}
|