From e3c37b51a996073e4075a044d0a5c33d2ced4a47 Mon Sep 17 00:00:00 2001 From: Boris Ranto Date: Wed, 21 Jun 2017 20:37:14 +0200 Subject: [PATCH] cephmetrics: Add new build job Signed-off-by: Boris Ranto --- cephmetrics/build/build_rpm | 70 ++++++++++++++ cephmetrics/build/setup | 44 +++++++++ .../config/definitions/cephmetrics.yml | 93 +++++++++++++++++++ 3 files changed, 207 insertions(+) create mode 100644 cephmetrics/build/build_rpm create mode 100644 cephmetrics/build/setup create mode 100644 cephmetrics/config/definitions/cephmetrics.yml diff --git a/cephmetrics/build/build_rpm b/cephmetrics/build/build_rpm new file mode 100644 index 00000000..4bc91afc --- /dev/null +++ b/cephmetrics/build/build_rpm @@ -0,0 +1,70 @@ +#! /usr/bin/bash +set -ex + +# Only do actual work when we are an RPM distro +if test "$DISTRO" != "fedora" -a "$DISTRO" != "centos" -a "$DISTRO" != "rhel"; then + exit 0 +fi + + +## Install any setup-time deps (to make dist package) + +# We need this to get the major version from lsb_release +yum install -y redhat-lsb-core mock git + +# Run the install-deps.sh upstream script if it exists +if [ -x install-deps.sh ]; then + echo "Ensuring dependencies are installed" + sudo ./install-deps.sh +fi + + +## Get some basic information about the system and the repository +RELEASE="$(lsb_release --short -r | cut -d '.' -f 1)" # sytem release +VERSION="0.1" +REVISION="$(git rev-list --count HEAD)-g$(git rev-parse --short HEAD)" +RPM_RELEASE=$(echo $REVISION | tr '-' '_') # the '-' has a special meaning + + +## Build the source tarball +echo "Building source distribution" +git archive --format=zip --prefix=cephmetrics-${VERSION}/ HEAD > dist/cephmetrics-${VERSION}.zip +wget https://grafana.com/api/plugins/vonage-status-panel/versions/1.0.4/download -O dist/vonage-status-panel-1.0.4.zip + + +## Prepare the spec file for build +sed -e "s/@VERSION@/${VERSION}/g" -e "s/@RELEASE@/${RPM_RELEASE}/g" < cephmetrics.spec.in > dist/cephmetrics.spec + + +## Create the source rpm +echo "Building SRPM" +rpmbuild \ + --define "_sourcedir ./dist" \ + --define "_specdir ." \ + --define "_builddir ." \ + --define "_srcrpmdir ." \ + --define "_rpmdir ." \ + --define "dist .any" \ + --define "fedora 21" \ + --define "rhel 7" \ + --nodeps -bs dist/cephmetrics.spec +SRPM=$(readlink -f *.src.rpm) + + +## Build the binaries with mock +echo "Building RPMs" +sudo mock -r ${MOCK_TARGET}-${RELEASE}-${ARCH} --resultdir=./dist/rpm/ ${SRPM} + + +## Upload the created RPMs to chacra +chacra_endpoint="cephmetrics/${BRANCH}/${GIT_COMMIT}/${DISTRO}/${RELEASE}" + +[ "$FORCE" = true ] && chacra_flags="--force" || chacra_flags="" + +# push binaries to chacra +find ./dist/rpm/ | egrep '\.rpm$' | $VENV/chacractl binary ${chacra_flags} create ${chacra_endpoint}/$ARCH/ + +# start repo creation +$VENV/chacractl repo update ${chacra_endpoint} + +echo Check the status of the repo at: https://shaman.ceph.com/api/repos/${chacra_endpoint} diff --git a/cephmetrics/build/setup b/cephmetrics/build/setup new file mode 100644 index 00000000..41939805 --- /dev/null +++ b/cephmetrics/build/setup @@ -0,0 +1,44 @@ +#! /usr/bin/bash +# +# Ceph distributed storage system +# +# Copyright (C) 2016 Red Hat +# +# Author: Boris Ranto +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +set -ex + +# Make sure we execute at the top level directory before we do anything +cd $WORKSPACE + +# This will set the DISTRO and MOCK_TARGET variables +get_distro_and_target + +# Perform a clean-up +git clean -fxd + +# Make sure the dist directory is clean +rm -rf dist +mkdir -p dist + +# Print some basic system info +HOST=$(hostname --short) +echo "Building on $(hostname) with the following env" +echo "*****" +env +echo "*****" + +export LC_ALL=C # the following is vulnerable to i18n + +pkgs=( "chacractl>=0.0.4" ) +install_python_packages "pkgs[@]" + +# ask shaman which chacra instance to use +chacra_url=`curl -f -u $SHAMAN_API_USER:$SHAMAN_API_KEY https://shaman.ceph.com/api/nodes/next/` +# create the .chacractl config file using global variables +make_chacractl_config $chacra_url diff --git a/cephmetrics/config/definitions/cephmetrics.yml b/cephmetrics/config/definitions/cephmetrics.yml new file mode 100644 index 00000000..6e831df5 --- /dev/null +++ b/cephmetrics/config/definitions/cephmetrics.yml @@ -0,0 +1,93 @@ +- job: + name: cephmetrics + project-type: matrix + defaults: global + display-name: 'cephmetrics' + block-downstream: false + block-upstream: false + concurrent: true + parameters: + - string: + name: BRANCH + description: "The git branch (or tag) to build" + + - string: + name: DISTROS + description: "A list of distros to build for. Available options are: centos7, centos6" + default: "centos7" + + - string: + name: ARCHS + description: "A list of architectures to build for. Available options are: x86_64, and arm64" + default: "x86_64" + + - bool: + name: FORCE + description: " +If this is unchecked, then nothing is built or pushed if they already exist in chacra. This is the default. + +If this is checked, then the binaries will be built and pushed to chacra even if they already exist in chacra." + + - string: + name: BUILD_VIRTUALENV + description: "Base parent path for virtualenv locations, set to avoid issues with extremely long paths that are incompatible with tools like pip. Defaults to '/tmp/' (note the trailing slash, which is required)." + default: "/tmp/" + + execution-strategy: + combination-filter: DIST==AVAILABLE_DIST && ARCH==AVAILABLE_ARCH && (ARCH=="x86_64" || (ARCH == "arm64" && (DIST == "xenial" || DIST == "centos7"))) + axes: + - axis: + type: label-expression + name: MACHINE_SIZE + values: + - small + - axis: + type: label-expression + name: AVAILABLE_ARCH + values: + - x86_64 + - arm64 + - axis: + type: label-expression + name: AVAILABLE_DIST + values: + - centos6 + - centos7 + - axis: + type: dynamic + name: DIST + values: + - DISTROS + - axis: + type: dynamic + name: ARCH + values: + - ARCHS + + scm: + - git: + url: git@github.com:ceph/cephmetrics.git + # Use the SSH key attached to the ceph-jenkins GitHub account. + credentials-id: '39fa150b-b2a1-416e-b334-29a9a2c0b32d' + branches: + - $BRANCH + skip-tag: true + wipe-workspace: true + + builders: + - shell: | + echo "Cleaning up top-level workarea (shared among workspaces)" + rm -rf dist + rm -rf venv + rm -rf release + # rpm build scripts + - shell: + !include-raw: + - ../../../scripts/build_utils.sh + - ../../build/setup + - ../../build/build_rpm + + wrappers: + - inject-passwords: + global: true + mask-password-params: true -- 2.39.5