Merge "Use twine to upload python package to pypi."
This commit is contained in:
commit
9611a8b343
@ -1,56 +0,0 @@
|
||||
#!/usr/bin/python
|
||||
#
|
||||
# Copyright 2012 Hewlett-Packard Development Company, L.P.
|
||||
#
|
||||
# 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.
|
||||
#
|
||||
# Extract package info metadata for use by curl.
|
||||
|
||||
import pkginfo
|
||||
import sys
|
||||
|
||||
if len(sys.argv) < 3:
|
||||
exit()
|
||||
|
||||
info = pkginfo.SDist(sys.argv[1])
|
||||
curl_config = open(sys.argv[2], 'w')
|
||||
|
||||
meta_items = {
|
||||
'metadata_version': info.metadata_version,
|
||||
'summary': info.summary,
|
||||
'home_page': info.home_page,
|
||||
'author': info.author,
|
||||
'author_email': info.author_email,
|
||||
'license': info.license,
|
||||
'description': info.description,
|
||||
'keywords': info.keywords,
|
||||
'platform': info.platforms,
|
||||
'classifiers': info.classifiers,
|
||||
'download_url': info.download_url,
|
||||
'provides': info.provides,
|
||||
'requires': info.requires,
|
||||
'obsoletes': info.obsoletes,
|
||||
}
|
||||
|
||||
for key, value in meta_items.items():
|
||||
if not value:
|
||||
continue
|
||||
if not isinstance(value, list):
|
||||
value = [value]
|
||||
for v in value:
|
||||
v = v.replace('\n', r'\n')
|
||||
v = v.replace('"', r'\"')
|
||||
curl_config.write('form = "%s=%s"\n' % (key, v))
|
||||
|
||||
curl_config.write('\n')
|
||||
curl_config.close()
|
@ -33,20 +33,4 @@ curl --fail -o $FILENAME http://$TARBALL_SITE/$PROJECT/$FILENAME
|
||||
# Make sure we actually got a gzipped file
|
||||
file -b $FILENAME | grep gzip
|
||||
|
||||
MD5_DIGEST=`md5sum ${FILENAME} | cut -d' ' -f1`
|
||||
|
||||
/usr/local/jenkins/slave_scripts/pypi-extract-metadata.py $FILENAME metadata.curl
|
||||
|
||||
# Turn off xtrace and mute curl, since under some circumstances API
|
||||
# errors may leak authentication credentials
|
||||
set +x
|
||||
curl --config /home/jenkins/.pypicurl \
|
||||
--config metadata.curl \
|
||||
-F "filetype=sdist" \
|
||||
-F "content=@${FILENAME};filename=${FILENAME}" \
|
||||
-F ":action=file_upload" \
|
||||
-F "protocol_version=1" \
|
||||
-F "name=${DISTNAME}" \
|
||||
-F "version=${TAG}" \
|
||||
-F "md5_digest=${MD5_DIGEST}" \
|
||||
https://pypi.python.org/pypi > /dev/null 2>&1
|
||||
twine upload $FILENAME
|
||||
|
@ -28,18 +28,18 @@ class openstack_project::pypi_slave (
|
||||
|
||||
include pip
|
||||
|
||||
package { 'pkginfo':
|
||||
package { 'twine':
|
||||
ensure => present,
|
||||
provider => 'pip',
|
||||
require => Class['pip'],
|
||||
}
|
||||
|
||||
file { '/home/jenkins/.pypicurl':
|
||||
file { '/home/jenkins/.pypirc':
|
||||
ensure => present,
|
||||
owner => 'jenkins',
|
||||
group => 'jenkins',
|
||||
mode => '0600',
|
||||
content => template('openstack_project/pypicurl.erb'),
|
||||
content => template('openstack_project/pypirc.erb'),
|
||||
require => File['/home/jenkins'],
|
||||
}
|
||||
|
||||
|
@ -1 +0,0 @@
|
||||
user = "<%= pypi_username %>:<%= pypi_password %>"
|
4
modules/openstack_project/templates/pypirc.erb
Normal file
4
modules/openstack_project/templates/pypirc.erb
Normal file
@ -0,0 +1,4 @@
|
||||
[pypi]
|
||||
repository: https://pypi.python.org/pypi
|
||||
username: <%= pypi_username %>
|
||||
password: <%= pypi_password %>
|
Loading…
x
Reference in New Issue
Block a user