/**
* 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.
*
* Copyright 2012-2015 the original author or authors.
*/
/**
* <p>
* Utilities for finding {@code Component}s.
* </p>
*
* <p>
* An example is the main window of an application being shown after the user's credentials have been successfully
* verified. The following are the steps to complete such scenario:
* </p>
*
* <ul>
* <li>User launches the application</li>
* <li>A login window appears</li>
* <li>User enters her username and password and clicks the "Login" button</li>
* <li>User is authenticated and authorized successfully</li>
* <li>The main window of the application is displayed</li>
* </ul>
*
* <p>
* The "tricky" part here is step 4. Authentication/authorization can take some time (depending on network
* traffic, etc). and we need to wait for the main window to appear in order to continue our test. It is possible to
* test this scenario with AssertJ-Swing:
* </p>
*
* <pre>
* loginDialog.textBox("username").enterText("yvonne");
* loginDialog.textBox("password").enterText("welcome");
* loginDialog.button("login").click();
*
* // now the interesting part, we need to wait till the main window is shown.
* FrameFixture mainFrame = findFrame("main").using(loginDialog.robot);
*
* // we can continue testing the main window.
* </pre>
*
* <p>
* The "{@link org.assertj.swing.finder.WindowFinder#findFrame(String) findFrame}" method (imported statically
* from {@link org.assertj.swing.finder.WindowFinder}) can lookup a {@code Frame} (having "main" as its name)
* with a default timeout of 5 seconds. That means that if in 5 seconds the frame we are looking for is not found, the
* test will fail.
* </p>
*
* <p>
* We can also specify a custom value for the timeout. For example, we can set the timeout to 10 seconds in two ways:
* </p>
*
* <pre>
* FrameFixture mainFrame = findFrame("main").withTimeout(10000).using(loginDialog.robot);
* // or
* FrameFixture mainFrame = findFrame("main").withTimeout(10, SECONDS).using(loginDialog.robot);
* </pre>
*
* <p>
* We can also look up Frames by type:
* </p>
*
* <pre>
* FrameFixture mainFrame = findFrame(MainFrame.class).using(loginDialog.robot);
* </pre>
*
* <p>
* Something that you may find weird in the code examples is "{@code using(loginDialog.robot)}." This is
* necessary because, in a given test, only one instance of {@link org.assertj.swing.core.Robot Robot} can be running,
* to prevent GUI tests from blocking each other on the screen. In another words, in a test class you can only use one
* and only one instance of {@code Robot}.
* </p>
*
* @author Alex Ruiz
*/
package org.assertj.swing.finder;