add integration test for NuGet executor on server
[teamcity/dotNetPackagesSupport.git] / nuget-server / src / jetbrains / buildServer / nuget / server / exec / NuGetExecutorImpl.java
1 /*\r
2  * Copyright 2000-2011 JetBrains s.r.o.\r
3  *\r
4  * Licensed under the Apache License, Version 2.0 (the "License");\r
5  * you may not use this file except in compliance with the License.\r
6  * You may obtain a copy of the License at\r
7  *\r
8  * http://www.apache.org/licenses/LICENSE-2.0\r
9  *\r
10  * Unless required by applicable law or agreed to in writing, software\r
11  * distributed under the License is distributed on an "AS IS" BASIS,\r
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
13  * See the License for the specific language governing permissions and\r
14  * limitations under the License.\r
15  */\r
16 \r
17 package jetbrains.buildServer.nuget.server.exec;\r
18 \r
19 import com.intellij.execution.configurations.GeneralCommandLine;\r
20 import com.intellij.openapi.diagnostic.Logger;\r
21 import jetbrains.buildServer.ExecResult;\r
22 import jetbrains.buildServer.SimpleCommandLineProcessRunner;\r
23 import org.jetbrains.annotations.NotNull;\r
24 \r
25 import java.io.File;\r
26 import java.util.List;\r
27 \r
28 /**\r
29  * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
30  * Date: 14.07.11 12:48\r
31  */\r
32 public class NuGetExecutorImpl implements NuGetExecutor {\r
33   private static final Logger LOG = Logger.getInstance(NuGetExecutorImpl.class.getName());\r
34 \r
35   private final NuGetTeamCityProvider myNuGetTeamCityProvider;\r
36 \r
37   public NuGetExecutorImpl(@NotNull final NuGetTeamCityProvider nuGetTeamCityProvider) {\r
38     myNuGetTeamCityProvider = nuGetTeamCityProvider;\r
39   }\r
40 \r
41   @NotNull\r
42   public <T> T executeNuGet(@NotNull final File nugetExePath,\r
43                             @NotNull final List<String> arguments,\r
44                             @NotNull final NuGetOutputProcessor<T> listener) {\r
45 \r
46     GeneralCommandLine cmd = new GeneralCommandLine();\r
47     cmd.setExePath(myNuGetTeamCityProvider.getNuGetRunnerPath().getPath());\r
48     cmd.addParameter(nugetExePath.getPath());\r
49     cmd.addParameters(arguments);\r
50 \r
51     if (LOG.isDebugEnabled()) {\r
52       LOG.debug("Starting: " + cmd.getCommandLineString());\r
53     }\r
54 \r
55     final ExecResult result = SimpleCommandLineProcessRunner.runCommand(cmd, new byte[0]);\r
56 \r
57     if (LOG.isDebugEnabled()) {\r
58       LOG.debug("Exited with code: " + result.getExitCode());\r
59       LOG.debug("Output: " + result.getStdout());\r
60       LOG.error("Error: " + result.getStderr());\r
61     }\r
62 \r
63     listener.onStdOutput(result.getStdout());\r
64     listener.onStdError(result.getStderr());\r
65     listener.onFinished(result.getExitCode());\r
66 \r
67     return listener.getResult();\r
68   }\r
69 }\r