0
Files
src/sql/statement_id_unittest.cc
Victor Costan 12daa3ac93 sql: Document sql::StatementID's thread safety properties.
This CL:

1) Extracts StatementID from sql/connection.{h,cc} into its own files
   sql/statement_id.{h,cc}.
2) Adds tests specifically targeting sql::StatementID.
3) Replaces passing StatementID by const reference with passing by
   value.
4) Removes the StatementID constructor that takes a name, and updates
   the call sites to use the source file+line constructor.

Bug: 863724
Change-Id: I5bc6e160fe294189d3e9a2baa8f6be61b21c38d2
Reviewed-on: https://chromium-review.googlesource.com/1137915
Commit-Queue: Victor Costan <pwnall@chromium.org>
Reviewed-by: Scott Violet <sky@chromium.org>
Reviewed-by: Chris Mumford <cmumford@chromium.org>
Cr-Commit-Position: refs/heads/master@{#576295}
2018-07-19 01:05:58 +00:00

68 lines
1.6 KiB
C++

// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "sql/statement_id.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace sql {
namespace {
class SqlStatementIdTest : public testing::Test {
protected:
// This test takes advantage of the fact that statement IDs are logically
// (file, line) tuples, and are compared lexicographically.
SqlStatementIdTest()
: id1_(SQL_FROM_HERE), // file statement_id_unittest.cc, line L
id2_(SQL_FROM_HERE), // file statement_id_unittest.cc, line L+1
id3_(SQL_FROM_HERE) { // file statement_id_unittest.cc, line L+2
}
StatementID id1_;
StatementID id2_;
StatementID id3_;
};
TEST_F(SqlStatementIdTest, LessThan) {
EXPECT_FALSE(id1_ < id1_);
EXPECT_FALSE(id2_ < id2_);
EXPECT_FALSE(id3_ < id3_);
EXPECT_LT(id1_, id2_);
EXPECT_LT(id1_, id3_);
EXPECT_LT(id2_, id3_);
EXPECT_FALSE(id2_ < id1_);
EXPECT_FALSE(id3_ < id1_);
EXPECT_FALSE(id3_ < id2_);
}
TEST_F(SqlStatementIdTest, CopyConstructor) {
StatementID id2_copy = id2_;
EXPECT_FALSE(id2_copy < id2_);
EXPECT_FALSE(id2_ < id2_copy);
EXPECT_LT(id1_, id2_copy);
EXPECT_LT(id2_copy, id3_);
}
TEST_F(SqlStatementIdTest, CopyAssignment) {
StatementID id2_copy(SQL_FROM_HERE);
// The new ID should be different from ID2.
EXPECT_TRUE(id2_copy < id2_ || id2_ < id2_copy);
id2_copy = id2_;
EXPECT_FALSE(id2_copy < id2_);
EXPECT_FALSE(id2_ < id2_copy);
EXPECT_LT(id1_, id2_copy);
EXPECT_LT(id2_copy, id3_);
}
} // namespace
} // namespace sql