re-implement hide of nuget api key in build logs, add more tests for it
[teamcity/dotNetPackagesSupport.git] / nuget-tests / src / jetbrains / buildServer / nuget / tests / agent / NuGetPackActionFactoryTest.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.tests.agent;\r
18 \r
19 import jetbrains.buildServer.BaseTestCase;\r
20 import jetbrains.buildServer.RunBuildException;\r
21 import jetbrains.buildServer.agent.AgentRunningBuild;\r
22 import jetbrains.buildServer.agent.BuildParametersMap;\r
23 import jetbrains.buildServer.agent.BuildRunnerContext;\r
24 import jetbrains.buildServer.nuget.agent.commands.impl.CommandFactoryImpl;\r
25 import jetbrains.buildServer.nuget.agent.commands.impl.NuGetActionFactoryImpl;\r
26 import jetbrains.buildServer.nuget.agent.dependencies.PackageUsages;\r
27 import jetbrains.buildServer.nuget.agent.parameters.NuGetPackParameters;\r
28 import jetbrains.buildServer.nuget.agent.util.CommandlineBuildProcessFactory;\r
29 import org.jmock.Expectations;\r
30 import org.jmock.Mockery;\r
31 import org.testng.annotations.BeforeMethod;\r
32 import org.testng.annotations.Test;\r
33 \r
34 import java.io.File;\r
35 import java.util.ArrayList;\r
36 import java.util.Arrays;\r
37 import java.util.Collection;\r
38 import java.util.Collections;\r
39 \r
40 /**\r
41  * @author Eugene Petrenko (eugene.petrenko@gmail.com)\r
42  *         Date: 23.08.11 16:23\r
43  */\r
44 public class NuGetPackActionFactoryTest extends BaseTestCase {\r
45   private Mockery m;\r
46   private CommandlineBuildProcessFactory myProcessFactory;\r
47   private NuGetActionFactoryImpl i;\r
48   private BuildRunnerContext ctx;\r
49   private AgentRunningBuild build;\r
50   private NuGetPackParameters myPackParameters;\r
51   private File myFile;\r
52   private File myNuGet;\r
53   private File myRoot;\r
54   private File myOut;\r
55   private File myWorkingDir;\r
56   private Collection<String> myExcludes;\r
57   private Collection<String> myProperties;\r
58   private Collection<String> myExtra;\r
59   private String cmd;\r
60   private BuildParametersMap myBuildParametersMap;\r
61 \r
62 \r
63 \r
64   @BeforeMethod\r
65   @Override\r
66   protected void setUp() throws Exception {\r
67     super.setUp();\r
68     m = new Mockery();\r
69     myProcessFactory = m.mock(CommandlineBuildProcessFactory.class);\r
70     PackageUsages pu = m.mock(PackageUsages.class);\r
71     i = new NuGetActionFactoryImpl(myProcessFactory, pu, new CommandFactoryImpl());\r
72     ctx = m.mock(BuildRunnerContext.class);\r
73     myPackParameters = m.mock(NuGetPackParameters.class);\r
74     build = m.mock(AgentRunningBuild.class);\r
75 \r
76     myFile = createTempFile();\r
77     myNuGet = createTempFile();\r
78     myRoot = createTempDir();\r
79     myOut = createTempDir();\r
80     myWorkingDir = createTempDir();\r
81 \r
82     myExcludes = new ArrayList<String>();\r
83     myProperties = new ArrayList<String>();\r
84     myExtra = new ArrayList<String>();\r
85     myBuildParametersMap = m.mock(BuildParametersMap.class);\r
86     cmd = System.getenv("ComSpec");\r
87 \r
88     m.checking(new Expectations(){{\r
89       allowing(ctx).getBuildParameters(); will(returnValue(myBuildParametersMap));\r
90       allowing(myBuildParametersMap).getEnvironmentVariables(); will(returnValue(Collections.singletonMap("ComSpec", cmd)));\r
91 \r
92 \r
93       allowing(ctx).getBuild(); will(returnValue(build));\r
94       allowing(build).getCheckoutDirectory(); will(returnValue(myWorkingDir));\r
95       allowing(myPackParameters).getSpecFile(); will(returnValue(myFile));\r
96       allowing(myPackParameters).getNuGetExeFile(); will(returnValue(myNuGet));\r
97       allowing(myPackParameters).getBaseDirectory(); will(returnValue(myRoot));\r
98       allowing(myPackParameters).getOutputDirectory(); will(returnValue(myOut));\r
99       allowing(myPackParameters).getVersion(); will(returnValue("45.239.32.12"));\r
100 \r
101       allowing(myPackParameters).getCustomCommandline(); will(returnValue(myExtra));\r
102       allowing(myPackParameters).getProperties(); will(returnValue(myProperties));\r
103       allowing(myPackParameters).getExclude(); will(returnValue(myExcludes));\r
104     }});\r
105   }\r
106 \r
107 \r
108   @Test\r
109   public void test_package() throws RunBuildException {\r
110     m.checking(new Expectations(){{\r
111       allowing(myPackParameters).packTool(); will(returnValue(false));\r
112       allowing(myPackParameters).packSymbols(); will(returnValue(false));\r
113 \r
114       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
115               Arrays.asList(\r
116                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12")\r
117               , myWorkingDir,\r
118               Collections.<String, String>emptyMap());\r
119     }});\r
120 \r
121     i.createPack(ctx, myPackParameters);\r
122     m.assertIsSatisfied();\r
123   }\r
124 \r
125   @Test\r
126   public void test_properties() throws RunBuildException {\r
127     myProperties.add("p1=p2");\r
128     myProperties.add("p3=p24");\r
129     m.checking(new Expectations(){{\r
130       allowing(myPackParameters).packTool(); will(returnValue(false));\r
131       allowing(myPackParameters).packSymbols(); will(returnValue(false));\r
132 \r
133       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
134               Arrays.asList(\r
135                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12", "-Properties", "p1=p2", "-Properties", "p3=p24")\r
136               , myWorkingDir,\r
137               Collections.<String, String>emptyMap());\r
138     }});\r
139 \r
140     i.createPack(ctx, myPackParameters);\r
141     m.assertIsSatisfied();\r
142   }\r
143 \r
144   @Test\r
145   public void test_custom_commandline() throws RunBuildException {\r
146     myExtra.add("arg1");\r
147     myExtra.add("arg2");\r
148     m.checking(new Expectations() {{\r
149       allowing(myPackParameters).packTool();\r
150       will(returnValue(false));\r
151       allowing(myPackParameters).packSymbols();\r
152       will(returnValue(false));\r
153 \r
154       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
155               Arrays.asList(\r
156                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12", "arg1", "arg2")\r
157               , myWorkingDir,\r
158               Collections.<String, String>emptyMap());\r
159     }});\r
160 \r
161     i.createPack(ctx, myPackParameters);\r
162     m.assertIsSatisfied();\r
163   }\r
164 \r
165   @Test\r
166   public void test_excludes() throws RunBuildException {\r
167     myExcludes.add("aaa");\r
168     myExcludes.add("d/v/de");\r
169     m.checking(new Expectations(){{\r
170       allowing(myPackParameters).packTool(); will(returnValue(false));\r
171       allowing(myPackParameters).packSymbols(); will(returnValue(false));\r
172 \r
173       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
174               Arrays.asList(\r
175                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12", "-Exclude", "aaa", "-Exclude", "d/v/de")\r
176               , myWorkingDir,\r
177               Collections.<String, String>emptyMap());\r
178     }});\r
179 \r
180     i.createPack(ctx, myPackParameters);\r
181     m.assertIsSatisfied();\r
182   }\r
183 \r
184   @Test\r
185   public void test_package_tool() throws RunBuildException {\r
186     m.checking(new Expectations(){{\r
187       allowing(myPackParameters).packTool(); will(returnValue(true));\r
188       allowing(myPackParameters).packSymbols(); will(returnValue(false));\r
189 \r
190       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
191               Arrays.asList(\r
192                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12", "-Tool")\r
193               , myWorkingDir,\r
194               Collections.<String, String>emptyMap());\r
195     }});\r
196 \r
197     i.createPack(ctx, myPackParameters);\r
198     m.assertIsSatisfied();\r
199   }\r
200 \r
201   @Test\r
202   public void test_package_symbols() throws RunBuildException {\r
203     m.checking(new Expectations(){{\r
204       allowing(myPackParameters).packTool(); will(returnValue(false));\r
205       allowing(myPackParameters).packSymbols(); will(returnValue(true));\r
206 \r
207       oneOf(myProcessFactory).executeCommandLine(ctx, cmd,\r
208               Arrays.asList(\r
209                       "/c", myNuGet.getPath(), "pack", myFile.getPath(), "-OutputDirectory", myOut.getPath(), "-BasePath", myRoot.getPath(), "-Verbose", "-Version", "45.239.32.12", "-Symbols")\r
210               , myWorkingDir,\r
211               Collections.<String, String>emptyMap());\r
212     }});\r
213 \r
214     i.createPack(ctx, myPackParameters);\r
215     m.assertIsSatisfied();\r
216   }\r
217 \r
218 }\r