precision_ns.sim 2.3 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
system sh/stop_dnodes.sh

system sh/deploy.sh -n dnode1 -i 1
system sh/cfg.sh -n dnode1 -c walLevel -v 1
system sh/exec.sh -n dnode1 -s start
sleep 1000
sql connect

$dbPrefix = m_di_db_ns
$tbPrefix = m_di_tb
$mtPrefix = m_di_mt
$ntPrefix = m_di_nt
$tbNum = 2
$rowNum = 200
$futureTs = 300000000000 

print =============== step1: create database and tables and insert data
$i = 0
$db = $dbPrefix . $i
$mt = $mtPrefix . $i
$nt = $ntPrefix . $i

sql drop database $db -x step1
step1:
sql create database $db precision 'ns'
sql use $db
sql create table $mt (ts timestamp, tbcol int) TAGS(tgcol int)

$i = 0
while $i < $tbNum
  $tb = $tbPrefix . $i
  sql create table $tb using $mt tags( $i )

  $x = 0
  while $x < $rowNum
    $cc = $futureTs + $x * 100 + 43
    $ns = $cc . b
    sql insert into $tb values (now + $ns , $x ) 
    $x = $x + 1
  endw 

  $i = $i + 1
endw 

sql create table $nt (ts timestamp, tbcol int)
$x = 0
while $x < $rowNum
    $cc = $futureTs + $x * 100 + 43
    $ns = $cc . b
    sql insert into $nt values (now + $ns , $x ) 
    $x = $x + 1  
endw

sleep 100

print =============== step2: select count(*) from tables
$i = 0
$tb = $tbPrefix . $i

sql select count(*) from $tb

if $data00 != $rowNum then
  print expect $rowNum, actual:$data00
  return -1
endi

$i = 0
$mt = $mtPrefix . $i
sql select count(*) from $mt

$mtRowNum = $tbNum * $rowNum
if $data00 != $mtRowNum then
  print expect $mtRowNum, actual:$data00
  return -1
endi

$i = 0
$nt = $ntPrefix . $i

sql select count(*) from $nt

if $data00 != $rowNum then
  print expect $rowNum, actual:$data00
  return -1
endi

print =============== step3: check nano second timestamp
$i = 0
$mt = $mtPrefix . $i
$tb = $tbPrefix . $i
sql insert into $tb values (now-43b , $x ) 
sql select count(*) from $tb where ts<now
if $data00 != 1 then
  print expected 1, actual: $data00
endi


print =============== step4: check interval/sliding nano second
$i = 0
$mt = $mtPrefix . $i
sql_error select count(*) from $mt interval(1000b) sliding(100b)
sql_error select count(*) from $mt interval(10000000b) sliding(99999b)

sql select count(*) from $mt interval(100000000b) sliding(100000000b)

print =============== clear
sql drop database $db
sql show databases
if $rows != 0 then 
  return -1
endi

system sh/exec.sh -n dnode1 -s stop -x SIGINT