5dnode3mnodeDrop.py 11.6 KB
Newer Older
haoranc's avatar
haoranc 已提交
1
from ssl import ALERT_DESCRIPTION_CERTIFICATE_UNOBTAINABLE
haoranc's avatar
haoranc 已提交
2
from paramiko import HostKeys
haoranc's avatar
haoranc 已提交
3 4 5
import taos
import sys
import time
G
Ganlin Zhao 已提交
6
import os
haoranc's avatar
haoranc 已提交
7 8 9 10 11 12 13 14 15

from util.log import *
from util.sql import *
from util.cases import *
from util.dnodes import TDDnodes
from util.dnodes import TDDnode
import time
import socket
import subprocess
haoranc's avatar
haoranc 已提交
16
from multiprocessing import Process
haoranc's avatar
haoranc 已提交
17 18 19 20 21
class MyDnodes(TDDnodes):
    def __init__(self ,dnodes_lists):
        super(MyDnodes,self).__init__()
        self.dnodes = dnodes_lists  # dnode must be TDDnode instance
        self.simDeployed = False
G
Ganlin Zhao 已提交
22

haoranc's avatar
haoranc 已提交
23 24 25 26 27
class TDTestCase:

    def init(self,conn ,logSql):
        tdLog.debug(f"start to excute {__file__}")
        self.TDDnodes = None
haoranc's avatar
haoranc 已提交
28 29 30

    def buildcluster(self,dnodenumber):
        self.depoly_cluster(dnodenumber)
haoranc's avatar
haoranc 已提交
31
        self.master_dnode = self.TDDnodes.dnodes[0]
haoranc's avatar
haoranc 已提交
32
        self.host=self.master_dnode.cfgDict["fqdn"]
haoranc's avatar
haoranc 已提交
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
        conn1 = taos.connect(self.master_dnode.cfgDict["fqdn"] , config=self.master_dnode.cfgDir)
        tdSql.init(conn1.cursor())

    def getBuildPath(self):
        selfPath = os.path.dirname(os.path.realpath(__file__))

        if ("community" in selfPath):
            projPath = selfPath[:selfPath.find("community")]
        else:
            projPath = selfPath[:selfPath.find("tests")]

        for root, dirs, files in os.walk(projPath):
            if ("taosd" in files):
                rootRealPath = os.path.dirname(os.path.realpath(root))
                if ("packaging" not in rootRealPath):
                    buildPath = root[:len(root) - len("/build/bin")]
                    break
        return buildPath
G
Ganlin Zhao 已提交
51

haoranc's avatar
haoranc 已提交
52 53 54 55
    def insert_data(self,count):
        # fisrt add data : db\stable\childtable\general table
        for couti in count:
            tdSql.execute("drop database if exists db%d" %couti)
56
            tdSql.execute("create database if not exists db%d replica 1 duration 300" %couti)
haoranc's avatar
haoranc 已提交
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
            tdSql.execute("use db%d" %couti)
            tdSql.execute(
            '''create table stb1
            (ts timestamp, c1 int, c2 bigint, c3 smallint, c4 tinyint, c5 float, c6 double, c7 bool, c8 binary(16),c9 nchar(32), c10 timestamp)
            tags (t1 int)
            '''
            )
            tdSql.execute(
                '''
                create table t1
                (ts timestamp, c1 int, c2 bigint, c3 smallint, c4 tinyint, c5 float, c6 double, c7 bool, c8 binary(16),c9 nchar(32), c10 timestamp)
                '''
            )
            for i in range(4):
                tdSql.execute(f'create table ct{i+1} using stb1 tags ( {i+1} )')
haoranc's avatar
haoranc 已提交
72

G
Ganlin Zhao 已提交
73
    def depoly_cluster(self ,dnodes_nums):
haoranc's avatar
haoranc 已提交
74 75

        testCluster = False
G
Ganlin Zhao 已提交
76
        valgrind = 0
haoranc's avatar
haoranc 已提交
77
        hostname = socket.gethostname()
S
Shengliang Guan 已提交
78
        tdLog.debug(hostname)
haoranc's avatar
haoranc 已提交
79 80
        dnodes = []
        start_port = 6030
haoranc's avatar
haoranc 已提交
81
        start_port_sec = 6130
haoranc's avatar
haoranc 已提交
82 83 84 85 86 87 88
        for num in range(1, dnodes_nums+1):
            dnode = TDDnode(num)
            dnode.addExtraCfg("firstEp", f"{hostname}:{start_port}")
            dnode.addExtraCfg("fqdn", f"{hostname}")
            dnode.addExtraCfg("serverPort", f"{start_port + (num-1)*100}")
            dnode.addExtraCfg("monitorFqdn", hostname)
            dnode.addExtraCfg("monitorPort", 7043)
haoranc's avatar
haoranc 已提交
89
            dnode.addExtraCfg("secondEp", f"{hostname}:{start_port_sec}")
haoranc's avatar
haoranc 已提交
90
            dnodes.append(dnode)
G
Ganlin Zhao 已提交
91

haoranc's avatar
haoranc 已提交
92 93 94 95 96 97 98
        self.TDDnodes = MyDnodes(dnodes)
        self.TDDnodes.init("")
        self.TDDnodes.setTestCluster(testCluster)
        self.TDDnodes.setValgrind(valgrind)
        self.TDDnodes.stopAll()
        for dnode in self.TDDnodes.dnodes:
            self.TDDnodes.deploy(dnode.index,{})
G
Ganlin Zhao 已提交
99

haoranc's avatar
haoranc 已提交
100 101 102
        for dnode in self.TDDnodes.dnodes:
            self.TDDnodes.starttaosd(dnode.index)

G
Ganlin Zhao 已提交
103
        # create cluster
haoranc's avatar
haoranc 已提交
104
        for dnode in self.TDDnodes.dnodes[1:]:
S
Shengliang Guan 已提交
105
            # tdLog.debug(dnode.cfgDict)
haoranc's avatar
haoranc 已提交
106 107 108 109
            dnode_id = dnode.cfgDict["fqdn"] +  ":" +dnode.cfgDict["serverPort"]
            dnode_first_host = dnode.cfgDict["firstEp"].split(":")[0]
            dnode_first_port = dnode.cfgDict["firstEp"].split(":")[-1]
            cmd = f" taos -h {dnode_first_host} -P {dnode_first_port} -s ' create dnode \"{dnode_id} \" ' ;"
S
Shengliang Guan 已提交
110
            tdLog.debug(cmd)
haoranc's avatar
haoranc 已提交
111
            os.system(cmd)
G
Ganlin Zhao 已提交
112

haoranc's avatar
haoranc 已提交
113
        time.sleep(2)
haoranc's avatar
haoranc 已提交
114 115 116 117 118 119 120
        tdLog.info(" create cluster with %d dnode  done! " %dnodes_nums)

    def check3mnode(self):
        count=0
        while count < 10:
            time.sleep(1)
            tdSql.query("show mnodes;")
G
Ganlin Zhao 已提交
121 122
            if tdSql.checkRows(3) :
                tdLog.debug("mnode is  three nodes")
haoranc's avatar
haoranc 已提交
123 124 125
            if  tdSql.queryResult[0][2]=='leader' :
                if  tdSql.queryResult[1][2]=='follower':
                    if  tdSql.queryResult[2][2]=='follower':
S
Shengliang Guan 已提交
126
                        tdLog.debug("three mnodes is ready in 10s")
haoranc's avatar
haoranc 已提交
127 128 129 130
                        break
            elif tdSql.queryResult[0][2]=='follower' :
                if  tdSql.queryResult[1][2]=='leader':
                    if  tdSql.queryResult[2][2]=='follower':
S
Shengliang Guan 已提交
131
                        tdLog.debug("three mnodes is ready in 10s")
G
Ganlin Zhao 已提交
132
                        break
haoranc's avatar
haoranc 已提交
133 134 135
            elif tdSql.queryResult[0][2]=='follower' :
                if  tdSql.queryResult[1][2]=='follower':
                    if  tdSql.queryResult[2][2]=='leader':
S
Shengliang Guan 已提交
136
                        tdLog.debug("three mnodes is ready in 10s")
G
Ganlin Zhao 已提交
137
                        break
haoranc's avatar
haoranc 已提交
138 139
            count+=1
        else:
S
Shengliang Guan 已提交
140 141
            tdLog.debug(tdSql.queryResult)
            tdLog.debug("three mnodes is not ready in 10s ")
haoranc's avatar
haoranc 已提交
142
            return -1
haoranc's avatar
haoranc 已提交
143

G
Ganlin Zhao 已提交
144 145
        tdSql.query("show mnodes;")
        tdSql.checkRows(3)
haoranc's avatar
haoranc 已提交
146
        tdSql.checkData(0,1,'%s:6030'%self.host)
haoranc's avatar
haoranc 已提交
147
        tdSql.checkData(0,3,'ready')
haoranc's avatar
haoranc 已提交
148 149 150 151
        tdSql.checkData(1,1,'%s:6130'%self.host)
        tdSql.checkData(1,3,'ready')
        tdSql.checkData(2,1,'%s:6230'%self.host)
        tdSql.checkData(2,3,'ready')
haoranc's avatar
haoranc 已提交
152

haoranc's avatar
haoranc 已提交
153 154 155 156 157 158
    def check3mnode1off(self):
        count=0
        while count < 10:
            time.sleep(1)
            tdSql.query("show mnodes;")
            if tdSql.checkRows(3) :
S
Shengliang Guan 已提交
159
                tdLog.debug("mnode is  three nodes")
haoranc's avatar
haoranc 已提交
160 161 162
            if  tdSql.queryResult[0][2]=='offline' :
                if  tdSql.queryResult[1][2]=='leader':
                    if  tdSql.queryResult[2][2]=='follower':
S
Shengliang Guan 已提交
163
                        tdLog.debug("stop mnodes  on dnode 2 successfully in 10s")
haoranc's avatar
haoranc 已提交
164 165 166
                        break
                elif tdSql.queryResult[1][2]=='follower':
                    if  tdSql.queryResult[2][2]=='leader':
S
Shengliang Guan 已提交
167
                        tdLog.debug("stop mnodes  on dnode 2 successfully in 10s")
haoranc's avatar
haoranc 已提交
168
                        break
haoranc's avatar
haoranc 已提交
169 170
            count+=1
        else:
S
Shengliang Guan 已提交
171
            tdLog.debug("stop mnodes  on dnode 2 failed in 10s ")
G
Ganlin Zhao 已提交
172
            return -1
haoranc's avatar
haoranc 已提交
173
        tdSql.error("drop mnode on dnode 1;")
haoranc's avatar
haoranc 已提交
174

G
Ganlin Zhao 已提交
175 176
        tdSql.query("show mnodes;")
        tdSql.checkRows(3)
haoranc's avatar
haoranc 已提交
177 178 179 180 181 182 183
        tdSql.checkData(0,1,'%s:6030'%self.host)
        tdSql.checkData(0,2,'offline')
        tdSql.checkData(0,3,'ready')
        tdSql.checkData(1,1,'%s:6130'%self.host)
        tdSql.checkData(1,3,'ready')
        tdSql.checkData(2,1,'%s:6230'%self.host)
        tdSql.checkData(2,3,'ready')
haoranc's avatar
haoranc 已提交
184

haoranc's avatar
haoranc 已提交
185
    def check3mnode2off(self):
haoranc's avatar
haoranc 已提交
186
        count=0
haoranc's avatar
haoranc 已提交
187
        while count < 40:
haoranc's avatar
haoranc 已提交
188 189
            time.sleep(1)
            tdSql.query("show mnodes;")
haoranc's avatar
haoranc 已提交
190
            if tdSql.checkRows(3) :
S
Shengliang Guan 已提交
191
                tdLog.debug("mnode is  three nodes")
haoranc's avatar
haoranc 已提交
192 193 194
            if  tdSql.queryResult[0][2]=='leader' :
                if  tdSql.queryResult[1][2]=='offline':
                    if  tdSql.queryResult[2][2]=='follower':
S
Shengliang Guan 已提交
195
                        tdLog.debug("stop mnodes  on dnode 2 successfully in 10s")
haoranc's avatar
haoranc 已提交
196
                        break
haoranc's avatar
haoranc 已提交
197 198
            count+=1
        else:
S
Shengliang Guan 已提交
199
            tdLog.debug("stop mnodes  on dnode 2 failed in 10s ")
haoranc's avatar
haoranc 已提交
200 201
            return -1
        tdSql.error("drop mnode on dnode 2;")
haoranc's avatar
haoranc 已提交
202

G
Ganlin Zhao 已提交
203 204
        tdSql.query("show mnodes;")
        tdSql.checkRows(3)
haoranc's avatar
haoranc 已提交
205
        tdSql.checkData(0,1,'%s:6030'%self.host)
haoranc's avatar
haoranc 已提交
206 207
        tdSql.checkData(0,2,'leader')
        tdSql.checkData(0,3,'ready')
haoranc's avatar
haoranc 已提交
208 209
        tdSql.checkData(1,1,'%s:6130'%self.host)
        tdSql.checkData(1,2,'offline')
haoranc's avatar
haoranc 已提交
210
        tdSql.checkData(1,3,'ready')
haoranc's avatar
haoranc 已提交
211
        tdSql.checkData(2,1,'%s:6230'%self.host)
haoranc's avatar
haoranc 已提交
212 213 214
        tdSql.checkData(2,2,'follower')
        tdSql.checkData(2,3,'ready')

haoranc's avatar
haoranc 已提交
215 216 217 218 219 220
    def check3mnode3off(self):
        count=0
        while count < 10:
            time.sleep(1)
            tdSql.query("show mnodes;")
            if tdSql.checkRows(3) :
S
Shengliang Guan 已提交
221
                tdLog.debug("mnode is  three nodes")
haoranc's avatar
haoranc 已提交
222 223 224
            if  tdSql.queryResult[0][2]=='leader' :
                if  tdSql.queryResult[2][2]=='offline':
                    if  tdSql.queryResult[1][2]=='follower':
S
Shengliang Guan 已提交
225
                        tdLog.debug("stop mnodes  on dnode 3 successfully in 10s")
haoranc's avatar
haoranc 已提交
226
                        break
haoranc's avatar
haoranc 已提交
227 228
            count+=1
        else:
S
Shengliang Guan 已提交
229
            tdLog.debug("stop mnodes  on dnode 3 failed in 10s")
haoranc's avatar
haoranc 已提交
230 231
            return -1
        tdSql.error("drop mnode on dnode 3;")
G
Ganlin Zhao 已提交
232 233
        tdSql.query("show mnodes;")
        tdSql.checkRows(3)
haoranc's avatar
haoranc 已提交
234 235 236 237 238 239 240 241 242
        tdSql.checkData(0,1,'%s:6030'%self.host)
        tdSql.checkData(0,2,'leader')
        tdSql.checkData(0,3,'ready')
        tdSql.checkData(1,1,'%s:6130'%self.host)
        tdSql.checkData(1,2,'follower')
        tdSql.checkData(1,3,'ready')
        tdSql.checkData(2,1,'%s:6230'%self.host)
        tdSql.checkData(2,2,'offline')
        tdSql.checkData(2,3,'ready')
haoranc's avatar
haoranc 已提交
243

haoranc's avatar
haoranc 已提交
244 245


haoranc's avatar
haoranc 已提交
246
    def five_dnode_three_mnode(self):
haoranc's avatar
haoranc 已提交
247 248 249 250 251
        tdSql.query("show dnodes;")
        tdSql.checkData(0,1,'%s:6030'%self.host)
        tdSql.checkData(4,1,'%s:6430'%self.host)
        tdSql.checkData(0,4,'ready')
        tdSql.checkData(4,4,'ready')
G
Ganlin Zhao 已提交
252 253
        tdSql.query("show mnodes;")
        tdSql.checkRows(1)
haoranc's avatar
haoranc 已提交
254 255 256 257 258 259 260 261 262 263
        tdSql.checkData(0,1,'%s:6030'%self.host)
        tdSql.checkData(0,2,'leader')
        tdSql.checkData(0,3,'ready')

        # fisr add three mnodes;
        tdSql.execute("create mnode on dnode 2")
        tdSql.execute("create mnode on dnode 3")

        # fisrt check statut ready
        self.check3mnode()
haoranc's avatar
haoranc 已提交
264
        tdSql.error("create mnode on dnode 2")
haoranc's avatar
haoranc 已提交
265 266 267 268 269
        tdSql.error("create mnode on dnode 1")
        tdSql.error("create mnode on dnode 3")

        tdSql.error("drop mnode on dnode 1")

haoranc's avatar
haoranc 已提交
270
        tdSql.query("show dnodes;")
S
Shengliang Guan 已提交
271
        tdLog.debug(tdSql.queryResult)
haoranc's avatar
haoranc 已提交
272

G
Ganlin Zhao 已提交
273 274
        #  drop follower of mnode
        dropcount =0
haoranc's avatar
haoranc 已提交
275
        while dropcount <= 10:
haoranc's avatar
haoranc 已提交
276
            for i in range(1,3):
haoranc's avatar
haoranc 已提交
277
                tdLog.debug("drop mnode on dnode %d"%(i+1))
haoranc's avatar
haoranc 已提交
278
                tdSql.execute("drop mnode on dnode %d"%(i+1))
haoranc's avatar
haoranc 已提交
279 280 281 282 283 284
                tdSql.query("show mnodes;")
                count=0
                while count<10:
                    time.sleep(1)
                    tdSql.query("show mnodes;")
                    if tdSql.checkRows(2):
S
Shengliang Guan 已提交
285
                        tdLog.debug("drop mnode %d successfully"%(i+1))
haoranc's avatar
haoranc 已提交
286 287
                        break
                    count+=1
haoranc's avatar
haoranc 已提交
288
                tdLog.debug("create mnode on dnode %d"%(i+1))
haoranc's avatar
haoranc 已提交
289
                tdSql.execute("create mnode on dnode %d"%(i+1))
haoranc's avatar
haoranc 已提交
290 291 292 293 294
                count=0
                while count<10:
                    time.sleep(1)
                    tdSql.query("show mnodes;")
                    if tdSql.checkRows(3):
S
Shengliang Guan 已提交
295
                        tdLog.debug("drop mnode %d successfully"%(i+1))
haoranc's avatar
haoranc 已提交
296 297
                        break
                    count+=1
haoranc's avatar
haoranc 已提交
298 299
            dropcount+=1
        self.check3mnode()
haoranc's avatar
haoranc 已提交
300 301 302 303 304 305 306 307 308


    def getConnection(self, dnode):
        host = dnode.cfgDict["fqdn"]
        port = dnode.cfgDict["serverPort"]
        config_dir = dnode.cfgDir
        return taos.connect(host=host, port=int(port), config=config_dir)


G
Ganlin Zhao 已提交
309
    def run(self):
S
Shengliang Guan 已提交
310
        # tdLog.debug(self.master_dnode.cfgDict)
haoranc's avatar
haoranc 已提交
311
        self.buildcluster(5)
haoranc's avatar
haoranc 已提交
312
        self.five_dnode_three_mnode()
haoranc's avatar
haoranc 已提交
313 314 315 316 317 318

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

tdCases.addLinux(__file__, TDTestCase())
G
Ganlin Zhao 已提交
319
tdCases.addWindows(__file__, TDTestCase())