• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

georgia-tech-db / eva / #763

06 Sep 2023 03:00AM UTC coverage: 74.923% (+5.1%) from 69.779%
#763

push

circle-ci

jiashenC
fix lint

10 of 10 new or added lines in 1 file covered. (100.0%)

8739 of 11664 relevant lines covered (74.92%)

0.75 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

57.14
/evadb/executor/create_database_executor.py
1
# coding=utf-8
2
# Copyright 2018-2023 EvaDB
3
#
4
# Licensed under the Apache License, Version 2.0 (the "License");
5
# you may not use this file except in compliance with the License.
6
# You may obtain a copy of the License at
7
#
8
#     http://www.apache.org/licenses/LICENSE-2.0
9
#
10
# Unless required by applicable law or agreed to in writing, software
11
# distributed under the License is distributed on an "AS IS" BASIS,
12
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
# See the License for the specific language governing permissions and
14
# limitations under the License.
15
import pandas as pd
1✔
16

17
from evadb.database import EvaDBDatabase
1✔
18
from evadb.executor.abstract_executor import AbstractExecutor
1✔
19
from evadb.executor.executor_utils import ExecutorError
1✔
20
from evadb.models.storage.batch import Batch
1✔
21
from evadb.parser.create_statement import CreateDatabaseStatement
1✔
22
from evadb.third_party.databases.interface import get_database_handler
1✔
23
from evadb.utils.logging_manager import logger
1✔
24

25

26
class CreateDatabaseExecutor(AbstractExecutor):
1✔
27
    def __init__(self, db: EvaDBDatabase, node: CreateDatabaseStatement):
1✔
28
        super().__init__(db, node)
1✔
29

30
    def exec(self, *args, **kwargs):
1✔
31
        # TODO: handle if_not_exists
32

33
        logger.debug(
×
34
            f"Trying to connect to the provided engine {self.node.engine} with params {self.node.param_dict}"
35
        )
36

37
        # Check if database already exists.
38
        db_catalog_entry = self.catalog().get_database_catalog_entry(
×
39
            self.node.database_name
40
        )
41
        if db_catalog_entry is not None:
×
42
            raise ExecutorError(f"{self.node.database_name} already exists.")
43

44
        # Check the validity of database entry.
45
        handler = get_database_handler(self.node.engine, **self.node.param_dict)
×
46
        resp = handler.connect()
×
47
        if not resp.status:
×
48
            raise ExecutorError(f"Cannot establish connection due to {resp.error}")
49

50
        logger.debug(f"Creating database {self.node}")
×
51
        self.catalog().insert_database_catalog_entry(
×
52
            self.node.database_name, self.node.engine, self.node.param_dict
53
        )
54

55
        yield Batch(
×
56
            pd.DataFrame(
57
                [
58
                    f"The database {self.node.database_name} has been successfully created."
59
                ]
60
            )
61
        )
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc