Skip to content

Commit

Permalink
Problem: [JENKINS-60901] GitHub manages hooks even when it has not be…
Browse files Browse the repository at this point in the history
…en configured to do it (and complains a lot in the log)

Solution: Check if configured to manage hooks before trying to
register or unregister them (which in case of no credential set
up, results in a meaningful exception message plus a lengthy
but somewhat useless stacktrace). If nothing else, this reduces
I/O and storage overhead due to hook not configured and disabled.

Signed-off-by: Jim Klimov <jimklimov@gmail.com>
  • Loading branch information
jimklimov committed Feb 28, 2020
1 parent 51dc96b commit a67d291
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,11 @@ public void run() {
*/
public void unregisterFor(GitHubRepositoryName name, List<GitHubRepositoryName> aliveRepos) {
try {
if (!(name.resolve(allowedToManageHooks()).iterator().hasNext())) {
LOGGER.debug("Skipped adding GitHub webhook for {} because not configured to Manage Hooks", name);
return;
}

GHRepository repo = checkNotNull(
from(name.resolve(allowedToManageHooks())).firstMatch(withAdminAccess()).orNull(),
"There are no credentials with admin access to manage hooks on %s", name
Expand Down Expand Up @@ -176,6 +181,12 @@ protected Function<GitHubRepositoryName, GHHook> createHookSubscribedTo(final Li
@Override
protected GHHook applyNullSafe(@Nonnull GitHubRepositoryName name) {
try {
if (!(name.resolve(allowedToManageHooks()).iterator().hasNext())) {
LOGGER.debug("Skipped adding GitHub webhook for {} because not configured to Manage Hooks",
name);
return null;
}

GHRepository repo = checkNotNull(
from(name.resolve(allowedToManageHooks())).firstMatch(withAdminAccess()).orNull(),
"There are no credentials with admin access to manage hooks on %s", name
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import hudson.model.FreeStyleProject;
import hudson.model.Item;
import hudson.plugins.git.GitSCM;
import org.jenkinsci.plugins.github.config.GitHubServerConfig;
import org.jenkinsci.plugins.github.extension.GHSubscriberEvent;
import org.jenkinsci.plugins.github.extension.GHEventsSubscriber;
import org.jenkinsci.plugins.github.webhook.WebhookManager;
Expand Down Expand Up @@ -149,6 +150,9 @@ public void shouldReportAboutHookProblemOnRegister() throws IOException {
job.addTrigger(new GitHubPushTrigger());
job.setScm(REPO_GIT_SCM);

GitHubServerConfig conf = new GitHubServerConfig(WebhookManagerTest.HOOK_ENDPOINT.toString());
conf.setManageHooks(true);

WebhookManager.forHookUrl(WebhookManagerTest.HOOK_ENDPOINT)
.registerFor((Item) job).run();

Expand All @@ -157,6 +161,9 @@ public void shouldReportAboutHookProblemOnRegister() throws IOException {

@Test
public void shouldReportAboutHookProblemOnUnregister() {
GitHubServerConfig conf = new GitHubServerConfig(WebhookManagerTest.HOOK_ENDPOINT.toString());
conf.setManageHooks(true);

WebhookManager.forHookUrl(WebhookManagerTest.HOOK_ENDPOINT)
.unregisterFor(REPO, Collections.<GitHubRepositoryName>emptyList());

Expand Down

0 comments on commit a67d291

Please sign in to comment.