public void AutoDetectColumnsTest()
        {
            var csv =
            @"1, 16000, 12345678, 12345678901234, 123.45, 1.1234567e5, 0.123456789012e-12,text";

            var f = new CsvFile(new StringReader(csv));
            f.ColumnNamesInFirstLine = false;
            f.AutoDetectColumns = true;
            f.AutoDetectColumnsCount = 100;
            f.GenerateIdentityColumn = true;

            var dr = f.OpenDataReader();

            dr.Read();

            int o = 0;

            Assert.AreEqual(1, dr.GetInt64(o++));
            Assert.AreEqual(1, dr.GetInt32(o++));
            Assert.AreEqual(16000, dr.GetInt32(o++));
            Assert.AreEqual(12345678, dr.GetInt32(o++));
            Assert.AreEqual(12345678901234, dr.GetInt64(o++));
            Assert.AreEqual(123.45, dr.GetDouble(o++));
            Assert.AreEqual(112345.67, dr.GetDouble(o++));
            Assert.AreEqual(1.23456789012e-13, dr.GetDouble(o++));
            Assert.AreEqual("text", dr.GetString(o++));

            Assert.AreEqual(o, dr.FieldCount);
        }
        private FileDataReader OpenSimpleReader(string csv)
        {
            var f = new CsvFile(new StringReader(csv));
            var b = new CsvFileBlock(f);

            b.Columns.Add(new DataFileColumn("one", typeof(int), 4));
            b.Columns.Add(new DataFileColumn("two", typeof(int), 4));
            b.Columns.Add(new DataFileColumn("three", typeof(int), 4));

            f.AppendBlock(b);

            return f.OpenDataReader();
        }
        public void AutoDetectColumnsTest2()
        {
            var csv =
            @"#Spectral_Value,Flux_Value,Flux_Accuracy_StatErrLow,Flux_Accuracy_StatErrHigh,Flux_Accuracy_Quality
            3801.01864554767,8.89645957946777,0,0,16777216
            3801.89396320561,8.88807010650635,0,0,16777216
            3802.7694824361,8.87969970703125,0,0,16777216
            3803.64520328556,8.87135982513428,0,0,16777216
            3804.5211258004,8.8630199432373,0,0,16777216
            3805.39725002709,8.85470962524414,0,0,16777216
            3806.27357601206,8.84642028808594,0,0,16777216
            3807.15010380177,8.83813953399658,0,0,16777216
            3808.02683344271,8.82987976074219,0,0,16777216
            3808.90376498135,8.82164001464844,0,0,218103808
            3809.78089846419,8.81342029571533,0,0,83886080
            3810.65823393773,8.80521011352539,0,0,83886080
            3811.53577144849,8.79703044891357,0,0,83886080
            3812.41351104299,8.78886032104492,0,0,83886080
            3813.29145276777,8.78069972991943,0,0,83886080
            3814.16959666939,8.77256965637207,0,0,16777216
            3815.04794279438,8.76445007324219,0,0,16777216
            3815.92649118934,8.75636005401611,4.35990858078003,4.35990858078003,0
            3816.80524190082,13.5115003585815,4.66361904144287,4.66361904144287,0
            3817.68419497544,21.9514007568359,4.84443044662476,4.84443044662476,0
            3818.56335045978,7.7454400062561,4.51452302932739,4.51452302932739,0
            3819.44270840046,6.19890022277832,4.03657913208008,4.03657913208008,0
            3820.32226884411,7.24296998977661,3.98828530311584,3.98828530311584,0
            3821.20203183735,3.41108989715576,3.92595434188843,3.92595434188843,0
            3822.08199742682,1.58747005462646,3.92526769638062,3.92526769638062,0
            3822.96216565919,4.89786005020142,4.08808422088623,4.08808422088623,0
            3823.84253658113,9.50407981872559,4.15539884567261,4.15539884567261,0
            3824.72311023929,11.3456001281738,4.22903490066528,4.22903490066528,0
            3825.60388668038,10.3824996948242,4.26791143417358,4.26791143417358,0
            3826.48486595109,4.91490983963013,4.14181470870972,4.14181470870972,0
            3827.36604809814,7.33786010742188,4.22164583206177,4.22164583206177,0
            3828.24743316822,7.24986982345581,4.26109457015991,4.26109457015991,0
            3829.1290212081,11.4675998687744,4.31576061248779,4.31576061248779,0
            3830.01081226448,13.0429000854492,4.32072496414185,4.32072496414185,0
            3830.89280638415,8.6926097869873,4.28437042236328,4.28437042236328,0
            3831.77500361384,12.6611995697021,4.30809211730957,4.30809211730957,0
            3832.65740400034,13.3259000778198,4.25758266448975,4.25758266448975,0
            3833.54000759044,6.77347993850708,4.10115146636963,4.10115146636963,0";

            var f = new CsvFile(new StringReader(csv));
            f.ColumnNamesInFirstLine = true;
            f.Culture = System.Globalization.CultureInfo.InvariantCulture;
            f.AutoDetectColumns = true;
            f.AutoDetectColumnsCount = 100;
            f.GenerateIdentityColumn = true;

            var dr = f.OpenDataReader();

            dr.Read();

            int o = 0;

            Assert.AreEqual(1, dr.GetInt64(o++));
            Assert.AreEqual(3801.01864554767, dr.GetDouble(o++));
            Assert.AreEqual(8.89645957946777, dr.GetDouble(o++));
            Assert.AreEqual(0.0, dr.GetDouble(o++));
            Assert.AreEqual(0.0, dr.GetDouble(o++));
            Assert.AreEqual(16777216, dr.GetInt32(o++));

            Assert.AreEqual(o, dr.FieldCount);
        }
        public void DetectColumnNamesTest()
        {
            var csv =
            @"#first, second, third, fourth
            1,2,3,4";

            var f = new CsvFile(new StringReader(csv));
            f.ColumnNamesInFirstLine = true;
            f.AutoDetectColumns = true;
            f.AutoDetectColumnsCount = 100;
            f.GenerateIdentityColumn = true;

            var dr = f.OpenDataReader();

            Assert.AreEqual("__ID", dr.GetName(0));
            Assert.AreEqual("first", dr.GetName(1));
            Assert.AreEqual("second", dr.GetName(2));
            Assert.AreEqual("third", dr.GetName(3));
            Assert.AreEqual("fourth", dr.GetName(4));

            dr.Read();

            Assert.AreEqual(1, dr["first"]);
        }