Uploaded image for project: 'Jenkins'
  1. Jenkins
  2. JENKINS-48295

Cannot load a pipeline shared library from Bitbucket PR with cloudbees-bitbucket-branch-source 2.2.7

    • Icon: Bug Bug
    • Resolution: Fixed
    • Icon: Major Major
    • None
    • Jenkins: 2.46.3
      OS: CentOS 6.8
      Java Version: 8

      Plugins (selected):
      cloudbees-bitbucket-branch-source: 2.2.7
      git: 3.6.4
      git-client: 2.6.0
      branch-api: 2.0.15
      credentials: 2.1.16
      credentials-binding: 1.13

      After upgrading the the cloudbees-bitbucket-branch-source plugin from 2.1.2 to 2.2.7, loading a pipeline shared library from a pull request no longer works

      Before the upgrade, it was possible to access and test code in a PR by appending the following refspec to the global shared library configuration:

      +refs/pull-requests/*/from:refs/remotes/origin/pr/*
      

      (as suggested in this guide to fetching Bitbucket pull requests). Using this refspec would allow a developer's PR to be tested using a syntax such as:

      @Library('pipeline-libs@pr/28')   // '28' is the PR ID
      

      Since updating the plugin to 2.2.7, this approach is no longer possible, so it is not possible to access a developer's shared library changes from Jenkins before merging the PR.

      This is the output from Jenkins:

      Loading library pipeline-libs@pr/28
      Attempting to resolve pr/28 from remote references...
       > git --version # timeout=10
      using GIT_SSH to set credentials Jenkins public key
       > git ls-remote -h -t ssh://git@stash.forgerock.org:7999/re/jenkins-pipeline-libs.git # timeout=10
      Could not find pr/28 in remote references. Pulling heads to local for deep search...
       > git rev-parse --is-inside-work-tree # timeout=10
      Setting origin to ssh://git@stash.forgerock.org:7999/re/jenkins-pipeline-libs.git
       > git config remote.origin.url ssh://git@stash.forgerock.org:7999/re/jenkins-pipeline-libs.git # timeout=10
      Fetching origin...
      Fetching upstream changes from origin
       > git --version # timeout=10
      using GIT_SSH to set credentials Jenkins public key
       > git fetch --tags --progress origin +refs/heads/*:refs/remotes/origin/* +refs/pull-requests/*/from:refs/remotes/origin/pr/*
       > git rev-parse pr/28^{commit} # timeout=10
       > git branch -v --no-abbrev --contains 36750e665cd8155d02b73d339e41ee5cd374599a # timeout=10
      Could not find a branch containing commit 36750e665cd8155d02b73d339e41ee5cd374599a
      ERROR: No version pr/28 found for library pipeline-libs
      [BFA] Scanning build for known causes...
      [BFA] No failure causes found
      [BFA] Done. 0s
      [Bitbucket] Notifying commit build result
      [Bitbucket] Build result notified
      org.codehaus.groovy.control.MultipleCompilationErrorsException: startup failed:
      WorkflowScript: Loading libraries failed
      

      It seems the commit I wish to test (36750e665cd8155d02b73d339e41ee5cd374599a) is correctly identified from the refspec, but no branch exists for this commit (since it is in a PR only) so the job is failing.

      Similar issues exist have been resolved for the GitHub branch source plugin - JENKINS-45953 and JENKINS-45830

          [JENKINS-48295] Cannot load a pipeline shared library from Bitbucket PR with cloudbees-bitbucket-branch-source 2.2.7

          Michael Neale added a comment -

          robin_smith any chance you could try 2.2.3 to see if it is specific to 2.2.7 (as there were quite few intermediate changes)

          Michael Neale added a comment - robin_smith  any chance you could try 2.2.3 to see if it is specific to 2.2.7 (as there were quite few intermediate changes)

          Robin Smith added a comment - - edited

          michaelneale I dug further into this issue and found that I was mistaken; the problem is caused by version 3.6.4 of the Git plugin - captured in JENKINS-48061. Ok to close this issue.

          Robin Smith added a comment - - edited michaelneale I dug further into this issue and found that I was mistaken; the problem is caused by version 3.6.4 of the Git plugin - captured in JENKINS-48061 . Ok to close this issue.

          Michael Neale added a comment -

          thanks for updating the ticket robin_smith - that is great to hear!

          Michael Neale added a comment - thanks for updating the ticket robin_smith - that is great to hear!

          Taras Kostyuk added a comment - - edited

          [3.9.1 and 3.10.0 are affected by the issue.

          [Pipeline] Start of Pipeline
          [Pipeline] timestamps
          [Pipeline] {
          [Pipeline] library
          04:21:04  Loading library pipeline-demo@refs/changes/06/24906/2
          04:21:04  Attempting to resolve refs/changes/06/24906/2 from remote references...
          04:21:04   > git --version # timeout=10
          04:21:04  using GIT_SSH to set credentials 
          04:21:04   > git ls-remote -h ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo # timeout=10
          04:21:04  Could not find refs/changes/06/24906/2 in remote references. Pulling heads to local for deep search...
          04:21:04   > git rev-parse --is-inside-work-tree # timeout=10
          04:21:04  Setting origin to ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo
          04:21:04   > git config remote.origin.url ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo # timeout=10
          04:21:04  Fetching origin...
          04:21:04  Fetching upstream changes from origin
          04:21:04   > git --version # timeout=10
          04:21:04   > git config --get remote.origin.url # timeout=10
          04:21:04  using GIT_SSH to set credentials 
          04:21:04   > git fetch --tags --progress origin +refs/heads/*:refs/remotes/origin/* +refs/changes/*:refs/changes/* # timeout=10
          04:21:04   > git rev-parse refs/changes/06/24906/2^{commit} # timeout=10
          04:21:04   > git branch -a -v --no-abbrev --contains 3e06cc6f676b664ec907cf926bed44e37710f133 # timeout=10
          04:21:04  Could not find a branch containing commit 3e06cc6f676b664ec907cf926bed44e37710f133 

           |

          Taras Kostyuk added a comment - - edited [3.9.1 and 3.10.0 are affected by the issue. [Pipeline] Start of Pipeline [Pipeline] timestamps [Pipeline] { [Pipeline] library 04:21:04 Loading library pipeline-demo@refs/changes/06/24906/2 04:21:04 Attempting to resolve refs/changes/06/24906/2 from remote references... 04:21:04 > git --version # timeout=10 04:21:04 using GIT_SSH to set credentials 04:21:04 > git ls-remote -h ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo # timeout=10 04:21:04 Could not find refs/changes/06/24906/2 in remote references. Pulling heads to local for deep search... 04:21:04 > git rev-parse --is-inside-work-tree # timeout=10 04:21:04 Setting origin to ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo 04:21:04 > git config remote.origin.url ssh://jenkinsvs@review.unifieddeliverynetwork.net:29418/pipeline-demo # timeout=10 04:21:04 Fetching origin... 04:21:04 Fetching upstream changes from origin 04:21:04 > git --version # timeout=10 04:21:04 > git config --get remote.origin.url # timeout=10 04:21:04 using GIT_SSH to set credentials 04:21:04 > git fetch --tags --progress origin +refs/heads/*:refs/remotes/origin/* +refs/changes/*:refs/changes/* # timeout=10 04:21:04 > git rev-parse refs/changes/06/24906/2^{commit} # timeout=10 04:21:04 > git branch -a -v --no-abbrev --contains 3e06cc6f676b664ec907cf926bed44e37710f133 # timeout=10 04:21:04 Could not find a branch containing commit 3e06cc6f676b664ec907cf926bed44e37710f133  |

          Taras Kostyuk added a comment -

          The following configuration in Mange Jenkins ->Configure system fixed the issue

          Taras Kostyuk added a comment - The following configuration in Mange Jenkins ->Configure system fixed the issue

          Taras Kostyuk added a comment -

          the shared library was't properly configured

          Taras Kostyuk added a comment - the shared library was't properly configured

            Unassigned Unassigned
            robin_smith Robin Smith
            Votes:
            1 Vote for this issue
            Watchers:
            4 Start watching this issue

              Created:
              Updated:
              Resolved: