From ca585878de602d792e1e4c705609316cc6cc4454 Mon Sep 17 00:00:00 2001 From: cpw <13495049+CPWstatic@users.noreply.github.com> Date: Fri, 17 Sep 2021 13:33:54 +0800 Subject: [PATCH] =?UTF-8?q?Do=20not=20update=20session=20when=20use=20spac?= =?UTF-8?q?e,=20the=20sessions=20will=20update=20at=20the=E2=80=A6=20(#135?= =?UTF-8?q?5)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Do not update session when use space, the sessions will update at the next upload period. * Fix test. --- src/validator/UseValidator.cpp | 11 +++----- src/validator/test/AdminValidatorTest.cpp | 34 +++++++---------------- tests/job/test_session.py | 8 ++++-- 3 files changed, 19 insertions(+), 34 deletions(-) diff --git a/src/validator/UseValidator.cpp b/src/validator/UseValidator.cpp index dcaefe563..8908dc61e 100644 --- a/src/validator/UseValidator.cpp +++ b/src/validator/UseValidator.cpp @@ -6,9 +6,9 @@ #include "validator/UseValidator.h" #include "parser/TraverseSentences.h" +#include "planner/plan/Admin.h" #include "planner/plan/Logic.h" #include "planner/plan/Query.h" -#include "planner/plan/Admin.h" namespace nebula { namespace graph { @@ -42,12 +42,9 @@ Status UseValidator::validateImpl() { Status UseValidator::toPlan() { // The input will be set by father validator later. - auto switchSpace = SwitchSpace::make(qctx_, nullptr, *spaceName_); - qctx_->rctx()->session()->updateSpaceName(*spaceName_); - auto session = qctx_->rctx()->session()->getSession(); - auto update = UpdateSession::make(qctx_, switchSpace, std::move(session)); - root_ = update; - tail_ = switchSpace; + auto reg = SwitchSpace::make(qctx_, nullptr, *spaceName_); + root_ = reg; + tail_ = root_; return Status::OK(); } } // namespace graph diff --git a/src/validator/test/AdminValidatorTest.cpp b/src/validator/test/AdminValidatorTest.cpp index 51d65e06f..f6258a642 100644 --- a/src/validator/test/AdminValidatorTest.cpp +++ b/src/validator/test/AdminValidatorTest.cpp @@ -9,8 +9,7 @@ namespace nebula { namespace graph { using PK = nebula::graph::PlanNode::Kind; -class AdminValidatorTest : public ValidatorTestBase { -}; +class AdminValidatorTest : public ValidatorTestBase {}; TEST_F(AdminValidatorTest, SpaceTest) { { @@ -19,8 +18,7 @@ TEST_F(AdminValidatorTest, SpaceTest) { expected)); } { - std::vector expected = { - PK::kUpdateSession, PK::kSwitchSpace, PK::kCreateSpace, PK::kStart}; + std::vector expected = {PK::kSwitchSpace, PK::kCreateSpace, PK::kStart}; ASSERT_TRUE( checkResult("CREATE SPACE TEST(vid_type = fixed_string(2)); USE TEST;", expected)); } @@ -28,49 +26,37 @@ TEST_F(AdminValidatorTest, SpaceTest) { TEST_F(AdminValidatorTest, ShowHosts) { { - std::vector expected = { - PK::kShowHosts, PK::kStart - }; + std::vector expected = {PK::kShowHosts, PK::kStart}; ASSERT_TRUE(checkResult("SHOW HOSTS;", expected)); } // chain { - std::vector expected = { - PK::kShowHosts, PK::kDescSpace, PK::kStart - }; + std::vector expected = {PK::kShowHosts, PK::kDescSpace, PK::kStart}; ASSERT_TRUE(checkResult("DESC SPACE TEST; SHOW HOSTS", expected)); } } TEST_F(AdminValidatorTest, TestParts) { { - std::vector expected = { - PK::kShowParts, PK::kStart - }; + std::vector expected = {PK::kShowParts, PK::kStart}; ASSERT_TRUE(checkResult("SHOW PARTS;", expected)); } { - std::vector expected = { - PK::kShowParts, PK::kShowParts, PK::kStart - }; + std::vector expected = {PK::kShowParts, PK::kShowParts, PK::kStart}; ASSERT_TRUE(checkResult("SHOW PARTS; SHOW PART 3;", expected)); } } TEST_F(AdminValidatorTest, TestSessions) { { - std::vector expected = { - PK::kShowSessions, PK::kStart - }; + std::vector expected = {PK::kShowSessions, PK::kStart}; ASSERT_TRUE(checkResult("SHOW SESSIONS;", expected)); } { - std::vector expected = { - PK::kShowSessions, PK::kStart - }; + std::vector expected = {PK::kShowSessions, PK::kStart}; ASSERT_TRUE(checkResult("SHOW SESSION 1;", expected)); } } -} // namespace graph -} // namespace nebula +} // namespace graph +} // namespace nebula diff --git a/tests/job/test_session.py b/tests/job/test_session.py index 6f8e9873c..97178cc2e 100644 --- a/tests/job/test_session.py +++ b/tests/job/test_session.py @@ -88,9 +88,9 @@ def test_sessions(self): for row in resp.rows(): if bytes.decode(row.values[1].get_sVal()) == 'session_user': session_id = row.values[0].get_iVal() - assert row.values[2].get_sVal() == b'' - assert row.values[3].getType() == ttypes.Value.DTVAL - assert row.values[4].getType() == ttypes.Value.DTVAL + assert row.values[2].get_sVal() == b'', f"resp: {resp}" + assert row.values[3].getType() == ttypes.Value.DTVAL, f"resp: {resp}" + assert row.values[4].getType() == ttypes.Value.DTVAL, f"resp: {resp}" break assert session_id != 0 @@ -99,6 +99,8 @@ def test_sessions(self): resp = client_ok.execute('USE nba') self.check_resp_succeeded(resp) + # wait for session sync. + time.sleep(3) resp = self.execute('SHOW SESSION {}'.format(session_id)) self.check_resp_succeeded(resp) expect_col_names = ['VariableName', 'Value']