/* * Copyright (c) 2019 TAOS Data, Inc. * * 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 . */ #include "parTestUtil.h" using namespace std; namespace ParserTest { class ParserShowToUseTest : public ParserDdlTest {}; // todo SHOW accounts // todo SHOW apps // todo SHOW connections 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)->pCfg, 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)->pCfg, 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"); } 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, showModules) { useDb("root", "test"); run("SHOW modules"); } 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%'"); } // todo SHOW topics TEST_F(ParserShowToUseTest, showUsers) { useDb("root", "test"); run("SHOW users"); } TEST_F(ParserShowToUseTest, showVariables) { useDb("root", "test"); run("SHOW VARIABLES"); } TEST_F(ParserShowToUseTest, showVgroups) { useDb("root", "test"); run("SHOW vgroups"); run("SHOW test.vgroups"); } // todo SHOW vnodes 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, useDatabase) { useDb("root", "test"); run("use wxy_db"); } } // namespace ParserTest