/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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 org.apache.ivy.util; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import junit.framework.AssertionFailedError; public class MockMessageLogger extends AbstractMessageLogger { private List _endProgress = new ArrayList(); private List _logs = new ArrayList(); private List _rawLogs = new ArrayList(); private int _progressCalls; public void doEndProgress(String msg) { _endProgress.add(msg); } public void log(String msg, int level) { _logs.add(level + " " + msg); } public void doProgress() { _progressCalls++; } public void rawlog(String msg, int level) { _rawLogs.add(level + " " + msg); } public List getEndProgress() { return _endProgress; } public List getLogs() { return _logs; } public int getProgressCalls() { return _progressCalls; } public List getRawLogs() { return _rawLogs; } public void clear() { _logs.clear(); _rawLogs.clear(); _endProgress.clear(); _progressCalls = 0; } public void assertLogContains(String message) { for (Iterator iter = _logs.iterator(); iter.hasNext();) { String log = (String) iter.next(); if (log.indexOf(message) != -1) { return; } } throw new AssertionFailedError("logs do not contain expected message: expected='" + message + "' logs='\n" + join(_logs) + "'"); } public void assertLogDoesntContain(String message) { for (Iterator iter = _logs.iterator(); iter.hasNext();) { String log = (String) iter.next(); if (log.indexOf(message) != -1) { throw new AssertionFailedError("logs contain unexpected message: '" + message + "' logs='\n" + join(_logs) + "'"); } } } public void assertLogVerboseContains(String message) { assertLogContains(Message.MSG_VERBOSE + " " + message); } public void assertLogInfoContains(String message) { assertLogContains(Message.MSG_INFO + " " + message); } public void assertLogWarningContains(String message) { Message.sumupProblems(); assertLogContains(Message.MSG_WARN + " \t" + message); } public void assertLogErrorContains(String message) { Message.sumupProblems(); assertLogContains(Message.MSG_ERR + " " + message); } private String join(List logs) { StringBuffer sb = new StringBuffer(); for (Iterator iter = logs.iterator(); iter.hasNext();) { String log = (String) iter.next(); sb.append(log).append("\n"); } return sb.toString(); } }