
* 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
53 lines
1.8 KiB
Bash
Executable File
53 lines
1.8 KiB
Bash
Executable File
#!/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
|
|
# 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.
|
|
#
|
|
# 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
|
|
|
|
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
|