/* * Copyright 2017 ThoughtWorks, 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.thoughtworks.go.domain.builder.pluggableTask; import java.io.StringBufferInputStream; import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Map; import com.thoughtworks.go.domain.BuildLogElement; import com.thoughtworks.go.work.DefaultGoPublisher; import com.thoughtworks.go.plugin.api.task.Console; import org.junit.Before; import org.junit.Test; import org.mockito.Mock; import static org.mockito.Matchers.anyString; import static org.mockito.Mockito.doNothing; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.times; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; import static org.mockito.MockitoAnnotations.initMocks; public class PluggableTaskConsoleTest { @Mock BuildLogElement buildLogElement; @Mock DefaultGoPublisher publisher; private PluggableTaskConsole console; private List<String> keys = Arrays.asList("Social Net 1", "Social Net 2", "Social Net 3"); private List<String> values = Arrays.asList("Twitter", "Facebook", "Mega Upload"); @Before public void setUp() throws Exception { initMocks(this); console = new PluggableTaskConsole(buildLogElement, publisher); } @Test public void shouldPrintLineToPublisher() throws Exception { String line = "Test Line"; doNothing().when(publisher).consumeLine(line); console.printLine(line); verify(publisher).consumeLine(line); } @Test public void shouldPrintEnvironmentVars() throws Exception { Map<String, String> env = new HashMap<>(); Console.SecureEnvVarSpecifier varSpecifier = mock(Console.SecureEnvVarSpecifier.class); for (int i = 0; i < keys.size(); i++) { env.put(keys.get(i), values.get(i)); when(varSpecifier.isSecure(keys.get(i))).thenReturn(i % 2 == 0); } doNothing().when(publisher).consumeLine("Environment variables: "); for (int i = 0; i < keys.size(); i++) { doNothing().when(publisher).consumeLine( String.format("Name= %s Value= %s", keys.get(i), i % 2 == 0 ? PluggableTaskConsole.MASK_VALUE : values.get(i))); } console.printEnvironment(env, varSpecifier); verify(publisher).consumeLine("Environment variables: "); for (int i = 0; i < keys.size(); i++) { verify(varSpecifier).isSecure(keys.get(i)); verify(publisher).consumeLine(String.format("Name= %s Value= %s", keys.get(i), i % 2 == 0 ? PluggableTaskConsole.MASK_VALUE : values.get(i))); } } @Test public void shouldReadOutputOfAGiveStream() throws Exception { StringBufferInputStream in = new StringBufferInputStream("Lorem ipsum dolor sit amet, consectetur adipisicing elit, \n" + "used do eiusmod tempor incididunt ut labore et dolore magna aliqua.\n " + "Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi \n" + "ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit \n" + "in voluptate velit esse cillum dolore eu fugiat nulla pariatur. \n " + "Excepteur sint occaecat cupidatat non proident, sunt in culpa qui \n" + "officia deserunt mollit anim id est laborum."); doNothing().when(publisher).consumeLine(anyString()); console.readOutputOf(in); Thread.sleep(100);// may become flaky!! Fingers crossed verify(publisher, times(7)).consumeLine(anyString()); } @Test public void shouldReadErrorOfAGiveStream() throws Exception { StringBufferInputStream in = new StringBufferInputStream("Lorem ipsum dolor sit amet, consectetur adipisicing elit, \n" + "used do eiusmod tempor incididunt ut labore et dolore magna aliqua.\n " + "Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi \n" + "ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit \n" + "in voluptate velit esse cillum dolore eu fugiat nulla pariatur. \n " + "Excepteur sint occaecat cupidatat non proident, sunt in culpa qui \n" + "officia deserunt mollit anim id est laborum."); doNothing().when(publisher).consumeLine(anyString()); console.readErrorOf(in); Thread.sleep(100);// may become flaky!! Fingers crossed verify(publisher, times(7)).consumeLine(anyString()); } }