Return-Path: X-Original-To: archive-asf-public-internal@cust-asf2.ponee.io Delivered-To: archive-asf-public-internal@cust-asf2.ponee.io Received: from cust-asf.ponee.io (cust-asf.ponee.io [163.172.22.183]) by cust-asf2.ponee.io (Postfix) with ESMTP id A3913200CBD for ; Thu, 6 Jul 2017 21:37:18 +0200 (CEST) Received: by cust-asf.ponee.io (Postfix) id A076D167409; Thu, 6 Jul 2017 19:37:18 +0000 (UTC) Delivered-To: archive-asf-public@cust-asf.ponee.io Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by cust-asf.ponee.io (Postfix) with SMTP id BFDE8167407 for ; Thu, 6 Jul 2017 21:37:17 +0200 (CEST) Received: (qmail 69566 invoked by uid 500); 6 Jul 2017 19:37:16 -0000 Mailing-List: contact commits-help@hbase.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@hbase.apache.org Delivered-To: mailing list commits@hbase.apache.org Received: (qmail 69547 invoked by uid 99); 6 Jul 2017 19:37:16 -0000 Received: from git1-us-west.apache.org (HELO git1-us-west.apache.org) (140.211.11.23) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 06 Jul 2017 19:37:16 +0000 Received: by git1-us-west.apache.org (ASF Mail Server at git1-us-west.apache.org, from userid 33) id 4F008E1863; Thu, 6 Jul 2017 19:37:16 +0000 (UTC) Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: busbey@apache.org To: commits@hbase.apache.org Message-Id: <67c70b1327234e9f9bc4dd833fd70954@git.apache.org> X-Mailer: ASF-Git Admin Mailer Subject: hbase git commit: HBASE-18147 POC jenkinsfile for nightly checks. [Forced Update!] Date: Thu, 6 Jul 2017 19:37:16 +0000 (UTC) archived-at: Thu, 06 Jul 2017 19:37:18 -0000 Repository: hbase Updated Branches: refs/heads/HBASE-18147 deb725964 -> f27687a5f (forced update) HBASE-18147 POC jenkinsfile for nightly checks. * adds ruby tools to dockerfile * adds rubocop to dockerfile * adds ruby-lint to dockerfile * adds perlcritic to dockerfile * TODO branch with mulitple jdk versions * TODO verify flaky list is in use Project: http://git-wip-us.apache.org/repos/asf/hbase/repo Commit: http://git-wip-us.apache.org/repos/asf/hbase/commit/f27687a5 Tree: http://git-wip-us.apache.org/repos/asf/hbase/tree/f27687a5 Diff: http://git-wip-us.apache.org/repos/asf/hbase/diff/f27687a5 Branch: refs/heads/HBASE-18147 Commit: f27687a5f970005dbe7f941b1088ba1530a5d4a9 Parents: df93c13 Author: Sean Busbey Authored: Tue Jul 4 15:12:38 2017 -0400 Committer: Sean Busbey Committed: Thu Jul 6 15:36:44 2017 -0400 ---------------------------------------------------------------------- dev-support/Jenkinsfile | 142 +++++++++++++++++++++++++++++++++++++ dev-support/docker/Dockerfile | 19 +++++ 2 files changed, 161 insertions(+) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/hbase/blob/f27687a5/dev-support/Jenkinsfile ---------------------------------------------------------------------- diff --git a/dev-support/Jenkinsfile b/dev-support/Jenkinsfile new file mode 100644 index 0000000..64822aa --- /dev/null +++ b/dev-support/Jenkinsfile @@ -0,0 +1,142 @@ +pipeline { + agent { + node { + label 'Hadoop' + } + } + // work around for YETUS-508, requires maven outside of the dockerfile + tools { + maven 'Maven (latest)' + } + triggers { + cron('@daily') + } + options { + timeout (time: 6, unit: 'HOURS') + timestamps() + } + environment { + TOOLS = "${env.WORKSPACE}/tools" + BASEDIR = "${env.WORKSPACE}/component" + YETUS_RELEASE = '0.4.0' + } + parameters { + booleanParam(name: 'USE_YETUS_PRERELEASE', defaultValue: false, description: '''Check to use the current HEAD of apache/yetus rather than our configured release. + + Should only be used manually when e.g. there is some non-work-aroundable issue in yetus we are checking a fix for.''') + } + stages { + stage ('yetus check') { + environment { + OUTPUTDIR = "${env.WORKSPACE}/artifacts" + PROJECT = 'hbase' + PROJET_PERSONALITY = 'https://raw.githubusercontent.com/apache/hbase/master/dev-support/hbase-personality.sh' + AUTHOR_IGNORE_LIST = 'src/main/asciidoc/_chapters/developer.adoc' + WHITESPACE_IGNORE_LIST = '.*/generated/.*' + TESTS_FILTER = 'cc,checkstyle,javac,javadoc,pylint,shellcheck,whitespace,perlcritic,ruby-lint,rubocop' + BRANCH_SPECIFIC_DOCKERFILE = "${env.BASEDIR}/dev-support/docker/Dockerfile" + } + steps { + // TODO we can move the yetus install into a different stage and then use stash to deploy it. + sh '''#!/usr/bin/env bash +printenv +echo "Ensure we have a copy of Apache Yetus." +if [[ true != "${USE_YETUS_PRERELEASE}" ]]; then + YETUS_DIR="${WORKSPACE}/yetus-${YETUS_RELEASE}" + echo "Checking for Yetus ${YETUS_RELEASE} in '${YETUS_DIR}'" + if [ ! -d "${YETUS_DIR}" ]; then + echo "New download of Apache Yetus version ${YETUS_RELEASE}." + rm -rf "${WORKSPACE}/.gpg" + mkdir -p "${WORKSPACE}/.gpg" + chmod -R 700 "${WORKSPACE}/.gpg" + + echo "install yetus project KEYS" + curl -L --fail -o "${WORKSPACE}/KEYS_YETUS" https://dist.apache.org/repos/dist/release/yetus/KEYS + gpg --homedir "${WORKSPACE}/.gpg" --import "${WORKSPACE}/KEYS_YETUS" + + echo "download yetus release ${YETUS_RELEASE}" + curl -L --fail -O "https://dist.apache.org/repos/dist/release/yetus/${YETUS_RELEASE}/yetus-${YETUS_RELEASE}-bin.tar.gz" + curl -L --fail -O "https://dist.apache.org/repos/dist/release/yetus/${YETUS_RELEASE}/yetus-${YETUS_RELEASE}-bin.tar.gz.asc" + echo "verifying yetus release" + gpg --homedir "${WORKSPACE}/.gpg" --verify "yetus-${YETUS_RELEASE}-bin.tar.gz.asc" + mv "yetus-${YETUS_RELEASE}-bin.tar.gz" yetus.tar.gz + else + echo "Reusing cached download of Apache Yetus version ${YETUS_RELEASE}." + fi +else + YETUS_DIR="${WORKSPACE}/yetus-git" + rm -rf "${YETUS_DIR}" + echo "downloading from github" + curl -L --fail https://api.github.com/repos/apache/yetus/tarball/HEAD -o yetus.tar.gz +fi +if [ ! -d "${YETUS_DIR}" ]; then + echo "unpacking yetus into '${YETUS_DIR}'" + mkdir -p "${YETUS_DIR}" + gunzip -c yetus.tar.gz | tar xpf - -C "${YETUS_DIR}" --strip-components 1 +fi + ''' + // TODO we can move the personality install into a different stage and then use stash to deploy it. + dir ("${env.TOOLS}") { + sh """#!/usr/bin/env bash +echo "Downloading Project personality." +curl -L -o personality.sh "${env.PROJET_PERSONALITY}" + """ + } + sh '''#!/usr/bin/env bash +YETUS_ARGS=() +YETUS_ARGS=("--personality=${TOOLS}/personality.sh" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--basedir=${BASEDIR}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--console-urls" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--docker" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--dockerfile=${BRANCH_SPECIFIC_DOCKERFILE}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--empty-patch" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--html-report-file=${OUTPUTDIR}/console-report.html" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--jenkins" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--mvn-custom-repos" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--patch-dir=${OUTPUTDIR}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--project=${PROJECT}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--resetrepo" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--author-ignore-list=${AUTHOR_IGNORE_LIST}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--whitespace-eol-ignore-list=${WHITESPACE_IGNORE_LIST}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--whitespace-tabs-ignore-list=${WHITESPACE_IGNORE_LIST}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--sentinel" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--branch=${BRANCH_NAME}" "${YETUS_ARGS[@]}") +YETUS_ARGS=("--tests-filter=${TESTS_FILTER}" "${YETUS_ARGS[@]}") + +rm -rf "${OUTPUTDIR}" +mkdir -p "${OUTPUTDIR}" +if [[ true != "${USE_YETUS_PRERELEASE}" ]]; then + YETUS_ARGS=("--shelldocs=${WORKSPACE}/yetus-${YETUS_RELEASE}/bin/shelldocs" "${YETUS_ARGS[@]}") + TESTPATCHBIN="${WORKSPACE}/yetus-${YETUS_RELEASE}/bin/test-patch" +else + YETUS_ARGS=("--shelldocs=${WORKSPACE}/yetus-git/shelldocs/shelldocs.py" "${YETUS_ARGS[@]}") + TESTPATCHBIN="${WORKSPACE}/yetus-git/precommit/test-patch.sh" +fi +echo "Launching yetus with command line:" +echo "${TESTPATCHBIN} ${YETUS_ARGS[@]}" + +/usr/bin/env bash "${TESTPATCHBIN}" "${YETUS_ARGS[@]}" + ''' + } + } + } + post { + always { + archive "${env.OUTPUTDIR}" + archive "${env.YETUS_DIR}/VERSION" + // Need HTML Publisher plugin. :/ +// publishHTML target: [ +// allowMissing: true, +// keepAll: true, +// alwaysLinkToLastBuild: true, +// reportDir: "${env.OUTPUTDIR}", +// reportFiles: 'console-report.html', +// reportName: 'Nightly Build Report' +// ] + } + failure { + deleteDir() + } + } +} + http://git-wip-us.apache.org/repos/asf/hbase/blob/f27687a5/dev-support/docker/Dockerfile ---------------------------------------------------------------------- diff --git a/dev-support/docker/Dockerfile b/dev-support/docker/Dockerfile index 2ecc42e..97a9d82 100644 --- a/dev-support/docker/Dockerfile +++ b/dev-support/docker/Dockerfile @@ -47,6 +47,7 @@ RUN apt-get -q update && apt-get -q install --no-install-recommends -y \ libbz2-dev \ libcurl4-openssl-dev \ libfuse-dev \ + libperl-critic-perl \ libprotobuf-dev \ libprotoc-dev \ libsnappy-dev \ @@ -60,6 +61,8 @@ RUN apt-get -q update && apt-get -q install --no-install-recommends -y \ python2.7 \ python-pip \ rsync \ + ruby \ + ruby-dev \ snappy \ zlib1g-dev @@ -126,6 +129,22 @@ RUN pip install pylint #### RUN pip install python-dateutil +#### +# Disable misc ruby bits +### +RUN echo 'gem: --no-rdoc --no-ri' >> /root/.gemrc + +#### +# Install rubocop +### +RUN gem install rake +RUN gem install rubocop + +#### +# Install ruby-lint +### +RUN gem install ruby-lint + ### # Avoid out of memory errors in builds ###