299 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			299 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
| /*
 | |
|  * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 | |
|  *
 | |
|  * This program is free software: you can use, redistribute, and/or modify
 | |
|  * it under the terms of the GNU Affero General Public License, version 3
 | |
|  * or later ("AGPL"), as published by the Free Software Foundation.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful, but WITHOUT
 | |
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 | |
|  * FITNESS FOR A PARTICULAR PURPOSE.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Affero General Public License
 | |
|  * along with this program. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #include "parTestUtil.h"
 | |
| 
 | |
| using namespace std;
 | |
| 
 | |
| namespace ParserTest {
 | |
| 
 | |
| class ParserShowToUseTest : public ParserDdlTest {};
 | |
| 
 | |
| // todo SHOW accounts
 | |
| // todo SHOW apps
 | |
| // todo SHOW connections
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showCluster) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc(
 | |
|       [&](const SQuery* pQuery, ParserStage stage) { ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SELECT_STMT); });
 | |
| 
 | |
|   run("SHOW CLUSTER");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showConsumers) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc(
 | |
|       [&](const SQuery* pQuery, ParserStage stage) { ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SELECT_STMT); });
 | |
| 
 | |
|   run("SHOW CONSUMERS");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showCreateDatabase) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | |
|     ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SHOW_CREATE_DATABASE_STMT);
 | |
|     ASSERT_EQ(pQuery->execMode, QUERY_EXEC_MODE_LOCAL);
 | |
|     ASSERT_TRUE(pQuery->haveResultSet);
 | |
|     ASSERT_NE(((SShowCreateDatabaseStmt*)pQuery->pRoot)->pCfg, nullptr);
 | |
|   });
 | |
| 
 | |
|   run("SHOW CREATE DATABASE test");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showCreateSTable) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | |
|     ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SHOW_CREATE_STABLE_STMT);
 | |
|     ASSERT_EQ(pQuery->execMode, QUERY_EXEC_MODE_LOCAL);
 | |
|     ASSERT_TRUE(pQuery->haveResultSet);
 | |
|     ASSERT_NE(((SShowCreateTableStmt*)pQuery->pRoot)->pDbCfg, nullptr);
 | |
|     ASSERT_NE(((SShowCreateTableStmt*)pQuery->pRoot)->pTableCfg, nullptr);
 | |
|   });
 | |
| 
 | |
|   run("SHOW CREATE STABLE st1");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showCreateTable) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | |
|     ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SHOW_CREATE_TABLE_STMT);
 | |
|     ASSERT_EQ(pQuery->execMode, QUERY_EXEC_MODE_LOCAL);
 | |
|     ASSERT_TRUE(pQuery->haveResultSet);
 | |
|     ASSERT_NE(((SShowCreateTableStmt*)pQuery->pRoot)->pDbCfg, nullptr);
 | |
|     ASSERT_NE(((SShowCreateTableStmt*)pQuery->pRoot)->pTableCfg, nullptr);
 | |
|   });
 | |
| 
 | |
|   run("SHOW CREATE TABLE t1");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showDatabases) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW databases");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showDnodes) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW dnodes");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showDnodeVariables) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW DNODE 1 VARIABLES");
 | |
| 
 | |
|   run("SHOW DNODE 1 VARIABLES LIKE '%debug%'");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showFunctions) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW functions");
 | |
| }
 | |
| 
 | |
| // todo SHOW licence
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showLocalVariables) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW LOCAL VARIABLES");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showIndexes) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW indexes from t1");
 | |
| 
 | |
|   run("SHOW indexes from t1 from test");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showMnodes) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW mnodes");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showQnodes) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW qnodes");
 | |
| }
 | |
| 
 | |
| // todo SHOW queries
 | |
| // todo SHOW scores
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showStables) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW stables");
 | |
| 
 | |
|   run("SHOW test.stables");
 | |
| 
 | |
|   run("SHOW stables like 'c%'");
 | |
| 
 | |
|   run("SHOW test.stables like 'c%'");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showStreams) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW streams");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showSubscriptions) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   setCheckDdlFunc(
 | |
|       [&](const SQuery* pQuery, ParserStage stage) { ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SELECT_STMT); });
 | |
| 
 | |
|   run("SHOW SUBSCRIPTIONS");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showTransactions) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW TRANSACTIONS");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showTables) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW tables");
 | |
| 
 | |
|   run("SHOW test.tables");
 | |
| 
 | |
|   run("SHOW tables like 'c%'");
 | |
| 
 | |
|   run("SHOW test.tables like 'c%'");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showTableDistributed) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW TABLE DISTRIBUTED st1");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showTableTags) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW TABLE TAGS FROM st1");
 | |
| 
 | |
|   run("SHOW TABLE TAGS tag1, tag2 FROM st1");
 | |
| 
 | |
|   run("SHOW TABLE TAGS TBNAME, _TAGS, tag3 FROM st1");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showTags) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW TAGS FROM st1s1");
 | |
| }
 | |
| 
 | |
| // todo SHOW topics
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showUsers) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW USERS");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showUserPrivileges) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW USER PRIVILEGES");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showVariables) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW VARIABLES");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showVgroups) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW VGROUPS");
 | |
| 
 | |
|   run("SHOW test.VGROUPS");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, showVnodes) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("SHOW VNODES 1");
 | |
| 
 | |
|   run("SHOW VNODES 'node1:7030'");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, splitVgroup) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   SSplitVgroupReq expect = {0};
 | |
| 
 | |
|   auto setSplitVgroupReqFunc = [&](int32_t vgId) { expect.vgId = vgId; };
 | |
| 
 | |
|   setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | |
|     ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_SPLIT_VGROUP_STMT);
 | |
|     ASSERT_EQ(pQuery->pCmdMsg->msgType, TDMT_MND_SPLIT_VGROUP);
 | |
|     SSplitVgroupReq req = {0};
 | |
|     ASSERT_EQ(tDeserializeSSplitVgroupReq(pQuery->pCmdMsg->pMsg, pQuery->pCmdMsg->msgLen, &req), TSDB_CODE_SUCCESS);
 | |
|     ASSERT_EQ(req.vgId, expect.vgId);
 | |
|   });
 | |
| 
 | |
|   setSplitVgroupReqFunc(15);
 | |
|   run("SPLIT VGROUP 15");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, trimDatabase) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   STrimDbReq expect = {0};
 | |
| 
 | |
|   auto setTrimDbReq = [&](const char* pDb, int32_t maxSpeed = 0) {
 | |
|     snprintf(expect.db, sizeof(expect.db), "0.%s", pDb);
 | |
|     expect.maxSpeed = maxSpeed;
 | |
|   };
 | |
| 
 | |
|   setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | |
|     ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_TRIM_DATABASE_STMT);
 | |
|     ASSERT_EQ(pQuery->pCmdMsg->msgType, TDMT_MND_TRIM_DB);
 | |
|     STrimDbReq req = {0};
 | |
|     ASSERT_EQ(tDeserializeSTrimDbReq(pQuery->pCmdMsg->pMsg, pQuery->pCmdMsg->msgLen, &req), TSDB_CODE_SUCCESS);
 | |
|     ASSERT_EQ(std::string(req.db), std::string(expect.db));
 | |
|     ASSERT_EQ(req.maxSpeed, expect.maxSpeed);
 | |
|   });
 | |
| 
 | |
|   setTrimDbReq("wxy_db");
 | |
|   run("TRIM DATABASE wxy_db");
 | |
| 
 | |
|   setTrimDbReq("wxy_db", 100);
 | |
|   run("TRIM DATABASE wxy_db MAX_SPEED 100");
 | |
| }
 | |
| 
 | |
| TEST_F(ParserShowToUseTest, useDatabase) {
 | |
|   useDb("root", "test");
 | |
| 
 | |
|   run("use wxy_db");
 | |
| }
 | |
| 
 | |
| }  // namespace ParserTest
 |