create_retentions.py 14.3 KB
Newer Older
C
cpwu 已提交
1 2
import datetime

C
cpwu 已提交
3 4
from dataclasses import dataclass
from typing import List
C
cpwu 已提交
5 6 7 8 9 10 11
from util.log import *
from util.sql import *
from util.cases import *
from util.dnodes import *

PRIMARY_COL = "ts"

C
cpwu 已提交
12 13 14 15 16 17 18 19 20 21 22
INT_COL     = "c_int"
BINT_COL    = "c_bint"
SINT_COL    = "c_sint"
TINT_COL    = "c_tint"
FLOAT_COL   = "c_float"
DOUBLE_COL  = "c_double"
BOOL_COL    = "c_bool"
TINT_UN_COL = "c_tint_un"
SINT_UN_COL = "c_sint_un"
BINT_UN_COL = "c_bint_un"
INT_UN_COL  = "c_int_un"
C
cpwu 已提交
23 24 25 26 27 28 29 30 31 32

BINARY_COL  = "c8"
NCHAR_COL   = "c9"
TS_COL      = "c10"

NUM_COL     = [ INT_COL, BINT_COL, SINT_COL, TINT_COL, FLOAT_COL, DOUBLE_COL, ]
CHAR_COL    = [ BINARY_COL, NCHAR_COL, ]
BOOLEAN_COL = [ BOOL_COL, ]
TS_TYPE_COL = [ TS_COL, ]

C
cpwu 已提交
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
@dataclass
class DataSet:
    ts_data : List[int] = None
    int_data : List[int] = None
    bint_data : List[int] = None
    sint_data : List[int] = None
    tint_data : List[int] = None
    int_un_data : List[int] = None
    bint_un_data : List[int] = None
    sint_un_data : List[int] = None
    tint_un_data : List[int] = None
    float_data : List[float] = None
    double_data : List[float] = None
    binary_data : List[str] = None
    nchar_data : List[str] = None


C
cpwu 已提交
50 51 52 53 54 55 56 57 58
class TDTestCase:

    def init(self, conn, logSql):
        tdLog.debug(f"start to excute {__file__}")
        tdSql.init(conn.cursor(), True)

    @property
    def create_databases_sql_err(self):
        return [
C
cpwu 已提交
59 60 61 62 63 64 65
            "create database db1 retentions 0s:1d",
            "create database db3 retentions 1s:0d",
            "create database db1 retentions 1s:1y",
            "create database db1 retentions 1s:1n",
            "create database db2 retentions 1w:1d ;",
            "create database db5 retentions 1s:1d,3s:3d,2s:2d",
            "create database db1 retentions 1s:1n,2s:2d,3s:3d,4s:4d",
C
cpwu 已提交
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
        ]

    @property
    def create_databases_sql_current(self):
        return [
            "create database db1 retentions 1s:1d",
            "create database db2 retentions 1s:1d,2m:2d,3h:3d",
        ]

    @property
    def alter_database_sql(self):
        return [
            "alter database db1 retentions 99h:99d",
            "alter database db2 retentions 97h:97d,98h:98d,99h:99d,",
        ]

    @property
    def create_stable_sql_err(self):
        return [
C
cpwu 已提交
85 86
            f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(ceil) delay 1",
            f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(count) delay 1",
C
cpwu 已提交
87 88
            f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(min) delay 0",
            f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(min) delay -1.0",
C
cpwu 已提交
89 90
            f"create stable stb2 ({PRIMARY_COL} timestamp, {INT_COL} int, {BINARY_COL} binary(16)) tags (tag1 int) rollup(avg) delay 1",
            f"create stable stb2 ({PRIMARY_COL} timestamp, {INT_COL} int, {BINARY_COL} nchar(16)) tags (tag1 int) rollup(avg) delay 1",
C
cpwu 已提交
91 92 93
        ]

    @property
C
cpwu 已提交
94
    def create_stable_sql_current(self):
C
cpwu 已提交
95
        return [
C
cpwu 已提交
96 97 98 99 100 101
            f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) delay 5",
            f"create stable stb2 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(min) delay 5",
            f"create stable stb3 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(max) delay 5",
            f"create stable stb4 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(sum) delay 5",
            f"create stable stb5 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(last) delay 5",
            f"create stable stb6 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) rollup(first) delay 5",
C
cpwu 已提交
102 103
        ]

C
cpwu 已提交
104 105 106 107 108 109 110 111
    def test_create_stb(self):
        tdSql.execute("use db2")
        for err_sql in self.create_stable_sql_err:
            tdSql.error(err_sql)
        for cur_sql in self.create_stable_sql_current:
            tdSql.execute(cur_sql)
        tdSql.query("show stables")
        tdSql.checkRows(len(self.create_stable_sql_current))
C
cpwu 已提交
112 113 114
        tdSql.execute("use db")  # because db is a noraml database, not a rollup database, can not create a rollup database
        tdSql.error(f"create stable stb1 ({PRIMARY_COL} timestamp, {INT_COL} int) tags (tag1 int) delay 5")

C
cpwu 已提交
115 116 117 118 119 120 121 122 123 124 125 126

    def test_create_databases(self):
        for err_sql in self.create_databases_sql_err:
            tdSql.error(err_sql)
        for cur_sql in self.create_databases_sql_current:
            tdSql.execute(cur_sql)
            tdSql.query("show databases")
        for alter_sql in self.alter_database_sql:
            tdSql.error(alter_sql)

    def all_test(self):
        self.test_create_databases()
C
cpwu 已提交
127
        self.test_create_stb()
C
cpwu 已提交
128 129 130 131 132 133 134

    def __create_tb(self):
        tdSql.prepare()

        tdLog.printNoPrefix("==========step1:create table")
        create_stb_sql  =  f'''create table stb1(
                ts timestamp, {INT_COL} int, {BINT_COL} bigint, {SINT_COL} smallint, {TINT_COL} tinyint,
C
cpwu 已提交
135 136 137
                {FLOAT_COL} float, {DOUBLE_COL} double, {BOOL_COL} bool,
                {BINARY_COL} binary(16), {NCHAR_COL} nchar(32), {TS_COL} timestamp,
                {TINT_UN_COL} tinyint unsigned, {SINT_UN_COL} smallint unsigned,
C
cpwu 已提交
138
                {INT_UN_COL} int unsigned, {BINT_UN_COL} bigint unsigned
C
cpwu 已提交
139 140 141 142
            ) tags (t1 int)
            '''
        create_ntb_sql = f'''create table t1(
                ts timestamp, {INT_COL} int, {BINT_COL} bigint, {SINT_COL} smallint, {TINT_COL} tinyint,
C
cpwu 已提交
143 144 145
                {FLOAT_COL} float, {DOUBLE_COL} double, {BOOL_COL} bool,
                {BINARY_COL} binary(16), {NCHAR_COL} nchar(32), {TS_COL} timestamp,
                {TINT_UN_COL} tinyint unsigned, {SINT_UN_COL} smallint unsigned,
C
cpwu 已提交
146
                {INT_UN_COL} int unsigned, {BINT_UN_COL} bigint unsigned
C
cpwu 已提交
147 148 149 150 151 152 153 154
            )
            '''
        tdSql.execute(create_stb_sql)
        tdSql.execute(create_ntb_sql)

        for i in range(4):
            tdSql.execute(f'create table ct{i+1} using stb1 tags ( {i+1} )')

C
cpwu 已提交
155
    def __data_set(self, rows):
C
cpwu 已提交
156
        now_time = int(datetime.datetime.timestamp(datetime.datetime.now()) * 1000)
C
cpwu 已提交
157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
        data_set = DataSet()
        # neg_data_set = DataSet()
        data_set.ts_data = [None, None, None]
        data_set.int_data = [None, None, None]
        data_set.bint_data = [None, None, None]
        data_set.sint_data = [None, None, None]
        data_set.tint_data = [None, None, None]
        data_set.int_un_data = [None, None, None]
        data_set.bint_un_data = [None, None, None]
        data_set.sint_un_data = [None, None, None]
        data_set.tint_un_data = [None, None, None]
        data_set.float_data = [None, None, None]
        data_set.double_data = [None, None, None]
        data_set.binary_data = [None, None, None]
        data_set.nchar_data = [None, None, None]
C
cpwu 已提交
172
        for i in range(rows):
C
cpwu 已提交
173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201
            data_set.ts_data.append(now_time + 1 * i)
            data_set.int_data.append(i)
            data_set.bint_data.append(11111 * i)
            data_set.sint_data.append(111 * i % 32767)
            data_set.tint_data.append(11 * i % 127)
            data_set.int_un_data.append(i)
            data_set.bint_un_data.append(11111 * i)
            data_set.sint_un_data.append(111 * i % 32767)
            data_set.tint_un_data.append(11 * i % 127)
            data_set.float_data.append(1.11 * i)
            data_set.double_data.append(1100.0011 * i)
            data_set.binary_data.append(f'binary{i}')
            data_set.nchar_data.append(f'nchar_测试_{i}')

            # neg_data_set.ts_data.append(-1 * i)
            # neg_data_set.int_data.append(-i)
            # neg_data_set.bint_data.append(-11111 * i)
            # neg_data_set.sint_data.append(-111 * i % 32767)
            # neg_data_set.tint_data.append(-11 * i % 127)
            # neg_data_set.int_un_data.append(-i)
            # neg_data_set.bint_un_data.append(-11111 * i)
            # neg_data_set.sint_un_data.append(-111 * i % 32767)
            # neg_data_set.tint_un_data.append(-11 * i % 127)
            # neg_data_set.float_data.append(-1.11 * i)
            # neg_data_set.double_data.append(-1100.0011 * i)
            # neg_data_set.binary_data.append(f'binary{i}')
            # neg_data_set.nchar_data.append(f'nchar_测试_{i}')

        return data_set
C
cpwu 已提交
202

C
cpwu 已提交
203 204
    def __insert_data(self, rows):
        now_time = int(datetime.datetime.timestamp(datetime.datetime.now()) * 1000)
C
cpwu 已提交
205
        data = self.__data_set(rows)
C
cpwu 已提交
206 207
        for i in range(rows):
            tdSql.execute(
C
cpwu 已提交
208 209
                f'''insert into ct1 values (
                { now_time - i * 1000 }, {i}, {11111 * i}, {111 * i % 32767 }, {11 * i % 127}, {1.11*i}, {1100.0011*i},
C
cpwu 已提交
210
                {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i }, {11 * i % 127}, {111 * i % 32767}, {i}, {11111 * i} )'''
C
cpwu 已提交
211 212
            )
            tdSql.execute(
C
cpwu 已提交
213 214
                f'''insert into ct4 values (
                { now_time - i * 7776000000 }, {i}, {11111 * i}, {111 * i % 32767 }, {11 * i % 127}, {1.11*i}, {1100.0011*i},
C
cpwu 已提交
215
                {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i }, {11 * i % 127}, {111 * i % 32767}, {i}, {11111 * i} )'''
C
cpwu 已提交
216 217
            )
            tdSql.execute(
C
cpwu 已提交
218 219 220
                f'''insert into ct2 values (
                { now_time - i * 7776000000 }, {-i},  {-11111 * i}, {-111 * i % 32767 }, {-11 * i % 127}, {-1.11*i}, {-1100.0011*i},
                {i%2}, 'binary{i}', 'nchar_测试_{i}', { now_time + 1 * i }, {11 * i % 127}, {111 * i % 32767}, {i}, {11111 * i} )'''
C
cpwu 已提交
221 222 223
            )
        tdSql.execute(
            f'''insert into ct1 values
C
cpwu 已提交
224
            ( { now_time - rows * 5 }, 0, 0, 0, 0, 0, 0, 0, 'binary0', 'nchar_测试_0', { now_time + 8 }, 0, 0, 0, 0)
C
cpwu 已提交
225
            ( { now_time + 10000 }, { rows }, -99999, -999, -99, -9.99, -99.99, 1, 'binary9', 'nchar_测试_9', { now_time + 9 }, 0, 0, 0, 0 )
C
cpwu 已提交
226 227 228 229 230
            '''
        )

        tdSql.execute(
            f'''insert into ct4 values
C
cpwu 已提交
231 232 233
            ( { now_time - rows * 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time - rows * 3888000000 + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time +  7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
234 235
            (
                { now_time + 5184000000}, {pow(2,31)-pow(2,15)}, {pow(2,63)-pow(2,30)}, 32767, 127,
C
cpwu 已提交
236
                { 3.3 * pow(10,38) }, { 1.3 * pow(10,308) }, { rows % 2 }, "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000},
C
cpwu 已提交
237
                254, 65534, {pow(2,32)-pow(2,16)}, {pow(2,64)-pow(2,31)}
C
cpwu 已提交
238 239 240
                )
            (
                { now_time + 2592000000 }, {pow(2,31)-pow(2,16)}, {pow(2,63)-pow(2,31)}, 32766, 126,
C
cpwu 已提交
241
                { 3.2 * pow(10,38) }, { 1.2 * pow(10,308) }, { (rows-1) % 2 }, "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000},
C
cpwu 已提交
242
                255, 65535, {pow(2,32)-pow(2,15)}, {pow(2,64)-pow(2,30)}
C
cpwu 已提交
243 244 245 246 247 248
                )
            '''
        )

        tdSql.execute(
            f'''insert into ct2 values
C
cpwu 已提交
249 250 251
            ( { now_time - rows * 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time - rows * 3888000000 + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time + 7776000000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
252
            (
C
cpwu 已提交
253
                { now_time + 5184000000 }, { -1 * pow(2,31) + pow(2,15) }, { -1 * pow(2,63) + pow(2,30) }, -32766, -126, { -1 * 3.2 * pow(10,38) },
C
cpwu 已提交
254
                { -1.2 * pow(10,308) }, { rows % 2 }, "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000 }, 1, 1, 1, 1
C
cpwu 已提交
255 256
                )
            (
C
cpwu 已提交
257
                { now_time + 2592000000 }, { -1 * pow(2,31) + pow(2,16) }, { -1 * pow(2,63) + pow(2,31) }, -32767, -127, { - 3.3 * pow(10,38) },
C
cpwu 已提交
258
                { -1.3 * pow(10,308) }, { (rows-1) % 2 }, "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000 }, 1, 1, 1, 1
C
cpwu 已提交
259 260 261 262 263 264 265
                )
            '''
        )

        for i in range(rows):
            insert_data = f'''insert into t1 values
                ( { now_time - i * 3600000 }, {i}, {i * 11111}, { i % 32767 }, { i % 127}, { i * 1.11111 }, { i * 1000.1111 }, { i % 2},
C
cpwu 已提交
266
                "binary_{i}", "nchar_测试_{i}", { now_time - 1000 * i }, {i % 127}, {i % 32767}, {i}, {i * 11111})
C
cpwu 已提交
267 268 269 270
                '''
            tdSql.execute(insert_data)
        tdSql.execute(
            f'''insert into t1 values
C
cpwu 已提交
271 272 273
            ( { now_time + 10800000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
            ( { now_time - (( rows // 2 ) * 60 + 30) * 60000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL)
            ( { now_time - rows * 3600000 }, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL )
C
cpwu 已提交
274
            (
C
cpwu 已提交
275 276
                { now_time + 7200000 }, { pow(2,31) - pow(2,15) }, { pow(2,63) - pow(2,30) }, 32767, 127, { 3.3 * pow(10,38) },
                { 1.3 * pow(10,308) }, { rows % 2 }, "binary_limit-1", "nchar_测试_limit-1", { now_time - 86400000 },
C
cpwu 已提交
277
                254, 65534, {pow(2,32)-pow(2,16)}, {pow(2,64)-pow(2,31)}
C
cpwu 已提交
278
                )
C
cpwu 已提交
279 280 281
            (
                { now_time + 3600000 } , { pow(2,31) - pow(2,16) }, { pow(2,63) - pow(2,31) }, 32766, 126, { 3.2 * pow(10,38) },
                { 1.2 * pow(10,308) }, { (rows-1) % 2 }, "binary_limit-2", "nchar_测试_limit-2", { now_time - 172800000 },
C
cpwu 已提交
282
                255, 65535, {pow(2,32)-pow(2,15)}, {pow(2,64)-pow(2,30)}
C
cpwu 已提交
283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299
                )
            '''
        )


    def run(self):
        tdSql.prepare()

        tdLog.printNoPrefix("==========step1:create table")
        self.__create_tb()

        tdLog.printNoPrefix("==========step2:insert data")
        self.rows = 10
        self.__insert_data(self.rows)

        tdLog.printNoPrefix("==========step3:all check")
        self.all_test()
C
cpwu 已提交
300 301
        tdSql.execute("drop database if exists db1 ")
        tdSql.execute("drop database if exists db2 ")
C
cpwu 已提交
302 303 304 305 306 307 308 309 310 311 312 313 314 315 316

        tdDnodes.stop(1)
        tdDnodes.start(1)

        tdSql.execute("use db")

        tdLog.printNoPrefix("==========step4:after wal, all check again ")
        self.all_test()

    def stop(self):
        tdSql.close()
        tdLog.success(f"{__file__} successfully executed")

tdCases.addLinux(__file__, TDTestCase())
tdCases.addWindows(__file__, TDTestCase())