Merge "Create and upload wheels"

This commit is contained in:
Jenkins 2014-05-30 18:49:14 +00:00 committed by Gerrit Code Review
commit 54a0913638
8 changed files with 292 additions and 628 deletions

View File

@ -0,0 +1,28 @@
#!/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
universal = False
setup_cfg = ConfigParser.SafeConfigParser()
setup_cfg.read("setup.cfg")
if setup_cfg.has_section("wheel"):
universal = setup_cfg.getboolean("wheel", "universal")
if universal:
print("py2.py3")
else:
print("py27")

View File

@ -0,0 +1,38 @@
#!/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 supported python wheels and upload them 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`
# Look in the setup.cfg to see if this is a universal wheel or not
WHEELTYPE=`/usr/local/jenkins/slave_scripts/pypi-extract-universal.py`
FILENAME="$DISTNAME-$TAG.$WHEELTYPE-none-any.whl"
rm -rf *.whl
curl --fail -o $FILENAME http://$TARBALL_SITE/$PROJECT/$FILENAME
# Make sure we actually got a wheel
file -b $FILENAME | grep -i zip
twine upload -r pypi $FILENAME

View File

@ -0,0 +1,38 @@
#!/bin/bash -xe
# 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.
org=$1
project=$2
if [[ -z "$org" || -z "$project" ]]
then
echo "Usage: $0 ORG PROJECT"
echo
echo "ORG: The project organization (eg 'openstack')"
echo "PROJECT: The project name (eg 'nova')"
exit 1
fi
source /usr/local/jenkins/slave_scripts/select-mirror.sh $org $project
rm -f dist/*.tar.gz
tox -evenv pip install wheel
tox -evenv python setup.py bdist_wheel
echo "SHA1sum: "
sha1sum dist/*
echo "MD5sum: "
md5sum dist/*

View File

@ -214,7 +214,10 @@
- builder: - builder:
name: tarball name: tarball
builders: builders:
- shell: "/usr/local/jenkins/slave_scripts/run-tarball.sh {github-org} {project}" - shell: |
#!/bin/bash -xe
/usr/local/jenkins/slave_scripts/run-tarball.sh {github-org} {project}
/usr/local/jenkins/slave_scripts/run-wheel.sh {github-org} {project}
- builder: - builder:
name: devstack-checkout name: devstack-checkout
@ -311,6 +314,17 @@
- target: 'tarballs/{project}/' - target: 'tarballs/{project}/'
source: 'dist/*.tar.gz' source: 'dist/*.tar.gz'
- publisher:
name: wheel
publishers:
- archive:
artifacts: 'dist/*.whl'
- scp:
site: '{site}'
files:
- target: 'tarballs/{project}/'
source: 'dist/*.whl'
- publisher: - publisher:
name: war name: war
publishers: publishers:

View File

@ -1,12 +1,27 @@
- job-template: - job-template:
name: '{name}-pypi-upload' name: '{name}-pypi-both-upload'
node: pypi node: pypi
builders: builders:
- revoke-sudo - revoke-sudo
- gerrit-git-prep - gerrit-git-prep
- shell: | - shell: |
/usr/local/jenkins/slave_scripts/pypi-upload.sh {name} {tarball-site} /usr/local/jenkins/slave_scripts/pypi-tarball-upload.sh {name} {tarball-site}
/usr/local/jenkins/slave_scripts/pypi-wheel-upload.sh {name} {tarball-site}
publishers:
- console-log
- job-template:
name: '{name}-pypi-wheel-upload'
node: pypi
builders:
- revoke-sudo
- gerrit-git-prep
- shell: |
/usr/local/jenkins/slave_scripts/pypi-wheel-upload.sh {name} {tarball-site}
publishers: publishers:
- console-log - console-log
@ -15,4 +30,5 @@
- job-group: - job-group:
name: pypi-jobs name: pypi-jobs
jobs: jobs:
- '{name}-pypi-upload' - '{name}-pypi-both-upload'
- '{name}-pypi-wheel-upload'

View File

@ -200,6 +200,9 @@
- tarball: - tarball:
project: '{name}' project: '{name}'
site: '{tarball-site}' site: '{tarball-site}'
- wheel:
project: '{name}'
site: '{tarball-site}'
- console-log - console-log

File diff suppressed because it is too large Load Diff