cbd825deea
Summary: This PR implements the MergeOperator for Cassandra Row Values. Closes https://github.com/facebook/rocksdb/pull/2289 Differential Revision: D5055464 Pulled By: scv119 fbshipit-source-id: 45f276ef8cbc4704279202f6a20c64889bc1adef
44 lines
1.4 KiB
C++
44 lines
1.4 KiB
C++
// Copyright (c) 2017-present, Facebook, Inc. All rights reserved.
|
|
// This source code is licensed under the BSD-style license found in the
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
// This source code is also licensed under the GPLv2 license found in the
|
|
// COPYING file in the root directory of this source tree.
|
|
|
|
#pragma once
|
|
#include <memory>
|
|
#include "util/testharness.h"
|
|
#include "utilities/merge_operators/cassandra/format.h"
|
|
#include "utilities/merge_operators/cassandra/serialize.h"
|
|
|
|
namespace rocksdb {
|
|
namespace cassandra {
|
|
extern const char kData[];
|
|
extern const char kExpiringData[];
|
|
extern const int32_t kLocalDeletionTime;
|
|
extern const int32_t kTtl;
|
|
extern const int8_t kColumn;
|
|
extern const int8_t kTombstone;
|
|
extern const int8_t kExpiringColumn;
|
|
|
|
|
|
std::unique_ptr<ColumnBase> CreateTestColumn(int8_t mask,
|
|
int8_t index,
|
|
int64_t timestamp);
|
|
|
|
RowValue CreateTestRowValue(
|
|
std::vector<std::tuple<int8_t, int8_t, int64_t>> column_specs);
|
|
|
|
RowValue CreateRowTombstone(int64_t timestamp);
|
|
|
|
void VerifyRowValueColumns(
|
|
std::vector<std::unique_ptr<ColumnBase>> &columns,
|
|
std::size_t index_of_vector,
|
|
int8_t expected_mask,
|
|
int8_t expected_index,
|
|
int64_t expected_timestamp
|
|
);
|
|
|
|
}
|
|
}
|