Determine the package name when uploading to PyPI

* modules/jenkins/files/slave_scripts/pypi-extract-name.py: Short
new script to safely parse the sdist package name out of a setup.cfg
file.

* modules/jenkins/files/slave_scripts/pypi-upload.sh: Subsume the
guts of the first shell builder from the pypi-upload job, extended
to call pypi-extract-name.py and fall back to the name of the Git
project if it fails--this is needed for cases where those names
differ, for example in capitalization.

* .../jenkins_job_builder/config/pypi-jobs.yaml: Clone and checkout
the Git tag which triggered this upload to PyPI, and then only call
the modified pypi-upload.sh script since it should now analyze the
state of the setup.cfg to determine how to retrieve the
corresponding tarball.

Change-Id: I43843e6e74b918e9c68f4b27958ec605774668ff
This commit is contained in:
Jeremy Stanley 2013-09-16 18:59:46 +00:00
parent fa6b9be9ec
commit 7a9fe8a9d0
3 changed files with 48 additions and 21 deletions

View File

@ -0,0 +1,23 @@
#!/usr/bin/python
#
# 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 Python package name from setup.cfg
import ConfigParser
setup_cfg = ConfigParser.SafeConfigParser()
setup_cfg.read("setup.cfg")
distname = setup_cfg.get("metadata", "name")
assert distname
print(distname)

View File

@ -1,6 +1,7 @@
#!/bin/bash
#!/bin/bash -xe
#
# Copyright 2012 Hewlett-Packard Development Company, L.P.
# Copyright 2013 OpenStack Foundation
#
# 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
@ -14,26 +15,38 @@
# License for the specific language governing permissions and limitations
# under the License.
#
# Upload python sdist to pypi with Curl.
# Retrieve a python sdist and upload it to pypi with Curl.
PROJECT=$1
TARBALL_SITE=$2
TAG=`echo $ZUUL_REF | sed 's/^refs.tags.//'`
# Look in the setup.cfg to determine if a package name is specified, but
# fall back on the project name if necessary
DISTNAME=`/usr/local/jenkins/slave_scripts/pypi-extract-name.py \
|| echo $PROJECT`
FILENAME="$DISTNAME-$TAG.tar.gz"
rm -rf *tar.gz
curl --fail -o $FILENAME http://$TARBALL_SITE/$PROJECT/$FILENAME
# Make sure we actually got a gzipped file
file -b $FILENAME | grep gzip
FILENAME=`ls ${PROJECT}*.tar.gz`
# Strip project name and extension leaving only the version.
VERSION=`echo ${FILENAME} | sed -n "s/${PROJECT}-\(.*\).tar.gz/\1/p"`
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=${PROJECT}" \
-F "version=${VERSION}" \
-F "name=${DISTNAME}" \
-F "version=${TAG}" \
-F "md5_digest=${MD5_DIGEST}" \
https://pypi.python.org/pypi > /dev/null 2>&1
exit $?

View File

@ -3,18 +3,9 @@
node: pypi
builders:
- gerrit-git-prep
- shell: |
#!/bin/bash -xe
TAG=`echo $ZUUL_REF | sed 's/^refs.tags.//'`
FILENAME="{name}-$TAG.tar.gz"
rm -rf *tar.gz
curl --fail -o $FILENAME http://{tarball-site}/{name}/$FILENAME
# Make sure we actually got a gzipped file
file -b $FILENAME | grep gzip
- shell: |
/usr/local/jenkins/slave_scripts/pypi-upload.sh {name}
/usr/local/jenkins/slave_scripts/pypi-upload.sh {name} {tarball-site}
publishers:
- console-log