116 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			3.4 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 ParserExplainToSyncdbTest : public ParserDdlTest {};
 | 
						|
 | 
						|
TEST_F(ParserExplainToSyncdbTest, explain) {
 | 
						|
  useDb("root", "test");
 | 
						|
 | 
						|
  run("EXPLAIN SELECT * FROM t1");
 | 
						|
 | 
						|
  run("EXPLAIN ANALYZE SELECT * FROM t1");
 | 
						|
 | 
						|
  run("EXPLAIN ANALYZE VERBOSE true RATIO 0.01 SELECT * FROM t1");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ParserExplainToSyncdbTest, grant) {
 | 
						|
  useDb("root", "test");
 | 
						|
 | 
						|
  run("GRANT ALL ON test.* TO wxy");
 | 
						|
  run("GRANT READ ON test.* TO wxy");
 | 
						|
  run("GRANT WRITE ON test.* TO wxy");
 | 
						|
  run("GRANT READ, WRITE ON test.* TO wxy");
 | 
						|
}
 | 
						|
 | 
						|
// todo kill connection
 | 
						|
// todo kill query
 | 
						|
// todo kill stream
 | 
						|
 | 
						|
TEST_F(ParserExplainToSyncdbTest, mergeVgroup) {
 | 
						|
  useDb("root", "test");
 | 
						|
 | 
						|
  SMergeVgroupReq expect = {0};
 | 
						|
 | 
						|
  auto setMergeVgroupReqFunc = [&](int32_t vgId1, int32_t vgId2) {
 | 
						|
    expect.vgId1 = vgId1;
 | 
						|
    expect.vgId2 = vgId2;
 | 
						|
  };
 | 
						|
 | 
						|
  setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | 
						|
    ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_MERGE_VGROUP_STMT);
 | 
						|
    ASSERT_EQ(pQuery->pCmdMsg->msgType, TDMT_MND_MERGE_VGROUP);
 | 
						|
    SMergeVgroupReq req = {0};
 | 
						|
    ASSERT_EQ(tDeserializeSMergeVgroupReq(pQuery->pCmdMsg->pMsg, pQuery->pCmdMsg->msgLen, &req), TSDB_CODE_SUCCESS);
 | 
						|
    ASSERT_EQ(req.vgId1, expect.vgId1);
 | 
						|
    ASSERT_EQ(req.vgId2, expect.vgId2);
 | 
						|
  });
 | 
						|
 | 
						|
  setMergeVgroupReqFunc(1, 2);
 | 
						|
  run("MERGE VGROUP 1 2");
 | 
						|
}
 | 
						|
 | 
						|
TEST_F(ParserExplainToSyncdbTest, redistributeVgroup) {
 | 
						|
  useDb("root", "test");
 | 
						|
 | 
						|
  SRedistributeVgroupReq expect = {0};
 | 
						|
 | 
						|
  auto setRedistributeVgroupReqFunc = [&](int32_t vgId, int32_t dnodeId1, int32_t dnodeId2 = -1,
 | 
						|
                                          int32_t dnodeId3 = -1) {
 | 
						|
    expect.vgId = vgId;
 | 
						|
    expect.dnodeId1 = dnodeId1;
 | 
						|
    expect.dnodeId2 = dnodeId2;
 | 
						|
    expect.dnodeId3 = dnodeId3;
 | 
						|
  };
 | 
						|
 | 
						|
  setCheckDdlFunc([&](const SQuery* pQuery, ParserStage stage) {
 | 
						|
    ASSERT_EQ(nodeType(pQuery->pRoot), QUERY_NODE_REDISTRIBUTE_VGROUP_STMT);
 | 
						|
    ASSERT_EQ(pQuery->pCmdMsg->msgType, TDMT_MND_REDISTRIBUTE_VGROUP);
 | 
						|
    SRedistributeVgroupReq req = {0};
 | 
						|
    ASSERT_EQ(tDeserializeSRedistributeVgroupReq(pQuery->pCmdMsg->pMsg, pQuery->pCmdMsg->msgLen, &req),
 | 
						|
              TSDB_CODE_SUCCESS);
 | 
						|
    ASSERT_EQ(req.vgId, expect.vgId);
 | 
						|
    ASSERT_EQ(req.dnodeId1, expect.dnodeId1);
 | 
						|
    ASSERT_EQ(req.dnodeId2, expect.dnodeId2);
 | 
						|
    ASSERT_EQ(req.dnodeId3, expect.dnodeId3);
 | 
						|
  });
 | 
						|
 | 
						|
  setRedistributeVgroupReqFunc(3, 1);
 | 
						|
  run("REDISTRIBUTE VGROUP 3 DNODE 1");
 | 
						|
 | 
						|
  setRedistributeVgroupReqFunc(5, 10, 20, 30);
 | 
						|
  run("REDISTRIBUTE VGROUP 5 DNODE 10 DNODE 20 DNODE 30");
 | 
						|
}
 | 
						|
 | 
						|
// todo reset query cache
 | 
						|
 | 
						|
TEST_F(ParserExplainToSyncdbTest, revoke) {
 | 
						|
  useDb("root", "test");
 | 
						|
 | 
						|
  run("REVOKE ALL ON test.* FROM wxy");
 | 
						|
  run("REVOKE READ ON test.* FROM wxy");
 | 
						|
  run("REVOKE WRITE ON test.* FROM wxy");
 | 
						|
  run("REVOKE READ, WRITE ON test.* FROM wxy");
 | 
						|
}
 | 
						|
 | 
						|
// todo syncdb
 | 
						|
 | 
						|
}  // namespace ParserTest
 |