Steps to reproduce:
- Initial state is a Jenkins pipeline job, set to "Pipeline script from SCM", with a Jenkinsfile in the root of a Git repo on master.
- SCM polling set to 5-minute intervals.
- Commits/pushes to master will trigger builds as expected.
- Add a Git Parameter:
- Name: GIT_BRANCH
- Parameter Type: Branch
- Default Value: master (note: can also use origin/master or refs/heads/master)
- Use repository: (same repo as specified for the Jenkinsfile)
- Update the Branch Specifier for the pipeline to ${GIT_BRANCH}
- Wait one polling interval.
- Push a change to master.
-
- In a few attempts, the first push was detected correctly, and the false negative did not occur until the second push.
- In most attempts, the first push was enough to cause the false negative.
When the false negative occurs, the Git Polling Log correctly shows the Last Built Revision, but does not detect the new HEAD revision.
Remediating the issue required the following:
- Remove the Git Parameter
- Set the Branch Spec for the pipeline back to "master"
- Start a build manually–this has the effect of resetting/refreshing the polling data
- Push a change to master–the next poll should detect the change and build normally
Running a manual build with the Git Parameter in place, and choosing origin/master from the list, did NOT reset/refresh the polling data, even though the correct hash was checked out for the build. The false-negative behavior returned on the next poll after another push to master.
I also upgraded the plugin from version 0.8.0 to version 0.9.9 to see if that would resolve the issue; it did not.
I can confirm this (Jenkins 2.164.3, git-parameter-plugin 0.9.10, git-client-plugin 2.7.7, git-plugin 3.10.0, scm-api-plugin 2.4.1). We also use Bitbucket server (v5.14.4).
Is this being looked at? With the current state we cannot use Git SCM polling to trigger nightly builds (@midnight). Changes are simply not detected. I looked at the workspace folder and it did not contain the latest changes (no git pull or similar executed).
Job type is pipeline and we also use the git parameter to specify the branch (default origin/master). As additional behaviors we have Check out to specific local branch with an empty value activated.
Git Polling Log