using FreeSql.DataAnnotations;
using System;
using Xunit;

namespace FreeSql.Tests.GBase
{
    public class GBaseAdoTest
    {
        [Fact]
        public void Pool()
        {
            var t1 = g.gbase.Ado.MasterPool.StatisticsFullily;
        }

        [Fact]
        public void SlavePools()
        {
            var t2 = g.gbase.Ado.SlavePools.Count;
        }

        [Fact]
        public void ExecuteTest()
        {
            Assert.True(g.gbase.Ado.ExecuteConnectTest());
        }
        [Fact]
        public void ExecuteReader()
        {

        }
        [Fact]
        public void ExecuteArray()
        {

        }
        [Fact]
        public void ExecuteNonQuery()
        {

        }
        [Fact]
        public void ExecuteScalar()
        {

        }

        [Fact]
        public void Query()
        {

            var t3 = g.gbase.Ado.Query<xxx>("select * from TB_TOPIC22");

            var t4 = g.gbase.Ado.Query<(int, string, string)>("select * from TB_TOPIC22");

            var t5 = g.gbase.Ado.Query<dynamic>("select * from TB_TOPIC22");

            var t6 = g.gbase.Ado.Query<xxx>("select * from TB_TOPIC22 where ID in @ids", new { ids = new[] { 1, 2, 3 } });
        }

        [Fact]
        public void QueryMultipline()
        {
            //var t3 = g.firebird.Ado.Query<xxx, (int, string, string), dynamic>("select * from TB_TOPIC; select * from TB_TOPIC; select * from TB_TOPIC");
        }

        class xxx
        {
            public int Id { get; set; }
            public string Path { get; set; }
            public string Title2 { get; set; }
        }
    }
}