0
0
mirror of https://github.com/sqlite/sqlite.git synced 2024-11-24 16:18:08 +01:00
sqlite/test/round1.test
drh 17c20bb15e Improved rounding policy.
FossilOrigin-Name: 6f1122e942b8269552daaf13d647d200d8546ec25f36310d67037c6b58d09976
2023-07-01 17:56:00 +00:00

43 lines
1.3 KiB
Plaintext

# 2019-05-24
#
# The author disclaims copyright to this source code. In place of
# a legal notice, here is a blessing:
#
# May you do good and not evil.
# May you find forgiveness for yourself and forgive others.
# May you share freely, never taking more than you give.
#
#***********************************************************************
# Test cases for rounding behavior of floating point values.
#
# TESTRUNNER: slow
set testdir [file dirname $argv0]
source $testdir/tester.tcl
set testprefix round1
expr srand(0)
unset -nocomplain iTest
for {set iTest 1} {$iTest<=50000} {incr iTest} {
set x1 [expr int(rand()*100000)]
set x2 [expr int(rand()*100000)+1000*int(rand()*10000)]
set n [expr int(rand()*8)+1]
set x3 [string range [format %09d $x2] [expr {9-$n}] end]
set r $x1.$x3
set ans [string trimright $r 0]
if {[string match *. $ans]} {set ans ${ans}0}
do_test $iTest/$n/${r}4=>$ans {
set x [db one "SELECT round(${r}4,$n)"]
} $ans
set x4 [string range [format %09d [expr {$x2+1}]] [expr {9-$n}] end]
if {[string trim $x3 9]==""} {incr x1}
set r2 $x1.$x4
set ans [string trimright $r2 0]
if {[string match *. $ans]} {set ans ${ans}0}
do_test $iTest/$n/${r}6=>$ans {
set x [db one "SELECT round(${r}6,$n)"]
} $ans
}
finish_test