104 lines
2.9 KiB
Python
Raw Normal View History

# Copyright (C) 2013 The Android Open Source Project
#
# 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
Buck: Support plugin own Maven repositories Currently only predefined Maven repositories are supported by Buck maven_jar. Additional logic exists to redirect to a local repository mirror. Current implementation relies on the repository name matching between repo passed to maven_jar and redirect definition defined in local.properties that is not under Git control. This change extends that by allowing to pass not only the repo name but the complete URL to maven_jar. The augmented implementation checks if it is a known Maven repository: if it is, then the behavious is unchanged, if not, then the passed URL is used. As result plugin's can use custom Maven repositories: GERRIT_FORGE = 'http://gerritforge.com/snapshot' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Plugin owned Maven repositories can also be rewritten in local.properties. To achieve that custom repository name must be passed to the maven_jar() function, like known repositories, and the URL must be defined in local.properties. local.properties excerpt: download.GERRIT_FORGE = http://my.company.mirror/gerrit-forge BUCK excerpt: GERRIT_FORGE = 'GERRIT_FORGE:' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Python unit test can be executed with other Java unit tests: buck test tools:python_tests Change-Id: Ib31d51f0884b1ca1a07b6492f861f404db115946
2013-11-14 00:35:07 +01:00
from os import path
REPO_ROOTS = {
'GERRIT': 'http://gerrit-maven.storage.googleapis.com',
'GERRIT_API': 'https://gerrit-api.commondatastorage.googleapis.com/release',
Buck: Support plugin own Maven repositories Currently only predefined Maven repositories are supported by Buck maven_jar. Additional logic exists to redirect to a local repository mirror. Current implementation relies on the repository name matching between repo passed to maven_jar and redirect definition defined in local.properties that is not under Git control. This change extends that by allowing to pass not only the repo name but the complete URL to maven_jar. The augmented implementation checks if it is a known Maven repository: if it is, then the behavious is unchanged, if not, then the passed URL is used. As result plugin's can use custom Maven repositories: GERRIT_FORGE = 'http://gerritforge.com/snapshot' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Plugin owned Maven repositories can also be rewritten in local.properties. To achieve that custom repository name must be passed to the maven_jar() function, like known repositories, and the URL must be defined in local.properties. local.properties excerpt: download.GERRIT_FORGE = http://my.company.mirror/gerrit-forge BUCK excerpt: GERRIT_FORGE = 'GERRIT_FORGE:' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Python unit test can be executed with other Java unit tests: buck test tools:python_tests Change-Id: Ib31d51f0884b1ca1a07b6492f861f404db115946
2013-11-14 00:35:07 +01:00
'MAVEN_CENTRAL': 'http://repo1.maven.org/maven2',
'MAVEN_LOCAL': 'file://' + path.expanduser('~/.m2/repository'),
'MAVEN_SNAPSHOT': 'https://oss.sonatype.org/content/repositories/snapshots',
Buck: Support plugin own Maven repositories Currently only predefined Maven repositories are supported by Buck maven_jar. Additional logic exists to redirect to a local repository mirror. Current implementation relies on the repository name matching between repo passed to maven_jar and redirect definition defined in local.properties that is not under Git control. This change extends that by allowing to pass not only the repo name but the complete URL to maven_jar. The augmented implementation checks if it is a known Maven repository: if it is, then the behavious is unchanged, if not, then the passed URL is used. As result plugin's can use custom Maven repositories: GERRIT_FORGE = 'http://gerritforge.com/snapshot' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Plugin owned Maven repositories can also be rewritten in local.properties. To achieve that custom repository name must be passed to the maven_jar() function, like known repositories, and the URL must be defined in local.properties. local.properties excerpt: download.GERRIT_FORGE = http://my.company.mirror/gerrit-forge BUCK excerpt: GERRIT_FORGE = 'GERRIT_FORGE:' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Python unit test can be executed with other Java unit tests: buck test tools:python_tests Change-Id: Ib31d51f0884b1ca1a07b6492f861f404db115946
2013-11-14 00:35:07 +01:00
}
Buck: Support plugin own Maven repositories Currently only predefined Maven repositories are supported by Buck maven_jar. Additional logic exists to redirect to a local repository mirror. Current implementation relies on the repository name matching between repo passed to maven_jar and redirect definition defined in local.properties that is not under Git control. This change extends that by allowing to pass not only the repo name but the complete URL to maven_jar. The augmented implementation checks if it is a known Maven repository: if it is, then the behavious is unchanged, if not, then the passed URL is used. As result plugin's can use custom Maven repositories: GERRIT_FORGE = 'http://gerritforge.com/snapshot' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Plugin owned Maven repositories can also be rewritten in local.properties. To achieve that custom repository name must be passed to the maven_jar() function, like known repositories, and the URL must be defined in local.properties. local.properties excerpt: download.GERRIT_FORGE = http://my.company.mirror/gerrit-forge BUCK excerpt: GERRIT_FORGE = 'GERRIT_FORGE:' maven_jar( name = 'gitblit', id = 'com.gitblit:gitblit:1.4.0', sha1 = '1b130dbf5578ace37507430a4a523f6594bf34fa', license = 'Apache2.0', repository = GERRIT_FORGE, ) Python unit test can be executed with other Java unit tests: buck test tools:python_tests Change-Id: Ib31d51f0884b1ca1a07b6492f861f404db115946
2013-11-14 00:35:07 +01:00
def resolve_url(url, redirects):
""" Resolve URL of a Maven artifact.
prefix:path is passed as URL. prefix identifies known or custom
repositories that can be rewritten in redirects set, passed as
second arguments.
A special case is supported, when prefix neither exists in
REPO_ROOTS, no in redirects set: the url is returned as is.
This enables plugins to pass custom maven_repository URL as is
directly to maven_jar().
Returns a resolved path for Maven artifact.
"""
s = url.find(':')
if s < 0:
return url
scheme, rest = url[:s], url[s+1:]
if scheme in redirects:
root = redirects[scheme]
elif scheme in REPO_ROOTS:
root = REPO_ROOTS[scheme]
else:
return url
root = root.rstrip('/')
rest = rest.lstrip('/')
return '/'.join([root, rest])
def hash_file(hash_obj, path):
"""Hash the contents of a file.
Args:
hash_obj: an open hash object, e.g. hashlib.sha1().
path: path to the file to hash.
Returns:
The passed-in hash_obj.
"""
with open(path, 'rb') as f:
while True:
b = f.read(8192)
if not b:
break
hash_obj.update(b)
return hash_obj
def hash_bower_component(hash_obj, path):
"""Hash the contents of a bower component directory.
This is a stable hash of a directory downloaded with `bower install`, minus
the .bower.json file, which is autogenerated each time by bower. Used in lieu
of hashing a zipfile of the contents, since zipfiles are difficult to hash in
a stable manner.
Args:
hash_obj: an open hash object, e.g. hashlib.sha1().
path: path to the directory to hash.
Returns:
The passed-in hash_obj.
"""
if not os.path.isdir(path):
raise ValueError('Not a directory: %s' % path)
path = os.path.abspath(path)
for root, dirs, files in os.walk(path):
dirs.sort()
for f in sorted(files):
if f == '.bower.json':
continue
p = os.path.join(root, f)
hash_obj.update(p[len(path)+1:])
hash_file(hash_obj, p)
return hash_obj