MssqlMsDataPreExecuteTests.cs 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Linq;
  5. using System.Threading.Tasks;
  6. using PetaPoco.Providers;
  7. using Shouldly;
  8. using Xunit;
  9. namespace PetaPoco.Tests.Integration.Databases.MSSQLMsData
  10. {
  11. [Collection("MssqlMsData")]
  12. public class MssqlMsDataPreExecuteTests : BaseDatabase
  13. {
  14. public MssqlMsDataPreExecuteDatabaseProvider Provider => DB.Provider as MssqlMsDataPreExecuteDatabaseProvider;
  15. public MssqlMsDataPreExecuteTests() : base(new MssqlMsDataPreExecuteDBTestProvider())
  16. {
  17. Provider.ThrowExceptions = true;
  18. }
  19. [Fact]
  20. public void Query_Calls_PreExecute()
  21. {
  22. var expected = Guid.NewGuid().ToString();
  23. var sql = Sql.Builder
  24. .Select("*")
  25. .From("sometable")
  26. .Where("foo = @0", expected);
  27. void act() => DB.Query<string>(sql).First();
  28. Should.Throw<PreExecuteException>(act);
  29. Provider.Parameters.Count().ShouldBe(1);
  30. Provider.Parameters.First().Value.ShouldBe(expected);
  31. }
  32. [Fact]
  33. public void Execute_Calls_PreExecute()
  34. {
  35. var expected = Guid.NewGuid().ToString();
  36. var sql = Sql.Builder
  37. .Select("*")
  38. .From("sometable")
  39. .Where("foo = @0", expected);
  40. void act() => DB.Execute(sql);
  41. Should.Throw<PreExecuteException>(act);
  42. Provider.Parameters.Count().ShouldBe(1);
  43. Provider.Parameters.First().Value.ShouldBe(expected);
  44. }
  45. [Fact]
  46. public void Insert_Calls_PreExecute()
  47. {
  48. var expected = Guid.NewGuid().ToString();
  49. void act() => DB.Insert("sometable", new { Foo = expected });
  50. Should.Throw<PreExecuteException>(act);
  51. Provider.Parameters.Count().ShouldBe(1);
  52. Provider.Parameters.First().Value.ShouldBe(expected);
  53. }
  54. [Fact]
  55. public void Update_Calls_PreExecute()
  56. {
  57. var expected = Guid.NewGuid().ToString();
  58. void act() => DB.Update("sometable", "id", new { ID = 3, Foo = expected });
  59. Should.Throw<PreExecuteException>(act);
  60. Provider.Parameters.Count().ShouldBe(2);
  61. Provider.Parameters.First().Value.ShouldBe(expected);
  62. }
  63. [Fact]
  64. public void ExecuteScalar_Calls_PreExecute()
  65. {
  66. var expected = Guid.NewGuid().ToString();
  67. var sql = Sql.Builder
  68. .Select("count(*)")
  69. .From("sometable")
  70. .Where("foo = @0", expected);
  71. void act() => DB.ExecuteScalar<int>(sql);
  72. Should.Throw<PreExecuteException>(act);
  73. Provider.Parameters.Count().ShouldBe(1);
  74. Provider.Parameters.First().Value.ShouldBe(expected);
  75. }
  76. [Fact]
  77. public void QueryAsync_Calls_PreExecute()
  78. {
  79. var expected = Guid.NewGuid().ToString();
  80. var sql = Sql.Builder
  81. .Select("*")
  82. .From("sometable")
  83. .Where("foo = @0", expected);
  84. async Task act() => await DB.QueryAsync<string>(sql).Result.ReadAsync();
  85. Should.Throw<PreExecuteException>(act);
  86. Provider.Parameters.Count().ShouldBe(1);
  87. Provider.Parameters.First().Value.ShouldBe(expected);
  88. }
  89. [Fact]
  90. public void ExecuteAsync_Calls_PreExecute()
  91. {
  92. var expected = Guid.NewGuid().ToString();
  93. var sql = Sql.Builder
  94. .Select("*")
  95. .From("sometable")
  96. .Where("foo = @0", expected);
  97. async Task act() => await DB.ExecuteAsync(sql);
  98. Should.Throw<PreExecuteException>(act);
  99. Provider.Parameters.Count().ShouldBe(1);
  100. Provider.Parameters.First().Value.ShouldBe(expected);
  101. }
  102. [Fact]
  103. public void InsertAsync_Calls_PreExecute()
  104. {
  105. var expected = Guid.NewGuid().ToString();
  106. async Task act() => await DB.InsertAsync("sometable", new { Foo = expected });
  107. Should.Throw<PreExecuteException>(act);
  108. Provider.Parameters.Count().ShouldBe(1);
  109. Provider.Parameters.First().Value.ShouldBe(expected);
  110. }
  111. [Fact]
  112. public void UpdateAsync_Calls_PreExecute()
  113. {
  114. var expected = Guid.NewGuid().ToString();
  115. async Task act() => await DB.UpdateAsync("sometable", "id", new { ID = 3, Foo = expected });
  116. Should.Throw<PreExecuteException>(act);
  117. Provider.Parameters.Count().ShouldBe(2);
  118. Provider.Parameters.First().Value.ShouldBe(expected);
  119. }
  120. [Fact]
  121. public void ExecuteScalarAsync_Calls_PreExecute()
  122. {
  123. var expected = Guid.NewGuid().ToString();
  124. var sql = Sql.Builder
  125. .Select("count(*)")
  126. .From("sometable")
  127. .Where("foo = @0", expected);
  128. async Task act() => await DB.ExecuteScalarAsync<int>(sql);
  129. Should.Throw<PreExecuteException>(act);
  130. Provider.Parameters.Count().ShouldBe(1);
  131. Provider.Parameters.First().Value.ShouldBe(expected);
  132. }
  133. public class MssqlMsDataPreExecuteDBTestProvider : MssqlMsDataDBTestProvider
  134. {
  135. protected override IDatabase LoadFromConnectionName(string name)
  136. {
  137. var config = BuildFromConnectionName(name);
  138. config.UsingProvider<MssqlMsDataPreExecuteDatabaseProvider>();
  139. return config.Create();
  140. }
  141. }
  142. public class MssqlMsDataPreExecuteDatabaseProvider : SqlServerDatabaseProvider
  143. {
  144. public bool ThrowExceptions { get; set; }
  145. public List<IDataParameter> Parameters { get; set; } = new List<IDataParameter>();
  146. public override void PreExecute(IDbCommand cmd)
  147. {
  148. Parameters.Clear();
  149. if (ThrowExceptions)
  150. {
  151. Parameters = cmd.Parameters.Cast<IDataParameter>().ToList();
  152. throw new PreExecuteException();
  153. }
  154. }
  155. }
  156. public class PreExecuteException : Exception { }
  157. }
  158. }