-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathsetup.py
87 lines (78 loc) · 3.28 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
#!/usr/bin/env python
# Copyright 2022 Cloudera Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import os
import re
from setuptools import find_namespace_packages, setup
# pull long description from README
this_directory = os.path.abspath(os.path.dirname(__file__))
with open(os.path.join(this_directory, "README.md"), encoding="utf8") as f:
long_description = f.read()
# get this package's version from dbt/adapters/<name>/__version__.py
def _get_plugin_version_dict():
_version_path = os.path.join(this_directory, "dbt", "adapters", "hive", "__version__.py")
_semver = r"""(?P<major>\d+)\.(?P<minor>\d+)\.(?P<patch>\d+)"""
_pre = r"""((?P<prekind>a|b|rc)(?P<pre>\d+))?"""
_version_pattern = rf"""version\s*=\s*["']{_semver}{_pre}["']"""
with open(_version_path) as f:
match = re.search(_version_pattern, f.read().strip())
if match is None:
raise ValueError(f"invalid version at {_version_path}")
return match.groupdict()
# require a compatible minor version (~=), prerelease if this is a prerelease
def _get_dbt_core_version():
parts = _get_plugin_version_dict()
minor = "{major}.{minor}.0".format(**parts)
pre = parts["prekind"] + "1" if parts["prekind"] else ""
return f"{minor}{pre}"
package_name = "dbt-hive"
# make sure this always matches dbt/adapters/hive/__version__.py
package_version = "1.8.0"
description = """The Hive adapter plugin for dbt"""
dbt_core_version = _get_dbt_core_version()
setup(
name=package_name,
version=package_version,
description=description,
long_description=long_description,
long_description_content_type="text/markdown",
author="Cloudera",
author_email="[email protected]",
url="https://github.com/cloudera/dbt-hive",
packages=find_namespace_packages(include=["dbt", "dbt.*"]),
data_files=[("", ["dbt/adapters/hive/.env"])],
include_package_data=True,
package_data={
"dbt": [
"include/hive/dbt_project.yml",
"include/hive/sample_profiles.yml",
"include/hive/macros/*.sql",
"include/hive/macros/*/*.sql",
"include/hive/macros/*/*/*.sql",
]
},
install_requires=[
f"dbt-core~={dbt_core_version}",
"setuptools>=40.3.0",
"impyla==0.18",
"sqlparams>=3.0.0",
"python-decouple>=3.6",
# pining the protobuf version to 4.x because the dbt-core backports were messed up.
# more details in https://github.com/dbt-labs/dbt-core/issues/9830.
# TODO: remove this pin once the above issue and https://github.com/dbt-labs/dbt-core/issues/9724 is resolved.
"protobuf>=4.0.0,<5",
"kerberos>=1.3.0; platform_system == 'Darwin' or platform_system == 'Linux' ",
"winkerberos>=0.9.1; platform_system == 'Windows' ",
],
)