Exemplo n.º 1
0
        // see https://github.com/uniVocity/csv-parsers-comparison
        public void CsvParsing_should_parse_uniVocity_correctness_test()
        {
            var fut = FileIO.FromFile(new FileInfo("resources/correctness.csv"))
                      .Via(CsvParsing.LineScanner(escapeChar: 0x01))
                      .Via(CsvToDictionary.ToDictionary())
                      .Select(dict =>
            {
                var outDict = new Dictionary <string, string>();
                foreach (var pair in dict)
                {
                    outDict.Add(pair.Key, pair.Value.DecodeString(Encoding.UTF8));
                }
                return(outDict);
            })
                      .RunWith(Sink.Seq <Dictionary <string, string> >(), Materializer);

            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new Dictionary <string, string>()
            {
                { "Year", "1997" },
                { "Make", "Ford" },
                { "Model", "E350" },
                { "Description", "ac, abs, moon" },
                { "Price", "3000.00" },
            });
            res[1].ShouldAllBeEquivalentTo(new Dictionary <string, string>()
            {
                { "Year", "1999" },
                { "Make", "Chevy" },
                { "Model", "Venture \"Extended Edition\"" },
                { "Description", "" },
                { "Price", "4900.00" },
            });
            res[2].ShouldAllBeEquivalentTo(new Dictionary <string, string>()
            {
                { "Year", "1996" },
                { "Make", "Jeep" },
                { "Model", "Grand Cherokee" },
                { "Description", "MUST SELL!\nair, moon roof, loaded" },
                { "Price", "4799.00" },
            });
            res[3].ShouldAllBeEquivalentTo(new Dictionary <string, string>()
            {
                { "Year", "1999" },
                { "Make", "Chevy" },
                { "Model", "Venture \"Extended Edition, Very Large\"" },
                { "Description", "" },
                { "Price", "5000.00" },
            });
            res[4].ShouldAllBeEquivalentTo(new Dictionary <string, string>()
            {
                { "Year", "" },
                { "Make", "" },
                { "Model", "Venture \"Extended Edition\"" },
                { "Description", "" },
                { "Price", "4900.00" },
            });
        }
Exemplo n.º 2
0
        public void CsvParsing_should_parse_one_line()
        {
            var fut = Source
                      .Single(ByteString.FromString("eins,zwei,drei\n"))
                      .Via(CsvParsing.LineScanner())
                      .RunWith(Sink.First <ImmutableList <ByteString> >(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            fut.Result.ShouldAllBeEquivalentTo(new[] { ByteString.FromString("eins"), ByteString.FromString("zwei"), ByteString.FromString("drei") });
        }
Exemplo n.º 3
0
        public void CsvParsing_should_parse_Google_Docs_exported_file()
        {
            var fut = FileIO.FromFile(new FileInfo("resources/google-docs.csv"))
                      .Via(CsvParsing.LineScanner(escapeChar: 0x01))
                      .Select(list => list.Select(bs => bs.DecodeString(Encoding.UTF8)).ToArray())
                      .RunWith(Sink.Seq <string[]>(), Materializer);

            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new[] { "abc", "def", "ghi" });
            res[1].ShouldAllBeEquivalentTo(new[] { "\"", "\\\\,", "a\"\nb\"\"c" });
        }
Exemplo n.º 4
0
        public void CsvParsing_should_parse_Apple_Numbers_exported_file()
        {
            var fut = FileIO.FromFile(new FileInfo("resources/numbers-utf-8.csv"))
                      .Via(CsvParsing.LineScanner(delimiter: CsvParsing.SemiColon, escapeChar: 0x01))
                      .Select(list => list.Select(bs => bs.DecodeString(Encoding.UTF8)).ToArray())
                      .RunWith(Sink.Seq <string[]>(), Materializer);

            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new[] { "abc", "def", "ghi", "", "", "", "" });
            res[1].ShouldAllBeEquivalentTo(new[] { "\"", "\\\\;", "a\"\nb\"\"c", "", "", "", "" });
        }
Exemplo n.º 5
0
        public void CsvParsing_should_parse_two_line_even_without_line_end()
        {
            var fut = Source
                      .Single(ByteString.FromString("eins,zwei,drei\nuno,dos,tres"))
                      .Via(CsvParsing.LineScanner())
                      .RunWith(Sink.Seq <ImmutableList <ByteString> >(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new[] { ByteString.FromString("eins"), ByteString.FromString("zwei"), ByteString.FromString("drei") });
            res[1].ShouldAllBeEquivalentTo(new[] { ByteString.FromString("uno"), ByteString.FromString("dos"), ByteString.FromString("tres") });
        }
Exemplo n.º 6
0
        public void CsvParsing_should_parse_semicolon_lines()
        {
            var fut = Source
                      .Single(ByteString.FromString("eins;zwei;drei\nein”s;zw ei;dr\\ei\nun’o;dos;tres\n"))
                      .Via(CsvParsing.LineScanner(delimiter: CsvParsing.SemiColon, escapeChar: 0x2a /*'*'*/))
                      .Select(list => list.Select(bs => bs.DecodeString()).ToArray())
                      .RunWith(Sink.Seq <string[]>(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new[] { "eins", "zwei", "drei" });
            res[1].ShouldAllBeEquivalentTo(new[] { "ein”s", "zw ei", "dr\\ei" });
        }
Exemplo n.º 7
0
        public void CsvToDictionary_should_be_OK_with_fewer_header_columns_than_data()
        {
            var fut = Source.Single(ByteString.FromString("eins,zwei\n1,2,3"))
                      .Via(CsvParsing.LineScanner())
                      .Via(CsvToDictionary.ToDictionary())
                      .RunWith(Sink.First <Dictionary <string, ByteString> >(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            fut.Result.Should().BeEquivalentTo(new Dictionary <string, ByteString>
            {
                { "eins", ByteString.FromString("1") },
                { "zwei", ByteString.FromString("2") },
            }, opt => opt.WithStrictOrdering());
        }
Exemplo n.º 8
0
        public void CsvToDictionary_should_use_column_names_and_data_line_into_map()
        {
            var fut = Source.Single(ByteString.FromString("1,2,3"))
                      .Via(CsvParsing.LineScanner())
                      .Via(CsvToDictionary.WithHeaders(new [] { "eins", "zwei", "drei" }.ToImmutableList()))
                      .RunWith(Sink.First <Dictionary <string, ByteString> >(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            fut.Result.Should().BeEquivalentTo(new Dictionary <string, ByteString>
            {
                { "eins", ByteString.FromString("1") },
                { "zwei", ByteString.FromString("2") },
                { "drei", ByteString.FromString("3") },
            }, opt => opt.WithStrictOrdering());
        }
Exemplo n.º 9
0
        public void CsvToDictionary_should_parse_header_line_and_data_line_into_dictionary()
        {
            var fut = Source.Single(ByteString.FromString("eins,zwei,drei\n1,2,3"))
                      .Via(CsvParsing.LineScanner())
                      .Via(CsvToDictionary.ToDictionary())
                      .RunWith(Sink.First <Dictionary <string, ByteString> >(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            fut.Result.ShouldAllBeEquivalentTo(new Dictionary <string, ByteString>
            {
                { "eins", ByteString.FromString("1") },
                { "zwei", ByteString.FromString("2") },
                { "drei", ByteString.FromString("3") },
            });
        }
Exemplo n.º 10
0
        public void CsvParsing_should_emit_completion_even_without_new_line_at_end()
        {
            var t = this.SourceProbe <ByteString>()
                    .Via(CsvParsing.LineScanner())
                    .Select(list => list.Select(bs => bs.DecodeString(Encoding.UTF8)).ToArray())
                    .ToMaterialized(this.SinkProbe <string[]>(), Keep.Both)
                    .Run(Materializer);
            var source = t.Item1;
            var sink   = t.Item2;

            source.SendNext(ByteString.FromString("eins,zwei,drei\nuno,dos,tres\n1,2,3"));
            sink.Request(3);
            sink.ExpectNext().ShouldAllBeEquivalentTo(new[] { "eins", "zwei", "drei" });
            sink.ExpectNext().ShouldAllBeEquivalentTo(new[] { "uno", "dos", "tres" });
            sink.ExpectNoMsg(TimeSpan.FromMilliseconds(100));
            source.SendComplete();
            sink.ExpectNext().ShouldAllBeEquivalentTo(new[] { "1", "2", "3" });
            sink.ExpectComplete();
        }
Exemplo n.º 11
0
        public void CsvParsing_should_parse_chunks_successfully()
        {
            var input = new[]
            {
                ByteString.FromString("eins,zw"),
                ByteString.FromString("ei,drei\nuno"),
                ByteString.FromString(",dos,tres\n")
            };
            var fut = Source
                      .From(input)
                      .Via(CsvParsing.LineScanner())
                      .Select(list => list.Select(bs => bs.DecodeString()).ToArray())
                      .RunWith(Sink.Seq <string[]>(), Materializer);

            fut.Wait(TimeSpan.FromSeconds(3));
            var res = fut.Result;

            res[0].ShouldAllBeEquivalentTo(new[] { "eins", "zwei", "drei" });
            res[1].ShouldAllBeEquivalentTo(new[] { "uno", "dos", "tres" });
        }