YugabyteDB (2.13.0.0-b42, bfc6a6643e7399ac8a0e81d06a3ee6d6571b33ab)

Coverage Report

Created: 2022-03-09 17:30

/Users/deen/code/yugabyte-db/src/yb/master/yql_views_vtable.cc
Line
Count
Source
1
// Copyright (c) YugaByte, Inc.
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
4
// in compliance with the License.  You may obtain a copy of the License at
5
//
6
// http://www.apache.org/licenses/LICENSE-2.0
7
//
8
// Unless required by applicable law or agreed to in writing, software distributed under the License
9
// is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
10
// or implied.  See the License for the specific language governing permissions and limitations
11
// under the License.
12
//
13
#include "yb/master/yql_views_vtable.h"
14
15
#include "yb/common/ql_type.h"
16
#include "yb/common/schema.h"
17
#include "yb/util/status_log.h"
18
19
namespace yb {
20
namespace master {
21
22
YQLViewsVTable::YQLViewsVTable(const TableName& table_name,
23
                               const NamespaceName& namespace_name,
24
                               Master * const master)
25
2.00k
    : YQLEmptyVTable(table_name, namespace_name, master, CreateSchema()) {
26
2.00k
}
27
28
2.00k
Schema YQLViewsVTable::CreateSchema() const {
29
2.00k
  SchemaBuilder builder;
30
2.00k
  CHECK_OK(builder.AddHashKeyColumn("keyspace_name", QLType::Create(DataType::STRING)));
31
2.00k
  CHECK_OK(builder.AddKeyColumn("view_name", QLType::Create(DataType::STRING)));
32
2.00k
  CHECK_OK(builder.AddColumn("base_table_id", QLType::Create(DataType::UUID)));
33
2.00k
  CHECK_OK(builder.AddColumn("base_table_name", QLType::Create(DataType::STRING)));
34
2.00k
  CHECK_OK(builder.AddColumn("bloom_filter_fp_chance", QLType::Create(DataType::DOUBLE)));
35
  // TODO: caching needs to be a frozen map.
36
2.00k
  CHECK_OK(builder.AddColumn("caching",
37
2.00k
                             QLType::CreateTypeMap(DataType::STRING, DataType::STRING)));
38
2.00k
  CHECK_OK(builder.AddColumn("cdc", QLType::Create(DataType::BOOL)));
39
2.00k
  CHECK_OK(builder.AddColumn("comment", QLType::Create(DataType::STRING)));
40
  // TODO: compaction needs to be a frozen map.
41
2.00k
  CHECK_OK(builder.AddColumn("compaction",
42
2.00k
                             QLType::CreateTypeMap(DataType::STRING, DataType::STRING)));
43
  // TODO: compression needs to be a frozen map.
44
2.00k
  CHECK_OK(builder.AddColumn("compression",
45
2.00k
                             QLType::CreateTypeMap(DataType::STRING, DataType::STRING)));
46
2.00k
  CHECK_OK(builder.AddColumn("crc_check_chance", QLType::Create(DataType::DOUBLE)));
47
2.00k
  CHECK_OK(builder.AddColumn("dclocal_read_repair_chance", QLType::Create(DataType::DOUBLE)));
48
2.00k
  CHECK_OK(builder.AddColumn("default_time_to_live", QLType::Create(DataType::INT32)));
49
2.00k
  CHECK_OK(builder.AddColumn("extensions",
50
2.00k
                             QLType::CreateTypeMap(DataType::STRING, DataType::BINARY)));
51
2.00k
  CHECK_OK(builder.AddColumn("gc_grace_seconds", QLType::Create(DataType::INT32)));
52
2.00k
  CHECK_OK(builder.AddColumn("id", QLType::Create(DataType::UUID)));
53
2.00k
  CHECK_OK(builder.AddColumn("include_all_columns", QLType::Create(DataType::BOOL)));
54
2.00k
  CHECK_OK(builder.AddColumn("max_index_interval", QLType::Create(DataType::INT32)));
55
2.00k
  CHECK_OK(builder.AddColumn("memtable_flush_period_in_ms", QLType::Create(DataType::INT32)));
56
2.00k
  CHECK_OK(builder.AddColumn("min_index_interval", QLType::Create(DataType::INT32)));
57
2.00k
  CHECK_OK(builder.AddColumn("read_repair_chance", QLType::Create(DataType::DOUBLE)));
58
2.00k
  CHECK_OK(builder.AddColumn("speculative_retry", QLType::Create(DataType::STRING)));
59
2.00k
  CHECK_OK(builder.AddColumn("where_clause", QLType::Create(DataType::STRING)));
60
2.00k
  return builder.Build();
61
2.00k
}
62
63
}  // namespace master
64
}  // namespace yb