/** * Copyright 2014 ArcBees Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ package com.arcbees.staging; import java.io.IOException; import java.util.concurrent.ExecutorService; import java.util.logging.Level; import java.util.logging.Logger; import org.jetbrains.annotations.NotNull; import jetbrains.buildServer.buildTriggers.BuildTriggerDescriptor; import jetbrains.buildServer.serverSide.Branch; import jetbrains.buildServer.serverSide.BuildServerAdapter; import jetbrains.buildServer.serverSide.BuildServerListener; import jetbrains.buildServer.serverSide.SBuildType; import jetbrains.buildServer.serverSide.SRunningBuild; import jetbrains.buildServer.serverSide.executors.ExecutorServices; import jetbrains.buildServer.util.EventDispatcher; import jetbrains.buildServer.util.ExceptionUtil; public class StagingBuildListener { private static final Logger LOGGER = Logger.getLogger(StagingBuildListener.class.getName()); private final TomcatDeployHandler deployHandler; private final ExecutorService executorService; public StagingBuildListener(EventDispatcher<BuildServerListener> listener, ExecutorServices executorServices, TomcatDeployHandler deployHandler) { this.deployHandler = deployHandler; executorService = executorServices.getLowPriorityExecutorService(); listener.addListener(new BuildServerAdapter() { @Override public void buildFinished(@NotNull SRunningBuild build) { onBuildFinished(build); } }); } private void onBuildFinished(final SRunningBuild build) { SBuildType buildType = build.getBuildType(); if (buildType == null) { return; } for (final BuildTriggerDescriptor trigger : buildType.getResolvedSettings().getBuildTriggersCollection()) { if (!trigger.getType().equals(TomcatStagingFeature.NAME)) { continue; } Branch branch = build.getBranch(); if (branch != null) { handleDeploy(build, trigger); } else { LOGGER.severe("Unknown branch name"); } } } private void handleDeploy(final SRunningBuild build, final BuildTriggerDescriptor trigger) { executorService.submit(ExceptionUtil.catchAll("Tomcat7 Deploy", new Runnable() { @Override public void run() { try { deployHandler.handle(build, trigger); } catch (IOException e) { LOGGER.log(Level.SEVERE, "Error getting pull request infos", e); } } })); } }