org.assertj.swing.driver.JScrollBarDriver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of assertj-swing Show documentation
Show all versions of assertj-swing Show documentation
Fluent interface for functional GUI testing
/**
* 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.
*/
package org.assertj.swing.driver;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.util.Preconditions.checkNotNull;
import static org.assertj.core.util.Strings.concat;
import static org.assertj.swing.driver.ComponentPreconditions.checkEnabledAndShowing;
import static org.assertj.swing.driver.JScrollBarSetValueTask.setValue;
import static org.assertj.swing.driver.JScrollBarValueQuery.valueOf;
import static org.assertj.swing.edt.GuiActionRunner.execute;
import java.awt.Point;
import javax.annotation.Nonnull;
import javax.swing.JScrollBar;
import org.assertj.swing.annotation.RunsInCurrentThread;
import org.assertj.swing.annotation.RunsInEDT;
import org.assertj.swing.core.Robot;
import org.assertj.swing.edt.GuiQuery;
import org.assertj.swing.internal.annotation.InternalApi;
import org.assertj.swing.util.GenericRange;
import org.assertj.swing.util.Pair;
/**
*
* Supports functional testing of {@code JScrollBar}s.
*
*
*
* Note: This class is intended for internal use only. Please use the classes in the package
* {@link org.assertj.swing.fixture} in your tests.
*
*
* @author Yvonne Wang
* @author Alex Ruiz
*/
@InternalApi
public class JScrollBarDriver extends JComponentDriver {
private static final String VALUE_PROPERTY = "value";
private final JScrollBarLocation location = new JScrollBarLocation();
/**
* Creates a new {@link JScrollBarDriver}.
*
* @param robot the robot to use to simulate user input.
*/
public JScrollBarDriver(@Nonnull Robot robot) {
super(robot);
}
/**
* Scrolls up (or left) one unit (usually a line).
*
* @param scrollBar the target {@code JScrollBar}.
*/
public void scrollUnitUp(@Nonnull JScrollBar scrollBar) {
scrollUnitUp(scrollBar, 1);
}
/**
* Scrolls up (or left) one unit (usually a line), the given number of times.
*
* @param scrollBar the target {@code JScrollBar}.
* @param times the number of times to scroll up one unit.
* @throws IllegalArgumentException if {@code times} is less than or equal to zero.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
public void scrollUnitUp(@Nonnull JScrollBar scrollBar, int times) {
checkPositive(times, "scroll up one unit");
Pair scrollInfo = findScrollUnitInfo(scrollBar, location(), times * -1);
scroll(scrollBar, scrollInfo);
}
/**
* Scrolls down (or right) one unit (usually a line).
*
* @param scrollBar the target {@code JScrollBar}.
*/
public void scrollUnitDown(@Nonnull JScrollBar scrollBar) {
scrollUnitDown(scrollBar, 1);
}
/**
* Scrolls down (or right) one unit (usually a line), the given number of times.
*
* @param scrollBar the target {@code JScrollBar}.
* @param times the number of times to scroll down one unit.
* @throws IllegalArgumentException if {@code times} is less than or equal to zero.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
public void scrollUnitDown(@Nonnull JScrollBar scrollBar, int times) {
checkPositive(times, "scroll down one unit");
Pair scrollInfo = findScrollUnitInfo(scrollBar, location(), times);
scroll(scrollBar, scrollInfo);
}
@RunsInEDT
private static @Nonnull Pair findScrollUnitInfo(final @Nonnull JScrollBar scrollBar,
final @Nonnull JScrollBarLocation location, final int times) {
Pair result = execute(new GuiQuery>() {
@Override
protected Pair executeInEDT() {
checkEnabledAndShowing(scrollBar);
return scrollUnitInfo(scrollBar, location, times);
}
});
return checkNotNull(result);
}
@RunsInCurrentThread
private static @Nonnull Pair scrollUnitInfo(@Nonnull JScrollBar scrollBar,
@Nonnull JScrollBarLocation location, int times) {
Point where = blockLocation(scrollBar, location, times);
int count = times * scrollBar.getUnitIncrement();
return Pair.of(where, scrollBar.getValue() + count);
}
/**
* Scrolls up (or left) one block (usually a page).
*
* @param scrollBar the target {@code JScrollBar}.
*/
@RunsInEDT
public void scrollBlockUp(@Nonnull JScrollBar scrollBar) {
scrollBlockUp(scrollBar, 1);
}
/**
* Scrolls up (or left) one block (usually a page), the given number of times.
*
* @param scrollBar the target {@code JScrollBar}.
* @param times the number of times to scroll up one block.
* @throws IllegalArgumentException if {@code times} is less than or equal to zero.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
@RunsInEDT
public void scrollBlockUp(@Nonnull JScrollBar scrollBar, int times) {
checkPositive(times, "scroll up one block");
Pair scrollInfo = validateAndFindScrollBlockInfo(scrollBar, location(), times * -1);
scroll(scrollBar, scrollInfo);
}
/**
* Scrolls down (or right) one block (usually a page).
*
* @param scrollBar the target {@code JScrollBar}.
*/
@RunsInEDT
public void scrollBlockDown(@Nonnull JScrollBar scrollBar) {
scrollBlockDown(scrollBar, 1);
}
/**
* Scrolls down (or right) one block (usually a page), the given number of times.
*
* @param scrollBar the target {@code JScrollBar}.
* @param times the number of times to scroll down one block.
* @throws IllegalArgumentException if {@code times} is less than or equal to zero.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
@RunsInEDT
public void scrollBlockDown(@Nonnull JScrollBar scrollBar, int times) {
checkPositive(times, "scroll down one block");
Pair scrollInfo = validateAndFindScrollBlockInfo(scrollBar, location(), times);
scroll(scrollBar, scrollInfo);
}
private void checkPositive(int times, @Nonnull String action) {
if (times > 0) {
return;
}
String msg = String.format("The number of times to %s should be greater than zero, but was <%d>", action, times);
throw new IllegalArgumentException(msg);
}
@RunsInEDT
private static @Nonnull Pair validateAndFindScrollBlockInfo(final @Nonnull JScrollBar scrollBar,
final @Nonnull JScrollBarLocation location, final int times) {
Pair result = execute(new GuiQuery>() {
@Override
protected Pair executeInEDT() {
checkEnabledAndShowing(scrollBar);
return scrollBlockInfo(scrollBar, location, times);
}
});
return checkNotNull(result);
}
@RunsInCurrentThread
private static Pair scrollBlockInfo(@Nonnull JScrollBar scrollBar,
@Nonnull JScrollBarLocation location, int times) {
Point where = blockLocation(scrollBar, location, times);
int count = times * scrollBar.getBlockIncrement();
return Pair.of(where, scrollBar.getValue() + count);
}
@RunsInCurrentThread
private static @Nonnull Point blockLocation(@Nonnull JScrollBar scrollBar, @Nonnull JScrollBarLocation location,
int times) {
return times > 0 ? location.blockLocationToScrollDown(scrollBar) : location.blockLocationToScrollUp(scrollBar);
}
@RunsInEDT
private void scroll(@Nonnull JScrollBar scrollBar, @Nonnull Pair scrollInfo) {
// For now, do it programmatically, faking the mouse movement and clicking
robot.moveMouse(scrollBar, checkNotNull(scrollInfo.first));
setValueProperty(scrollBar, scrollInfo.second);
}
/**
* Scrolls to the maximum position of the given {@code JScrollBar}.
*
* @param scrollBar the target {@code JScrollBar}.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
@RunsInEDT
public void scrollToMaximum(@Nonnull JScrollBar scrollBar) {
Pair> scrollInfo = findScrollToMaximumInfo(scrollBar, location());
scroll(scrollBar, scrollInfo.first, checkNotNull(scrollInfo.second));
}
@RunsInEDT
private static @Nonnull Pair> findScrollToMaximumInfo(
final @Nonnull JScrollBar scrollBar, final @Nonnull JScrollBarLocation location) {
Pair> result = execute(new GuiQuery>>() {
@Override
protected Pair> executeInEDT() {
checkEnabledAndShowing(scrollBar);
int position = scrollBar.getMaximum();
GenericRange scrollInfo = scrollInfo(scrollBar, location, position);
return Pair.of(position, scrollInfo);
}
});
return checkNotNull(result);
}
/**
* Scrolls to the minimum position of the given {@code JScrollBar}.
*
* @param scrollBar the target {@code JScrollBar}.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
*/
@RunsInEDT
public void scrollToMinimum(@Nonnull JScrollBar scrollBar) {
Pair> scrollInfo = findScrollToMinimumInfo(scrollBar, location);
scroll(scrollBar, scrollInfo.first, checkNotNull(scrollInfo.second));
}
@RunsInEDT
private static @Nonnull Pair> findScrollToMinimumInfo(
final @Nonnull JScrollBar scrollBar, final JScrollBarLocation location) {
Pair> result = execute(new GuiQuery>>() {
@Override
protected Pair> executeInEDT() {
checkEnabledAndShowing(scrollBar);
int position = scrollBar.getMinimum();
GenericRange scrollInfo = scrollInfo(scrollBar, location, position);
return Pair.of(position, scrollInfo);
}
});
return checkNotNull(result);
}
/**
* Scrolls to the given position.
*
* @param scrollBar the target {@code JScrollBar}.
* @param position the position to scroll to.
* @throws IllegalStateException if the {@code JScrollBar} is disabled.
* @throws IllegalStateException if the {@code JScrollBar} is not showing on the screen.
* @throws IllegalArgumentException if the given position is not within the {@code JScrollBar} bounds.
*/
@RunsInEDT
public void scrollTo(@Nonnull JScrollBar scrollBar, int position) {
GenericRange scrollInfo = validateAndFindScrollInfo(scrollBar, location(), position);
scroll(scrollBar, position, scrollInfo);
}
@RunsInEDT
private static @Nonnull GenericRange validateAndFindScrollInfo(final @Nonnull JScrollBar scrollBar,
final @Nonnull JScrollBarLocation location, final int position) {
GenericRange result = execute(new GuiQuery>() {
@Override
protected GenericRange executeInEDT() {
checkPositionInBounds(scrollBar, position);
checkEnabledAndShowing(scrollBar);
return scrollInfo(scrollBar, location, position);
}
});
return checkNotNull(result);
}
@RunsInCurrentThread
private static void checkPositionInBounds(@Nonnull JScrollBar scrollBar, int position) {
int min = scrollBar.getMinimum();
int max = scrollBar.getMaximum();
if (position >= min && position <= max) {
return;
}
throw new IllegalArgumentException(concat("Position <", position, "> is not within the JScrollBar bounds of <",
min, "> and <", max, ">"));
}
@RunsInCurrentThread
private static @Nonnull GenericRange scrollInfo(@Nonnull JScrollBar scrollBar,
@Nonnull JScrollBarLocation location, int position) {
Point from = location.thumbLocation(scrollBar, scrollBar.getValue());
Point to = location.thumbLocation(scrollBar, position);
return new GenericRange(from, to);
}
private void scroll(@Nonnull JScrollBar scrollBar, int position, @Nonnull GenericRange points) {
simulateScrolling(scrollBar, points);
setValueProperty(scrollBar, position);
}
@RunsInEDT
private void simulateScrolling(@Nonnull JScrollBar scrollBar, @Nonnull GenericRange points) {
robot.moveMouse(scrollBar, points.from());
robot.moveMouse(scrollBar, points.to());
}
@RunsInEDT
private void setValueProperty(@Nonnull JScrollBar scrollBar, int value) {
setValue(scrollBar, value);
robot.waitForIdle();
}
/**
* Asserts that the value of the {@code JScrollBar} is equal to the given one.
*
* @param scrollBar the target {@code JScrollBar}.
* @param value the expected value.
* @throws AssertionError if the value of the {@code JScrollBar} is not equal to the given one.
*/
@RunsInEDT
public void requireValue(@Nonnull JScrollBar scrollBar, int value) {
assertThat(valueOf(scrollBar)).as(propertyName(scrollBar, VALUE_PROPERTY)).isEqualTo(value);
}
private @Nonnull JScrollBarLocation location() {
return location;
}
}