add tests to ListPackagesCommand
[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 jetbrains.buildServer.plugins.bean.PluginInfo;\r
24 import org.jetbrains.annotations.NotNull;\r
25 \r
26 import java.io.File;\r
27 import java.util.List;\r
28 \r
29 /**\r
30  * Created by Eugene Petrenko (eugene.petrenko@gmail.com)\r
31  * Date: 14.07.11 12:48\r
32  */\r
33 public class NuGetExecutorImpl implements NuGetExecutor {\r
34   private static final Logger LOG = Logger.getInstance(NuGetExecutorImpl.class.getName());\r
35 \r
36   private final PluginInfo myPluginInfo;\r
37 \r
38   public NuGetExecutorImpl(PluginInfo pluginInfo) {\r
39     myPluginInfo = pluginInfo;\r
40   }\r
41 \r
42   @NotNull\r
43   private File getNuGetRunnerPath() {\r
44     return new File(myPluginInfo.getPluginRoot(), "bin/JetBrains.TeamCity.NuGetRunner.exe");\r
45   }\r
46 \r
47   @NotNull\r
48   public <T> T executeNuGet(@NotNull final List<String> arguments,\r
49                             @NotNull final NuGetOutputProcessor<T> listener) {\r
50 \r
51     GeneralCommandLine cmd = new GeneralCommandLine();\r
52     cmd.setExePath(getNuGetRunnerPath().getPath());\r
53     cmd.addParameters(arguments);\r
54 \r
55     if (LOG.isDebugEnabled()) {\r
56       LOG.debug("Starting: " + cmd.getCommandLineString());\r
57     }\r
58 \r
59     final ExecResult result = SimpleCommandLineProcessRunner.runCommand(cmd, new byte[0]);\r
60 \r
61     if (LOG.isDebugEnabled()) {\r
62       LOG.debug("Exited with code: " + result.getExitCode());\r
63       LOG.debug("Output: " + result.getStdout());\r
64       LOG.error("Error: " + result.getStderr());\r
65     }\r
66 \r
67     listener.onStdOutput(result.getStdout());\r
68     listener.onStdError(result.getStderr());\r
69     listener.onFinished(result.getExitCode());\r
70 \r
71     return listener.getResult();\r
72   }\r
73 }\r