當前位置: 首頁>>代碼示例>>Python>>正文


Python GLOBAL_LOGGER.debug方法代碼示例

本文整理匯總了Python中dbt.logger.GLOBAL_LOGGER.debug方法的典型用法代碼示例。如果您正苦於以下問題:Python GLOBAL_LOGGER.debug方法的具體用法?Python GLOBAL_LOGGER.debug怎麽用?Python GLOBAL_LOGGER.debug使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在dbt.logger.GLOBAL_LOGGER的用法示例。


在下文中一共展示了GLOBAL_LOGGER.debug方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: run_sql

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def run_sql(self, query, fetch='None', kwargs=None, connection_name=None):
        if connection_name is None:
            connection_name = '__test'

        if query.strip() == "":
            return

        sql = self.transform_sql(query, kwargs=kwargs)
        if self.adapter_type == 'bigquery':
            return self.run_sql_bigquery(sql, fetch)
        elif self.adapter_type == 'presto':
            return self.run_sql_presto(sql, fetch, connection_name)

        conn = self.adapter.acquire_connection(connection_name)
        with conn.handle.cursor() as cursor:
            logger.debug('test connection "{}" executing: {}'.format(connection_name, sql))
            try:
                cursor.execute(sql)
                conn.handle.commit()
                if fetch == 'one':
                    return cursor.fetchone()
                elif fetch == 'all':
                    return cursor.fetchall()
                else:
                    return
            except BaseException as e:
                conn.handle.rollback()
                print(query)
                print(e)
                raise e
            finally:
                conn.transaction_open = False
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:34,代碼來源:base.py

示例2: open

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def open(cls, connection):
        if connection.state == 'open':
            logger.debug('Connection is already open, skipping open.')
            return connection

        try:
            handle = cls.get_bigquery_client(connection.credentials)

        except google.auth.exceptions.DefaultCredentialsError as e:
            logger.info("Please log into GCP to continue")
            dbt.clients.gcloud.setup_default_credentials()

            handle = cls.get_bigquery_client(connection.credentials)

        except Exception as e:
            raise
            logger.debug("Got an error when attempting to create a bigquery "
                         "client: '{}'".format(e))

            connection.handle = None
            connection.state = 'fail'

            raise dbt.exceptions.FailedToConnectException(str(e))

        connection.handle = handle
        connection.state = 'open'
        return connection
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:29,代碼來源:connections.py

示例3: expand_column_types

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def expand_column_types(self, goal, current, model_name=None):
        reference_columns = {
            c.name: c for c in
            self.get_columns_in_relation(goal, model_name=model_name)
        }

        target_columns = {
            c.name: c for c
            in self.get_columns_in_relation(current, model_name=model_name)
        }

        for column_name, reference_column in reference_columns.items():
            target_column = target_columns.get(column_name)

            if target_column is not None and \
               target_column.can_expand_to(reference_column):
                col_string_size = reference_column.string_size()
                new_type = self.Column.string_type(col_string_size)
                logger.debug("Changing col type from %s to %s in table %s",
                             target_column.data_type, new_type, current)

                self.alter_column_type(current, column_name, new_type,
                                       model_name=model_name)

        if model_name is None:
            self.release_connection('master')
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:28,代碼來源:impl.py

示例4: clone_and_checkout

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
def clone_and_checkout(repo, cwd, dirname=None, remove_git_dir=False,
                       branch=None):
    exists = None
    try:
        _, err = clone(repo, cwd, dirname=dirname,
                       remove_git_dir=remove_git_dir)
    except dbt.exceptions.CommandResultError as exc:
        err = exc.stderr.decode('utf-8')
        exists = re.match("fatal: destination path '(.+)' already exists", err)
        if not exists:  # something else is wrong, raise it
            raise

    directory = None
    start_sha = None
    if exists:
        directory = exists.group(1)
        logger.debug('Updating existing dependency %s.', directory)
    else:
        matches = re.match("Cloning into '(.+)'", err.decode('utf-8'))
        directory = matches.group(1)
        logger.debug('Pulling new dependency %s.', directory)
    full_path = os.path.join(cwd, directory)
    start_sha = get_current_sha(full_path)
    checkout(full_path, repo, branch)
    end_sha = get_current_sha(full_path)
    if exists:
        if start_sha == end_sha:
            logger.debug('  Already at %s, nothing to do.', start_sha[:7])
        else:
            logger.debug('  Updated checkout from %s to %s.',
                         start_sha[:7], end_sha[:7])
    else:
        logger.debug('  Checked out at %s.', end_sha[:7])
    return directory
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:36,代碼來源:git.py

示例5: patch_nodes

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def patch_nodes(self, patches):
        """Patch nodes with the given dict of patches. Note that this consumes
        the input!
        """
        # because we don't have any mapping from node _names_ to nodes, and we
        # only have the node name in the patch, we have to iterate over all the
        # nodes looking for matching names. We could use _find_by_name if we
        # were ok with doing an O(n*m) search (one nodes scan per patch)
        for node in self.nodes.values():
            if node.resource_type != NodeType.Model:
                continue
            patch = patches.pop(node.name, None)
            if not patch:
                continue
            node.patch(patch)

        # log debug-level warning about nodes we couldn't find
        if patches:
            for patch in patches.values():
                # since patches aren't nodes, we can't use the existing
                # target_not_found warning
                logger.debug((
                    'WARNING: Found documentation for model "{}" which was '
                    'not found or is disabled').format(patch.name)
                )
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:27,代碼來源:manifest.py

示例6: render_profile

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def render_profile(cls, raw_profile, profile_name, target_override,
                       cli_vars):
        """This is a containment zone for the hateful way we're rendering
        profiles.
        """
        renderer = ConfigRenderer(cli_vars=cli_vars)

        # rendering profiles is a bit complex. Two constraints cause trouble:
        # 1) users should be able to use environment/cli variables to specify
        #    the target in their profile.
        # 2) Missing environment/cli variables in profiles/targets that don't
        #    end up getting selected should not cause errors.
        # so first we'll just render the target name, then we use that rendered
        # name to extract a profile that we can render.
        if target_override is not None:
            target_name = target_override
        elif 'target' in raw_profile:
            # render the target if it was parsed from yaml
            target_name = renderer.render_value(raw_profile['target'])
        else:
            target_name = 'default'
            logger.debug(
                "target not specified in profile '{}', using '{}'"
                .format(profile_name, target_name)
            )

        raw_profile_data = cls._get_profile_data(
            raw_profile, profile_name, target_name
        )

        profile_data = renderer.render_profile_data(raw_profile_data)
        return target_name, profile_data
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:34,代碼來源:profile.py

示例7: handle_error

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def handle_error(cls, error, message, sql):
        logger.debug(message.format(sql=sql))
        logger.debug(error)
        error_msg = "\n".join(
            [item['message'] for item in error.errors])

        raise dbt.exceptions.DatabaseException(error_msg)
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:9,代碼來源:connections.py

示例8: gcloud_installed

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
def gcloud_installed():
    try:
        run_cmd('.', ['gcloud', '--version'])
        return True
    except OSError as e:
        logger.debug(e)
        return False
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:9,代碼來源:gcloud.py

示例9: initialize_tracking

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
def initialize_tracking(cookie_dir):
    global active_user
    active_user = User(cookie_dir)
    try:
        active_user.initialize()
    except Exception:
        logger.debug('Got an exception trying to initialize tracking',
                     exc_info=True)
        active_user = User(None)
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:11,代碼來源:tracking.py

示例10: drop_schema

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
 def drop_schema(self, database, schema, model_name=None):
     logger.debug('Dropping schema "%s"."%s".', database, schema)
     kwargs = {
         'database_name': self.quote_as_configured(database, 'database'),
         'schema_name': self.quote_as_configured(schema, 'schema'),
     }
     self.execute_macro(DROP_SCHEMA_MACRO_NAME,
                        kwargs=kwargs,
                        connection_name=model_name)
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:11,代碼來源:impl.py

示例11: compile_node

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def compile_node(self, node, manifest, extra_context=None):
        if extra_context is None:
            extra_context = {}

        logger.debug("Compiling {}".format(node.get('unique_id')))

        data = node.to_dict()
        data.update({
            'compiled': False,
            'compiled_sql': None,
            'extra_ctes_injected': False,
            'extra_ctes': [],
            'injected_sql': None,
        })
        compiled_node = CompiledNode(**data)

        context = dbt.context.runtime.generate(
            compiled_node, self.config, manifest)
        context.update(extra_context)

        compiled_node.compiled_sql = dbt.clients.jinja.get_rendered(
            node.get('raw_sql'),
            context,
            node)

        compiled_node.compiled = True

        injected_node, _ = prepend_ctes(compiled_node, manifest)

        should_wrap = {NodeType.Test, NodeType.Operation}
        if injected_node.resource_type in should_wrap:
            # data tests get wrapped in count(*)
            # TODO : move this somewhere more reasonable
            if 'data' in injected_node.tags and \
               is_type(injected_node, NodeType.Test):
                injected_node.wrapped_sql = (
                    "select count(*) from (\n{test_sql}\n) sbq").format(
                        test_sql=injected_node.injected_sql)
            else:
                # don't wrap schema tests or analyses.
                injected_node.wrapped_sql = injected_node.injected_sql

        elif is_type(injected_node, NodeType.Archive):
            # unfortunately we do everything automagically for
            # archives. in the future it'd be nice to generate
            # the SQL at the parser level.
            pass

        elif(is_type(injected_node, NodeType.Model) and
             get_materialization(injected_node) == 'ephemeral'):
            pass

        else:
            injected_node.wrapped_sql = None

        return injected_node
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:58,代碼來源:compilation.py

示例12: parse_macro_file

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def parse_macro_file(self, macro_file_path, macro_file_contents, root_path,
                         package_name, resource_type, tags=None, context=None):

        logger.debug("Parsing {}".format(macro_file_path))

        to_return = {}

        if tags is None:
            tags = []

        context = {}

        # change these to actual kwargs
        base_node = UnparsedMacro(
            path=macro_file_path,
            original_file_path=macro_file_path,
            package_name=package_name,
            raw_sql=macro_file_contents,
            root_path=root_path,
        )

        try:
            ast = dbt.clients.jinja.parse(macro_file_contents)
        except dbt.exceptions.CompilationException as e:
            e.node = base_node
            raise e

        for macro_node in ast.find_all(jinja2.nodes.Macro):
            macro_name = macro_node.name

            node_type = None
            if macro_name.startswith(dbt.utils.MACRO_PREFIX):
                node_type = NodeType.Macro
                name = macro_name.replace(dbt.utils.MACRO_PREFIX, '')

            if node_type != resource_type:
                continue

            unique_id = self.get_path(resource_type, package_name, name)

            merged = dbt.utils.deep_merge(
                base_node.serialize(),
                {
                    'name': name,
                    'unique_id': unique_id,
                    'tags': tags,
                    'resource_type': resource_type,
                    'depends_on': {'macros': []},
                })

            new_node = ParsedMacro(**merged)

            to_return[unique_id] = new_node

        return to_return
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:57,代碼來源:macros.py

示例13: track

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
def track(user, *args, **kwargs):
    if user.do_not_track:
        return
    else:
        logger.debug("Sending event: {}".format(kwargs))
        try:
            tracker.track_struct_event(*args, **kwargs)
        except Exception:
            logger.debug(
                "An error was encountered while trying to send an event"
            )
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:13,代碼來源:tracking.py

示例14: create_schema

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
 def create_schema(self, database, schema, model_name=None):
     logger.debug('Creating schema "%s"."%s".', database, schema)
     if model_name is None:
         model_name = 'master'
     kwargs = {
         'database_name': self.quote_as_configured(database, 'database'),
         'schema_name': self.quote_as_configured(schema, 'schema'),
     }
     self.execute_macro(CREATE_SCHEMA_MACRO_NAME,
                        kwargs=kwargs,
                        connection_name=model_name)
     self.commit_if_has_connection(model_name)
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:14,代碼來源:impl.py

示例15: cancel

# 需要導入模塊: from dbt.logger import GLOBAL_LOGGER [as 別名]
# 或者: from dbt.logger.GLOBAL_LOGGER import debug [as 別名]
    def cancel(self, connection):
        connection_name = connection.name
        pid = connection.handle.get_backend_pid()

        sql = "select pg_terminate_backend({})".format(pid)

        logger.debug("Cancelling query '{}' ({})".format(connection_name, pid))

        _, cursor = self.add_query(sql, 'master')
        res = cursor.fetchone()

        logger.debug("Cancel query '{}': {}".format(connection_name, res))
開發者ID:analyst-collective,項目名稱:dbt,代碼行數:14,代碼來源:connections.py


注:本文中的dbt.logger.GLOBAL_LOGGER.debug方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。