| /******************************************************************************* |
| * Copyright (c) 2000, 2015 IBM Corporation and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License v1.0 |
| * which accompanies this distribution, and is available at |
| * http://www.eclipse.org/legal/epl-v10.html |
| * |
| * Contributors: |
| * IBM Corporation - initial API and implementation |
| *******************************************************************************/ |
| package org.eclipse.jdt.debug.tests.console; |
| |
| import org.eclipse.jdt.debug.tests.AbstractDebugTest; |
| import org.eclipse.ui.console.ConsolePlugin; |
| import org.eclipse.ui.console.IConsole; |
| import org.eclipse.ui.console.IConsoleManager; |
| import org.eclipse.ui.console.IPatternMatchListener; |
| import org.eclipse.ui.console.MessageConsole; |
| import org.eclipse.ui.console.MessageConsoleStream; |
| import org.eclipse.ui.console.PatternMatchEvent; |
| import org.eclipse.ui.console.TextConsole; |
| |
| /** |
| * IOConsoleTests for the Automated suite |
| */ |
| public class IOConsoleTests extends AbstractDebugTest implements IPatternMatchListener { |
| |
| private int fMatchCount; |
| private boolean fDisconnected = false; |
| |
| /** |
| * Constructor |
| * @param name |
| */ |
| public IOConsoleTests(String name) { |
| super(name); |
| } |
| |
| /** |
| * Tests that the pattern matcher will find a specific pattern |
| * @throws Exception |
| */ |
| public void testPatternMatchListener() throws Exception { |
| MessageConsole console = new MessageConsole("Test console", null); |
| fMatchCount = 0; |
| console.addPatternMatchListener(this); |
| IConsoleManager consoleManager = ConsolePlugin.getDefault().getConsoleManager(); |
| consoleManager.addConsoles(new IConsole[]{console}); |
| try { |
| MessageConsoleStream stream = console.newMessageStream(); |
| stream.print("one foo bar"); |
| stream.println(); |
| stream.print("two foo bar"); |
| |
| long endTime = System.currentTimeMillis() + 1500; |
| while (!fDisconnected && System.currentTimeMillis() < endTime) { |
| synchronized(this) { |
| wait(500); |
| } |
| } |
| |
| assertEquals("Should be two foo's", 2, fMatchCount); |
| } finally { |
| consoleManager.removeConsoles(new IConsole[]{console}); |
| } |
| } |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListener#getPattern() |
| */ |
| @Override |
| public String getPattern() { |
| return "foo"; |
| } |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListener#getLineQualifier() |
| */ |
| @Override |
| public String getLineQualifier() { |
| return "foo"; |
| } |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListenerDelegate#matchFound(org.eclipse.ui.console.PatternMatchEvent) |
| */ |
| @Override |
| public synchronized void matchFound(PatternMatchEvent event) { |
| fMatchCount++; |
| } |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListener#getCompilerFlags() |
| */ |
| @Override |
| public int getCompilerFlags() { |
| return 0; |
| } |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListenerDelegate#connect(org.eclipse.ui.console.TextConsole) |
| */ |
| @Override |
| public void connect(TextConsole console) {} |
| |
| /** |
| * @see org.eclipse.ui.console.IPatternMatchListenerDelegate#disconnect() |
| */ |
| @Override |
| public synchronized void disconnect() { |
| fDisconnected = true; |
| notifyAll(); |
| } |
| } |
| |