tests for adding fractional seconds to timestamp

Signed-off-by: Gavin King <gavin@hibernate.org>
This commit is contained in:
Gavin King 2024-05-02 13:45:59 +02:00
parent 927b046f13
commit 87516a77b7
1 changed files with 28 additions and 0 deletions

View File

@ -17,6 +17,7 @@ import org.hibernate.dialect.MariaDBDialect;
import org.hibernate.dialect.MySQLDialect; import org.hibernate.dialect.MySQLDialect;
import org.hibernate.dialect.OracleDialect; import org.hibernate.dialect.OracleDialect;
import org.hibernate.dialect.PostgreSQLDialect; import org.hibernate.dialect.PostgreSQLDialect;
import org.hibernate.dialect.SQLServerDialect;
import org.hibernate.dialect.SybaseDialect; import org.hibernate.dialect.SybaseDialect;
import org.hibernate.dialect.TiDBDialect; import org.hibernate.dialect.TiDBDialect;
import org.hibernate.query.sqm.produce.function.FunctionArgumentException; import org.hibernate.query.sqm.produce.function.FunctionArgumentException;
@ -1298,6 +1299,33 @@ public class FunctionTests {
); );
} }
@Test
// really this could and should be made work on these dialects
@SkipForDialect(dialectClass = DerbyDialect.class)
@SkipForDialect(dialectClass = SQLServerDialect.class)
@SkipForDialect(dialectClass = SybaseDialect.class)
public void testAddSecondsWithFractionalPart(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
assertEquals(LocalDateTime.of(1974, 3, 23, 0, 0, 28, 123_000_000),
session.createQuery("select datetime 1974-03-23 00:00:15 + 13.123 second", LocalDateTime.class)
.getSingleResult());
}
);
}
@Test
@SkipForDialect(dialectClass = SybaseDialect.class)
public void testAddNanoseconds(SessionFactoryScope scope) {
scope.inTransaction(
session -> {
assertEquals(LocalDateTime.of(1974, 3, 23, 0, 0, 28, 123_000_000),
session.createQuery("select datetime 1974-03-23 00:00:15 + 13_123_000_000 nanosecond", LocalDateTime.class)
.getSingleResult());
}
);
}
@Test @Test
public void testTimestampAddDiffFunctions(SessionFactoryScope scope) { public void testTimestampAddDiffFunctions(SessionFactoryScope scope) {
scope.inTransaction( scope.inTransaction(