|
1 | 1 | using System;
|
2 | 2 | using System.Linq;
|
3 | 3 | using NHibernate.Cfg;
|
| 4 | +using NHibernate.Dialect; |
4 | 5 | using NUnit.Framework;
|
5 | 6 |
|
6 | 7 | namespace NHibernate.Test.Linq.ByMethod
|
@@ -98,5 +99,50 @@ into temp
|
98 | 99 |
|
99 | 100 | Assert.That(result.Count, Is.EqualTo(77));
|
100 | 101 | }
|
| 102 | + |
| 103 | + [Test] |
| 104 | + public void CheckSqlFunctionNameLongCount() |
| 105 | + { |
| 106 | + var name = Dialect is MsSql2000Dialect ? "count_big" : "count"; |
| 107 | + using (var sqlLog = new SqlLogSpy()) |
| 108 | + { |
| 109 | + var result = db.Orders.LongCount(); |
| 110 | + Assert.That(result, Is.EqualTo(830)); |
| 111 | + |
| 112 | + var log = sqlLog.GetWholeLog(); |
| 113 | + Assert.That(log, Does.Contain($"{name}(")); |
| 114 | + } |
| 115 | + } |
| 116 | + |
| 117 | + [Test] |
| 118 | + public void CheckSqlFunctionNameForCount() |
| 119 | + { |
| 120 | + using (var sqlLog = new SqlLogSpy()) |
| 121 | + { |
| 122 | + var result = db.Orders.Count(); |
| 123 | + Assert.That(result, Is.EqualTo(830)); |
| 124 | + |
| 125 | + var log = sqlLog.GetWholeLog(); |
| 126 | + Assert.That(log, Does.Contain("count(")); |
| 127 | + } |
| 128 | + } |
| 129 | + |
| 130 | + [Test] |
| 131 | + public void CheckMssqlCountCast() |
| 132 | + { |
| 133 | + if (!(Dialect is MsSql2000Dialect)) |
| 134 | + { |
| 135 | + Assert.Ignore(); |
| 136 | + } |
| 137 | + |
| 138 | + using (var sqlLog = new SqlLogSpy()) |
| 139 | + { |
| 140 | + var result = db.Orders.Count(); |
| 141 | + Assert.That(result, Is.EqualTo(830)); |
| 142 | + |
| 143 | + var log = sqlLog.GetWholeLog(); |
| 144 | + Assert.That(log, Does.Not.Contain("cast(")); |
| 145 | + } |
| 146 | + } |
101 | 147 | }
|
102 | 148 | }
|
0 commit comments