com.codename1.testing.TestUtils Maven / Gradle / Ivy
/*
* Copyright (c) 2012, Codename One and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Codename One designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Codename One through http://www.codenameone.com/ if you
* need additional information or have any questions.
*/
package com.codename1.testing;
import com.codename1.io.Storage;
import com.codename1.io.Util;
import com.codename1.ui.Button;
import com.codename1.ui.Command;
import com.codename1.ui.Component;
import com.codename1.ui.Container;
import com.codename1.ui.Display;
import com.codename1.ui.Form;
import com.codename1.ui.Image;
import com.codename1.ui.Label;
import com.codename1.ui.List;
import com.codename1.ui.SideMenuBar;
import com.codename1.ui.TextArea;
import com.codename1.ui.Toolbar;
import com.codename1.ui.events.ActionEvent;
import com.codename1.ui.list.ContainerList;
import com.codename1.ui.spinner.BaseSpinner;
import com.codename1.ui.spinner.GenericSpinner;
import com.codename1.ui.util.ImageIO;
import java.io.IOException;
import java.util.ArrayList;
import com.codename1.compat.java.util.Objects;
/**
* Various utility classes to automate UI testing
*
* @author Shai Almog
*/
public class TestUtils {
private static boolean verbose;
private TestUtils() {}
/**
* Activates/deactivates the verbose test mode
* @param v true for verbosity
*/
public static void setVerboseMode(boolean v) {
verbose = v;
}
/**
* Waits for the given number of milliseconds even if the waiting is on the EDT thread
* @param millis the number of milliseconds to wait
*/
public static void waitFor(final int millis) {
if(verbose) {
log("waitFor(" + millis + ")");
}
if(Display.getInstance().isEdt()) {
Display.getInstance().invokeAndBlock(new Runnable() {
public void run() {
try {
Thread.sleep(millis);
} catch (InterruptedException ex) {
}
}
});
} else {
try {
Thread.sleep(millis);
} catch (InterruptedException ex) {
}
}
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param componentName the name of the component to find
* @return the component with the given name within the tree
*/
public static Component findByName(String componentName) {
if(verbose) {
log("findByName(" + componentName + ")");
}
Component c = findByName(Display.getInstance().getCurrent(), componentName);
if(c == null) {
waitFor(30);
return findByName(Display.getInstance().getCurrent(), componentName);
}
return c;
}
/**
* Selects the given offset in a list
* @param listName the name of the list component
* @param offset the offset to select
*/
public static void selectInList(String listName, int offset) {
selectListOffset(findByName(listName), offset);
}
private static void selectListOffset(Component c, int offset) {
assertBool(c != null, "List not found");
if(c instanceof List) {
((List)c).setSelectedIndex(offset);
return;
}
if(c instanceof ContainerList) {
((ContainerList)c).setSelectedIndex(offset);
return;
}
if(c instanceof GenericSpinner) {
((GenericSpinner)c).getModel().setSelectedIndex(offset);
return;
}
assertBool(false, "Unsupported list type: " + c.getName());
}
/**
* Selects the given offset in a list
* @param offset the offset to select
*/
public static void selectInList(int[] path, int offset) {
selectListOffset(getComponentByPath(path), offset);
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param componentName the name of the component to find
* @return the component with the given name within the tree
*/
private static Component findByName(Container root, String componentName) {
if(verbose) {
log("findByName(" + root + ", " + componentName + ")");
}
int count = root.getComponentCount();
for(int iter = 0 ; iter < count ; iter++) {
Component c = root.getComponentAt(iter);
String n = c.getName();
if(n != null && n.equals(componentName)) {
return c;
}
if(c instanceof Container) {
c = findByName((Container)c, componentName);
if(c != null) {
return c;
}
}
}
return null;
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param text the text of the label/button
* @return the component with the given label text within the tree
*/
public static Label findLabelText(String text) {
if(verbose) {
log("findLabelText(" + text + ")");
}
return findLabelText(Display.getInstance().getCurrent(), text);
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param text the text of the label/button
* @return the component with the given label text within the tree
*/
private static Label findLabelText(Container root, String text) {
if(verbose) {
log("findLabelText(" + root + ", " + text + ")");
}
int count = root.getComponentCount();
for(int iter = 0 ; iter < count ; iter++) {
Component c = root.getComponentAt(iter);
if(c instanceof Label) {
String n = ((Label)c).getText();
if(n != null && n.equals(text)) {
return (Label)c;
}
// will work for cases of upcase due to Android theme upcasing of buttons
n = (String)c.getClientProperty("cn1$origText");
if(n != null && n.equals(text)) {
return (Label)c;
}
continue;
}
if(c instanceof Container) {
Label l = findLabelText((Container)c, text);
if(l != null) {
return l;
}
}
}
return null;
}
/**
* Clicks the button with the given label
* @param text the text on the button
*/
public static void clickButtonByLabel(String text) {
if(verbose) {
log("clickButtonByLabel(" + text + ")");
}
Button b = (Button)findLabelText(text);
waitFor(20);
b.pressed();
waitFor(20);
b.released();
waitFor(20);
}
/**
* Clicks the button with the given label
* @param name the name of the button
*/
public static void clickButtonByName(String name) {
if(verbose) {
log("clickButtonByName(" + name + ")");
}
Button b = (Button)findByName(name);
waitFor(20);
b.pressed();
waitFor(20);
b.released();
waitFor(20);
}
private static String toString(int[] p) {
if(p == null) {
return "null";
}
if(p.length == 0) {
return "{}";
}
String s = "{" + p[0];
for(int iter = 1 ; iter < p.length ; iter++) {
s += ", " + p[iter];
}
return s + "}";
}
/**
* Clicks the button with the given component path
* @param path the path
*/
public static void clickButtonByPath(int[] path) {
if(verbose) {
log("clickButtonByPath(" + toString(path) + ")");
}
Button b = (Button)getComponentByPath(path);
b.pressed();
waitFor(10);
b.released();
waitFor(10);
}
/**
* Executes the back command for the current form, similarly to pressing the back button
*/
public static void goBack() {
if(verbose) {
log("goBack()");
}
Form f = Display.getInstance().getCurrent();
Command c = f.getBackCommand();
assertBool(c != null, "The current form doesn't have a back command at this moment! for form name " + f.getName());
f.dispatchCommand(c, new ActionEvent(c,ActionEvent.Type.Command));
waitFor(20);
}
/**
* Executes a menu command with the given name
* @param name the name of the command
*/
public static void clickMenuItem(String name) {
if(verbose) {
log("clickMenuItem(" + name + ")");
}
Form f = Display.getInstance().getCurrent();
for(int iter = 0 ; iter < f.getCommandCount() ; iter++) {
Command c = f.getCommand(iter);
if(name.equals(c.getCommandName())) {
f.dispatchCommand(c, new ActionEvent(c,ActionEvent.Type.Command));
return;
}
}
throw new RuntimeException("Command not found: " + name);
}
/**
* Returns all the command objects from the toolbar in the order of left, right, overflow & sidemenu
* @return the set of commands
*/
public static Command[] getToolbarCommands() {
Form f = Display.getInstance().getCurrent();
Toolbar tb = f.getToolbar();
ArrayList result = new ArrayList();
addAllCommands(tb.getLeftBarCommands(), result);
addAllCommands(tb.getRightBarCommands(), result);
addAllCommands(tb.getOverflowCommands(), result);
addAllCommands(tb.getSideMenuCommands(), result);
Command[] carr = new Command[result.size()];
result.toArray(carr);
return carr;
}
private static void addAllCommands(Iterable cs, ArrayList result) {
if(cs != null) {
for(Command c : cs) {
result.add(c);
}
}
}
/**
* Shows the sidemenu UI
*/
public static void showSidemenu() {
Form f = Display.getInstance().getCurrent();
Toolbar tb = f.getToolbar();
if(tb != null) {
tb.openSideMenu();
} else {
((SideMenuBar)f.getMenuBar()).openMenu(null);
}
}
/**
* Executes a command from the offset returned by {@link #getToolbarCommands()}
*
* @param offset the offset of the command we want to execute
*/
public static void executeToolbarCommandAtOffset(final int offset) {
Form f = Display.getInstance().getCurrent();
if(!Display.getInstance().isEdt()) {
Display.getInstance().callSerially(new Runnable() {
public void run() {
executeToolbarCommandAtOffset(offset);
}
});
return;
}
Command cmd = getToolbarCommands()[offset];
f.dispatchCommand(cmd, new ActionEvent(cmd));
}
/**
* Scrolls to show the component in case it is invisible currently
* @param c the component
*/
public static void ensureVisible(Component c) {
if(verbose) {
log("ensureVisible(" + c + ")");
}
Form f = Display.getInstance().getCurrent();
f.scrollComponentToVisible(c);
}
/**
* Scrolls to show the component in case it is invisible currently
* @param componentName the component
*/
public static void ensureVisible(String componentName) {
if(verbose) {
log("ensureVisible(" + componentName + ")");
}
ensureVisible(findByName(componentName));
}
/**
* Scrolls to show the component in case it is invisible currently
* @param path the path to the component
*/
public static void ensureVisible(int[] path) {
if(verbose) {
log("ensureVisible(" + toString(path) + ")");
}
ensureVisible(getComponentByPath(path));
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test
* @param title the title of the form to wait for
* @param timeout Timeout in ms.
*/
public static void waitForFormTitle(final String title, final long timeout) {
if(verbose) {
log("waitForFormTitle(" + title + ")");
}
if(Display.getInstance().isEdt()) {
Display.getInstance().invokeAndBlock(new Runnable() {
public void run() {
waitForFormTitleImpl(title, timeout);
}
});
} else {
waitForFormTitleImpl(title, timeout);
}
waitFor(50);
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test. Timeout is 90 seconds.
* @param title the title of the form to wait for
*/
public static void waitForFormTitle(final String title) {
waitForFormTitle(title, 90000);
}
private static String getFormTitle(Form f) {
if(f.getToolbar() != null) {
Component c = f.getToolbar().getTitleComponent();
if(c instanceof Label) {
return ((Label)c).getText();
}
return null;
} else {
return f.getTitle();
}
}
private static void waitForFormTitleImpl(String title, long timeout) {
long t = System.currentTimeMillis() + timeout;
while(!title.equals(getFormTitle(Display.getInstance().getCurrent()))) {
try {
Thread.sleep(50);
if(System.currentTimeMillis() > t) {
assertBool(false, "Waiting for form " + title + " timed out! Current form title is: " + Display.getInstance().getCurrent().getTitle());
}
} catch (InterruptedException ex) {
}
}
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test
* @param name the name of the form to wait for
* @param timeout Timeout in ms
*/
public static void waitForFormName(final String name, final long timeout) {
if(verbose) {
log("waitForFormName(" + name + ")");
}
if(Display.getInstance().isEdt()) {
Display.getInstance().invokeAndBlock(new Runnable() {
public void run() {
waitForFormNameImpl(name, timeout);
}
});
} else {
waitForFormNameImpl(name, timeout);
}
waitFor(50);
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test. Timeout is 90 seconds.
* @param name the name of the form to wait for
*/
public static void waitForFormName(final String name) {
waitForFormName(name, 90000);
}
private static void waitForFormNameImpl(String title, long timeout) {
long t = System.currentTimeMillis() + timeout;
while(!title.equals(Display.getInstance().getCurrent().getName())) {
try {
Thread.sleep(50);
} catch (InterruptedException ex) {
}
if(System.currentTimeMillis() > t) {
assertBool(false, "Waiting for form " + title + " timed out! Current form name is: " + Display.getInstance().getCurrent().getName());
}
}
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test
* @param timeout Timeout in milliseconds.
*/
public static void waitForUnnamedForm(final long timeout) {
if(verbose) {
log("waitForUnnamedForm()");
}
if(Display.getInstance().isEdt()) {
Display.getInstance().invokeAndBlock(new Runnable() {
public void run() {
waitForUnnamedFormImpl(timeout);
}
});
} else {
waitForUnnamedFormImpl(timeout);
}
waitFor(50);
}
/**
* Waits for a form change and if no form change occurred after a given timeout then fail the test
*/
public static void waitForUnnamedForm() {
waitForUnnamedForm(90000);
}
private static void waitForUnnamedFormImpl(long timeout) {
long t = System.currentTimeMillis() + timeout;
while(Display.getInstance().getCurrent().getName() != null) {
try {
Thread.sleep(50);
} catch (InterruptedException ex) {
}
if(System.currentTimeMillis() > t) {
assertBool(false, "Waiting for form unnamed form timed out! Current form name is: " + Display.getInstance().getCurrent().getName());
}
}
}
/**
* The screenshot test takes a screenshot of the screen and compares it to
* a prior screenshot, if both are 100% identical the test passes. If not
* the test fails.
* If this is the first time the test is run then the screenshot is taken
* and saved under the given name in the devices storage. The test passes
* for this case but a warning is printed to the console. The name will have
* .png appended to it so it will be identified.
* This test will only work on devices that support the ImageIO API with PNG
* file format.
*
* @param screenshotName the name to use for the storage, must be unique!
* @return true if the screenshots are identical or no prior screenshot exists
* or if the test can't be run on this device. False if a screenshot exists and
* it isn't 100% identical.
*/
public static boolean screenshotTest(String screenshotName) {
if(verbose) {
log("screenshotTest(" + screenshotName + ")");
}
try {
ImageIO io = ImageIO.getImageIO();
if(io == null || !io.isFormatSupported(ImageIO.FORMAT_PNG)) {
log("screenshot test skipped due to no image IO support for PNG format");
return true;
}
Image mute = Image.createImage(Display.getInstance().getDisplayWidth(), Display.getInstance().getDisplayHeight());
Display.getInstance().getCurrent().paintComponent(mute.getGraphics(), true);
screenshotName = screenshotName + ".png";
if(Storage.getInstance().exists(screenshotName)) {
int[] rgba = mute.getRGBCached();
Image orig = Image.createImage(Storage.getInstance().createInputStream(screenshotName));
int[] origRgba = orig.getRGBCached();
orig = null;
for(int iter = 0 ; iter < rgba.length ; iter++) {
if(rgba[iter] != origRgba[iter]) {
log("screenshots do not match at offset " + iter + " saving additional image under " + screenshotName + ".fail");
io.save(mute, Storage.getInstance().createOutputStream(screenshotName + ".fail"), ImageIO.FORMAT_PNG, 1);
return false;
}
}
} else {
io.save(mute, Storage.getInstance().createOutputStream(screenshotName), ImageIO.FORMAT_PNG, 1);
}
return true;
} catch(IOException err) {
log(err);
return false;
}
}
/**
* Log to the test log
* @param t the string to log
*/
public static void log(String t) {
TestReporting.getInstance().logMessage(t);
}
/**
* Log to the test log
* @param t exception to log
*/
public static void log(Throwable t) {
TestReporting.getInstance().logException(t);
}
/**
* Simulates a device key press
* @param keyCode the keycode
*/
public static void keyPress(int keyCode) {
if(verbose) {
log("keyPress(" + keyCode + ")");
}
Display.getInstance().getCurrent().keyPressed(keyCode);
waitFor(10);
}
/**
* Simulates a device key release
* @param keyCode the keycode
*/
public static void keyRelease(int keyCode) {
if(verbose) {
log("keyRelease(" + keyCode + ")");
}
Display.getInstance().getCurrent().keyReleased(keyCode);
waitFor(10);
}
/**
* Simulates a game key press
* @param gameKey the game key (arrows etc.)
*/
public static void gameKeyPress(int gameKey) {
if(verbose) {
log("gameKeyPress(" + gameKey + ")");
}
Display.getInstance().getCurrent().keyPressed(Display.getInstance().getKeyCode(gameKey));
waitFor(10);
}
/**
* Simulates a game key release
* @param gameKey the game key (arrows etc.)
*/
public static void gameKeyRelease(int gameKey) {
if(verbose) {
log("gameKeyRelease(" + gameKey + ")");
}
Display.getInstance().getCurrent().keyReleased(Display.getInstance().getKeyCode(gameKey));
waitFor(10);
}
/**
* A component press on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param componentName the name of the component
*/
public static void pointerPress(float x, float y, String componentName) {
if(verbose) {
if(componentName == null) {
log("pointerPress(" + x + ", " + y + ", null)");
} else {
log("pointerPress(" + x + ", " + y + ", " + componentName + ")");
}
}
waitFor(20);
if(componentName != null) {
Component c = findByName(componentName);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerPressed(actualX, actualY);
} else {
Display.getInstance().getCurrent().pointerPressed((int)(x * Display.getInstance().getDisplayWidth()),
(int)(y * Display.getInstance().getDisplayHeight()));
}
waitFor(10);
}
/**
* A component release on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param componentName the name of the component
*/
public static void pointerRelease(float x, float y, String componentName) {
if(verbose) {
log("pointerRelease(" + x + ", " + y + ", " + componentName + ")");
}
Component c = findByName(componentName);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerReleased(actualX, actualY);
waitFor(30);
}
/**
* A component drag on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param componentName the name of the component
*/
public static void pointerDrag(float x, float y, String componentName) {
if(verbose) {
log("pointerDrag(" + x + ", " + y + ", " + componentName + ")");
}
Component c = findByName(componentName);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerDragged(actualX, actualY);
}
/**
* A component press on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param path the path to the component
*/
public static void pointerPress(float x, float y, int[] path) {
if(verbose) {
log("pointerPress(" + x + ", " + y + ", " + toString(path) + ")");
}
Component c = getComponentByPath(path);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerPressed(actualX, actualY);
waitFor(10);
}
/**
* A component release on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param path the path to the component
*/
public static void pointerRelease(float x, float y, int[] path) {
if(verbose) {
log("pointerRelease(" + x + ", " + y + ", " + toString(path) + ")");
}
Component c = getComponentByPath(path);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerReleased(actualX, actualY);
waitFor(10);
}
/**
* A component drag on a given named component at x/y where x and y are NOT pixels
* but rather a number between 0 to 1 representing the percentage within the component where the
* event took place. E.g. For a 100x100 component a press within 10,5 would be 0.1f, 0.05f.
* @param x the offset within the component as a number between 0 and 1
* @param y the offset within the component as a number between 0 and 1
* @param path the path to the component
*/
public static void pointerDrag(float x, float y, int[] path) {
if(verbose) {
log("pointerDrag(" + x + ", " + y + ", " + toString(path) + ")");
}
Component c = getComponentByPath(path);
int actualX = c.getAbsoluteX() + (int)(x * c.getWidth());
int actualY = c.getAbsoluteY() + (int)(y * c.getHeight());
Display.getInstance().getCurrent().pointerDragged(actualX, actualY);
}
/**
* Gets the component from the current form based on its path. A path is a
* set of offsets starting from the content pane and moving inwards so a path
* of { 0, 3 } would mean that the first component within the Content pane (by
* index) is a Container whose 3rd component (again by index) is the component we
* want.
* @param path an array
* @return a component
*/
public static Component getComponentByPath(int[] path) {
Component current = Display.getInstance().getCurrent().getContentPane();
for(int iter = 0 ; iter < path.length ; iter++) {
current = ((Container)current).getComponentAt(path[iter]);
}
return current;
}
/**
* Sets the text for the given component
* @param name the name of the component
* @param text the text to set
*/
public static void setText(String name, String text) {
if(verbose) {
log("setText(" + name + ", " + text + ")");
}
Component c = findByName(name);
if(c instanceof Label) {
((Label)c).setText(text);
return;
}
((TextArea)c).setText(text);
Display.getInstance().onEditingComplete(c, text);
}
/**
* Sets the text for the given component
* @param path the path to the component
* @param text the text to set
*/
public static void setText(int[] path, String text) {
if(verbose) {
log("setText(" + toString(path) + ", " + text + ")");
}
Component c = getComponentByPath(path);
if(c instanceof Label) {
((Label)c).setText(text);
return;
}
((TextArea)c).setText(text);
}
/**
* Assertions allow for simpler test code
* @param b must be true, otherwise an exception is thrown thus failing the test
*/
public static void assertBool(boolean b) {
if(verbose) {
log("assertBool(" + b + ")");
}
if(!b) {
throw new RuntimeException();
}
}
/**
* Assertions allow for simpler test code
* @param b must be true, otherwise an exception is thrown thus failing the test
*/
public static void assertBool(boolean b, String errorMessage) {
if(verbose) {
log("assertBool(" + b + ", " + errorMessage + ")");
}
if(!b) {
log("Assert failed on: " + errorMessage);
throw new RuntimeException(errorMessage);
}
}
/**
* An assertion that always fails a test.
*/
public static void fail() {
if(verbose) {
log("fail()");
}
assertBool(false);
}
/**
* An assertion that always fails a test.
* @param errorMessage is a string describing the failure
*/
public static void fail(String errorMessage) {
if(verbose) {
log("fail(" + errorMessage + ")");
}
assertBool(false, errorMessage);
}
/**
* Asserts that the given expression evaluates to true
*/
public static void assertTrue(boolean value) {
if(verbose) {
log("assertTrue(" + value + ")");
}
assertBool(value);
}
/**
* Asserts that the given expression evaluates to true
* @param errorMessage is a string describing the failure
*/
public static void assertTrue(boolean value, String errorMessage) {
if(verbose) {
log("assertTrue(" + value + ", " + errorMessage + ")");
}
assertBool(value, errorMessage);
}
/**
* Asserts that the given expression evaluates to false
*/
public static void assertFalse(boolean value) {
if(verbose) {
log("assertFalse(" + value + ")");
}
assertBool(!value);
}
/**
* Asserts that the given expression evaluates to false
* @param errorMessage is a string describing the failure
*/
public static void assertFalse(boolean value, String errorMessage) {
if(verbose) {
log("assertFalse(" + value + ", " + errorMessage + ")");
}
assertBool(!value, errorMessage);
}
/**
* Asserts that the given expression evaluates to null
*/
public static void assertNull(Object object) {
if(verbose) {
log("assertNull(" + object + ")");
}
assertBool(object == null);
}
/**
* Asserts that the given expression evaluates to null
* @param errorMessage is a string describing the failure
*/
public static void assertNull(Object object, String errorMessage) {
if(verbose) {
log("assertNull(" + object + ", " + errorMessage + ")");
}
assertBool(object == null, errorMessage);
}
/**
* Asserts that the given expression does not evaluate to null
*/
public static void assertNotNull(Object object) {
if(verbose) {
log("assertNotNull(" + object + ")");
}
assertBool(object != null);
}
/**
* Asserts that the given expression does not evaluate to null
* @param errorMessage is a string describing the failure
*/
public static void assertNotNull(Object object, String errorMessage) {
if(verbose) {
log("assertNotNull(" + object + ", " + errorMessage + ")");
}
assertBool(object != null, errorMessage);
}
/**
* Asserts that the given parameters reference the same object
*/
public static void assertSame(Object expected, Object actual) {
if(verbose) {
log("assertSame(" + expected + ", " + actual + ")");
}
assertBool(expected == actual);
}
/**
* Asserts that the given parameters reference the same object
* @param errorMessage is a string describing the failure
*/
public static void assertSame(Object expected, Object actual, String errorMessage) {
if(verbose) {
log("assertSame(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected == actual, errorMessage);
}
/**
* Asserts that the given parameters do not reference the same object
*/
public static void assertNotSame(Object expected, Object actual) {
if(verbose) {
log("assertNotSame(" + expected + ", " + actual + ")");
}
assertBool(expected != actual);
}
/**
* Asserts that the given parameters do not reference the same object
* @param errorMessage is a string describing the failure
*/
public static void assertNotSame(Object expected, Object actual, String errorMessage) {
if(verbose) {
log("assertNotSame(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected != actual, errorMessage);
}
private static void assertRelativeErrorExceeded(float expected, float actual, double minRelativeError) {
if(verbose) {
log("assertRelativeErrorExceeded(" + expected + ", " + actual + ", " + minRelativeError + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error < minRelativeError) {
assertBool(false);
}
}
private static void assertRelativeErrorExceeded(double expected, double actual, double minRelativeError) {
if(verbose) {
log("assertRelativeErrorExceeded("+ expected + ", " + actual + ", " + minRelativeError + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error < minRelativeError) {
assertBool(false);
}
}
private static void assertRelativeErrorExceeded(float expected, float actual, double minRelativeError, String errorMessage) {
if(verbose) {
log("assertRelativeErrorExceeded(" + expected + ", " + actual + ", " + minRelativeError + ", " + errorMessage + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error < minRelativeError) {
assertBool(false, errorMessage);
}
}
private static void assertRelativeErrorExceeded(double expected, double actual, double minRelativeError, String errorMessage) {
if(verbose) {
log("assertRelativeErrorExceeded(" + expected + ", " + actual + ", " + minRelativeError + ", " + errorMessage + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error < minRelativeError) {
assertBool(false, errorMessage);
}
}
private static void assertRelativeErrorNotExceeded(float expected, float actual, double maxRelativeError) {
if(verbose) {
log("assertRelativeErrorNotExceeded(" + expected + ", " + actual + ", " + maxRelativeError + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error > maxRelativeError) {
assertBool(false);
}
}
private static void assertRelativeErrorNotExceeded(double expected, double actual, double maxRelativeError) {
if(verbose) {
log("assertRelativeErrorNotExceeded("+ expected + ", " + actual + ", " + maxRelativeError + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error > maxRelativeError) {
assertBool(false);
}
}
private static void assertRelativeErrorNotExceeded(float expected, float actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertRelativeErrorNotExceeded(" + expected + ", " + actual + ", " + maxRelativeError + ", " + errorMessage + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error > maxRelativeError) {
assertBool(false, errorMessage);
}
}
private static void assertRelativeErrorNotExceeded(double expected, double actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertRelativeErrorNotExceeded(" + expected + ", " + actual + ", " + maxRelativeError + ", " + errorMessage + ")");
}
double relative_error = Math.abs((expected - actual) / actual) * 100;
if (relative_error > maxRelativeError) {
assertBool(false, errorMessage);
}
}
private static void assertErrorNotExceeded(double expected, double actual, double maxError, String errorMessage) {
if(verbose) {
log("assertErrorNotExceeded(" + expected + ", " + actual + ", " + maxError + ", " + errorMessage + ")");
}
double error = Math.abs((expected - actual));
if (error > maxError) {
assertBool(false, errorMessage);
}
}
/**
* Asserts that the given bytes are equal
*/
public static void assertEqual(byte expected, byte actual) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
assertBool(expected == actual);
}
/**
* Asserts that the given bytes are equal
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(byte expected, byte actual, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected == actual, errorMessage);
}
/**
* Asserts that the given shorts are equal
*/
public static void assertEqual(short expected, short actual) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
assertBool(expected == actual);
}
/**
* Asserts that the given shorts are equal
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(short expected, short actual, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected == actual, errorMessage);
}
/**
* Asserts that the given ints are equal
*/
public static void assertEqual(int expected, int actual) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
assertBool(expected == actual, "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given ints are equal
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(int expected, int actual, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected == actual, errorMessage+";" + "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given longs are equal
*/
public static void assertEqual(long expected, long actual) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
assertBool(expected == actual, "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given longs are equal
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(long expected, long actual, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected == actual, errorMessage + "; " + "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given floats are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
*
*/
public static void assertEqual(float expected, float actual, double maxRelativeError) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
if (expected != actual) {
assertRelativeErrorNotExceeded(expected, actual, maxRelativeError, "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given floats are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(float expected, float actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
if (expected != actual) {
assertRelativeErrorNotExceeded(expected, actual, maxRelativeError, errorMessage + "; " + "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given doubles are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
*
*/
public static void assertEqual(double expected, double actual, double maxRelativeError) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
if (expected != actual) {
assertRelativeErrorNotExceeded(expected, actual, maxRelativeError, "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given doubles are equal
* @param expected Expected value
* @param actual Actual value
* @param absoluteError is the maximum allowed error, a value of 1 represents a 1% error.
* @since 8.0
*/
public static void assertRange(double expected, double actual, double absoluteError) {
if(verbose) {
log("assertRange(" + expected + ", " + actual + ")");
}
if (expected != actual) {
assertErrorNotExceeded(expected, actual, absoluteError, "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given doubles are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(double expected, double actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
if (expected != actual) {
assertRelativeErrorNotExceeded(expected, actual, maxRelativeError, errorMessage + "; "+ "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given doubles are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertRange(double expected, double actual, double maxAbsoluteError, String errorMessage) {
if(verbose) {
log("assertRange(" + expected + ", " + actual + ", " + errorMessage + ")");
}
if (expected != actual) {
assertErrorNotExceeded(expected, actual, maxAbsoluteError, errorMessage + "; "+ "Expected ["+expected+"], Actual ["+actual+"]");
}
}
/**
* Asserts that the given objects are equal using the first object's .equal() method
*/
public static void assertEqual(Object expected, Object actual) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ")");
}
assertBool(Objects.equals(expected, actual), "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given objects are equal using the first object's .equal() method
* @param errorMessage is a string describing the failure
*/
public static void assertEqual(Object expected, Object actual, String errorMessage) {
if(verbose) {
log("assertEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(Objects.equals(expected, actual), errorMessage + "; "+ "Expected ["+expected+"], Actual ["+actual+"]");
}
/**
* Asserts that the given bytes are not equal
*/
public static void assertNotEqual(byte expected, byte actual) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ")");
}
assertBool(expected != actual);
}
/**
* Asserts that the given bytes are not equal
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(byte expected, byte actual, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected != actual, errorMessage);
}
/**
* Asserts that the given shorts are not equal
*/
public static void assertNotEqual(short expected, short actual) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ")");
}
assertBool(expected != actual);
}
/**
* Asserts that the given shorts are not equal
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(short expected, short actual, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected != actual, errorMessage);
}
/**
* Asserts that the given ints are not equal
*/
public static void assertNotEqual(int expected, int actual) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ")");
}
assertBool(expected != actual);
}
/**
* Asserts that the given ints are not equal
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(int expected, int actual, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
assertBool(expected != actual, errorMessage);
}
/**
* Asserts that the given longs are not equal
*/
public static void assertNotEqual(long expected, long actual, double minRelativeError) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + minRelativeError + ")");
}
if (expected == actual) {
assertBool(false);
}
else {
assertRelativeErrorExceeded(expected, actual, minRelativeError);
}
}
/**
* Asserts that the given longs are not equal
* @param minRelativeError is the minimum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(long expected, long actual, double minRelativeError, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + minRelativeError + ", " + errorMessage + ")");
}
if (expected == actual) {
TestUtils.assertBool(false, errorMessage);
}
else {
assertRelativeErrorExceeded(expected, actual, minRelativeError, errorMessage);
}
}
/**
* Asserts that the given doubles are not equal
* @param minRelativeError is the minimum allowed error, a value of 1 represents a 1% error.
*/
public static void assertNotEqual(double expected, double actual, double minRelativeError) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + minRelativeError + ")");
}
if (expected == actual) {
TestUtils.assertBool(false);
}
else {
assertRelativeErrorExceeded(expected, actual, minRelativeError);
}
}
/**
* Asserts that the given doubles are not equal
* @param minRelativeError is the minimum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(double expected, double actual, double minRelativeError, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + minRelativeError + ", " + errorMessage + ")");
}
if (expected == actual) {
TestUtils.assertBool(false, errorMessage);
}
else {
assertRelativeErrorExceeded(expected, actual, minRelativeError, errorMessage);
}
}
/**
* Asserts that the given objects are not equal using the first object's .equal() method
*/
public static void assertNotEqual(Object expected, Object actual) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ")");
}
if (Objects.equals(expected, actual)) {
TestUtils.fail("Assertion failed. Expected not equal, but found that "+expected+" equals "+actual);
}
}
/**
* Asserts that the given objects are not equal using the first object's .equal() method
* @param errorMessage is a string describing the failure
*/
public static void assertNotEqual(Object expected, Object actual, String errorMessage) {
if(verbose) {
log("assertNotEqual(" + expected + ", " + actual + ", " + errorMessage + ")");
}
if (Objects.equals(expected, actual)) {
TestUtils.fail("Assertion failed. Expected not equal, but found that "+expected+" equals "+actual+". "+errorMessage);
}
}
/**
* Pretty-prints a byte array
*/
private static String arrayToString(byte[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints a short array
*/
private static String arrayToString(short[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints a int array
*/
private static String arrayToString(int[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints a long array
*/
private static String arrayToString(long[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints a float array
*/
private static String arrayToString(float[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints a double array
*/
private static String arrayToString(double[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Pretty-prints an object array
*/
private static String arrayToString(Object[] array) {
StringBuilder result = new StringBuilder("[");
for(int index = 0; index < array.length - 1; ++index) {
result.append(array[index]).append(",");
}
if (array.length > 0) {
result.append(array[array.length - 1]);
}
result.append("]");
return result.toString();
}
/**
* Asserts that the given byte arrays are equal
*/
public static void assertArrayEqual(byte[] expected, byte[] actual) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index]);
}
}
/**
* Asserts that the given byte arrays are equal
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(byte[] expected, byte[] actual, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], errorMessage);
}
}
/**
* Asserts that the given short arrays are equal
*/
public static void assertArrayEqual(short[] expected, short[] actual) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index]);
}
}
/**
* Asserts that the given short arrays are equal
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(short[] expected, short[] actual, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], errorMessage);
}
}
/**
* Asserts that the given int arrays are equal
*/
public static void assertArrayEqual(int[] expected, int[] actual) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index]);
}
}
/**
* Asserts that the given int arrays are equal
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(int[] expected, int[] actual, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], errorMessage);
}
}
/**
* Asserts that the given long arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
*/
public static void assertArrayEqual(long[] expected, long[] actual, double maxRelativeError) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError);
}
}
/**
* Asserts that the given long arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(long[] expected, long[] actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError, errorMessage);
}
}
/**
* Asserts that the given float arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
*/
public static void assertArrayEqual(float[] expected, float[] actual, double maxRelativeError) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError);
}
}
/**
* Asserts that the given double arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(float[] expected, float[] actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError, errorMessage);
}
}
/**
* Asserts that the given double arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
*/
public static void assertArrayEqual(double[] expected, double[] actual, double maxRelativeError) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError);
}
}
/**
* Asserts that the given double arrays are equal
* @param maxRelativeError is the maximum allowed error, a value of 1 represents a 1% error.
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(double[] expected, double[] actual, double maxRelativeError, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], maxRelativeError, errorMessage);
}
}
/**
* Asserts that the given object arrays are equal
*/
public static void assertArrayEqual(Object[] expected, Object[] actual) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index]);
}
}
/**
* Asserts that the given object arrays are equal
* @param errorMessage is a string describing the failure
*/
public static void assertArrayEqual(Object[] expected, Object[] actual, String errorMessage) {
if(verbose) {
log("assertArrayEqual(" + arrayToString(expected) + ", " + arrayToString(actual) + ", " + errorMessage + ")");
}
if (expected.length != actual.length) {
TestUtils.assertBool(false);
}
for (int index = 0; index < expected.length; ++index) {
assertEqual(expected[index], actual[index], errorMessage);
}
}
/**
* Asserts that a certain exception is raised
*
* @param exception
* @param expression
*/
public static void assertException(RuntimeException exception, Runnable expression) {
if (verbose) {
log("assertException(" + exception + ", " + expression + ")");
}
try {
expression.run();
} catch (RuntimeException failure) {
if (exception.getClass() != failure.getClass()) {
TestUtils.fail();
}
return;
}
TestUtils.fail();
}
/**
* Asserts that a certain exception is raised
*
* @param exception
* @param expression
* @param errorMessage
*/
public static void assertException(RuntimeException exception, Runnable expression, String errorMessage) {
if (verbose) {
log("assertException(" + exception + ", " + expression + ", " + errorMessage + ")");
}
try {
expression.run();
} catch (RuntimeException failure) {
if (exception.getClass() != failure.getClass()) {
TestUtils.fail(errorMessage);
}
return;
}
TestUtils.fail(errorMessage);
}
/**
* Asserts that no exception is raised
*
* @param expression
*/
public static void assertNoException(Runnable expression) {
if (verbose) {
log("assertNoException(" + expression + ")");
}
try {
expression.run();
} catch (RuntimeException failure) {
TestUtils.fail();
}
}
/**
* Asserts that no exception is raised
*
* @param expression
* @param errorMessage
*/
public static void assertNoException(Runnable expression, String errorMessage) {
if (verbose) {
log("assertNoException(" + expression + ", " + errorMessage + ")");
}
try {
expression.run();
} catch (RuntimeException failure) {
TestUtils.fail(errorMessage);
}
}
/**
* Verifies the current title is the same otherwise throws an exception
* @param title the tile to verify
*/
public static void assertTitle(String title) {
if(verbose) {
log("assertTitle(" + title + ")");
}
assertBool(Display.getInstance().getCurrent().getTitle().equals(title), title);
}
/**
* Asserts that we have a label with the given text baring the given name
* @param name the name of the label
* @param text the text of the label
*/
public static void assertLabel(String name, String text) {
if(verbose) {
log("assertLabel(" + name + ", " + text + ")");
}
Label l = (Label)findByName(name);
assertBool(l != null, "Null label" + text);
assertBool(text == l.getText() || text.equals(l.getText()), name + " != " + text);
}
/**
* Asserts that we have a label with the given text baring the given name
* @param path the path of the label
* @param text the text of the label
*/
public static void assertLabel(int[] path, String text) {
if(verbose) {
log("assertLabel(" + toString(path) + ", " + text + ")");
}
Label l = (Label)getComponentByPath(path);
assertBool(l != null, "Null label" + text);
assertBool(text == l.getText() || text.equals(l.getText()), ("" + l.getText()) + " != " + text);
}
/**
* Asserts that we have a label with the given text baring the given name
* @param text the text of the label
*/
public static void assertLabel(String text) {
if(verbose) {
log("assertLabel(" + text + ")");
}
Label l = findLabelText(text);
assertBool(l != null, "Null label " + text);
}
/**
* Asserts that we have a TextArea with the given text and the given name
* @param name the name of the TextArea
* @param text the text of the TextArea
*/
public static void assertTextArea(String name, String text) {
if(verbose) {
log("assertTextArea(" + name + ", " + text + ")");
}
TextArea l = (TextArea)findByName(name);
assertBool(l != null, "Null area " + text);
assertBool(l.getText().equals(text), "assertTextArea: " + l.getText() + " != " + text);
}
/**
* Asserts that we have a TextArea with the a text contains the given text and with the given name
* @param name the name of the TextArea
* @param text the sequence to search for in the TextArea
*/
public static void assertTextAreaContaining(String name, String text) {
if(verbose) {
log("assertTextAreaContaining(" + name + ", " + text + ")");
}
TextArea l = (TextArea)findByName(name);
assertBool(l != null, "Null area " + text);
assertBool(l.getText().indexOf(text) > -1, "assertTextArea: \"" + l.getText() + "\" is not containing: \"" + text + "\"");
}
/**
* Asserts that we have a TextArea with the a text starting with the given text and with the given name
* @param name the name of the TextArea
* @param text the prefix to search for in the TextArea
*/
public static void assertTextAreaStartingWith(String name, String text) {
if(verbose) {
log("assertTextAreaStartingWith(" + name + ", " + text + ")");
}
TextArea l = (TextArea)findByName(name);
assertBool(l != null, "Null area " + text);
assertBool(l.getText().startsWith(text), "assertTextArea: \"" + l.getText() + "\" is not starting with: \"" + text + "\"");
}
/**
* Asserts that we have a TextArea with the a text ending with the given text and with the given name
* @param name the name of the TextArea
* @param text the suffix to search for in the TextArea
*/
public static void assertTextAreaEndingWith(String name, String text) {
if(verbose) {
log("assertTextAreaEndingWith(" + name + ", " + text + ")");
}
TextArea l = (TextArea)findByName(name);
assertBool(l != null, "Null area " + text);
assertBool(l.getText().endsWith(text), "assertTextArea: \"" + l.getText() + "\" is not ending with: \"" + text + "\"");
}
/**
* Asserts that we have a label with the given text baring the given name
* @param path the path to the text area
* @param text the text of the label
*/
public static void assertTextArea(int[] path, String text) {
if(verbose) {
log("assertTextArea(" + toString(path) + ", " + text + ")");
}
TextArea l = (TextArea)getComponentByPath(path);
assertBool(l != null, "Null area " + text);
assertBool(l.getText().equals(text), "assertTextArea: " + l.getText() + " != " + text);
}
/**
* Asserts that we have a label with the given text baring the given name
* @param text the text of the label
*/
public static void assertTextArea(String text) {
if(verbose) {
log("assertTextArea(" + text + ")");
}
TextArea l = findTextAreaText(text);
assertBool(l != null, "Null text " + text);
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param text the text of the label/button
* @return the component with the given TextArea text within the tree
*/
public static TextArea findTextAreaText(String text) {
return findTextAreaText(Display.getInstance().getCurrent(), text);
}
/**
* Finds a component with the given name, works even with UI's that weren't created with the GUI builder
* @param text the text of the label/button
* @return the component with the given label text within the tree
*/
private static TextArea findTextAreaText(Container root, String text) {
int count = root.getComponentCount();
for(int iter = 0 ; iter < count ; iter++) {
Component c = root.getComponentAt(iter);
if(c instanceof TextArea) {
String n = ((TextArea)c).getText();
if(n != null && n.equals(text)) {
return (TextArea)c;
}
continue;
}
if(c instanceof Container) {
TextArea l = findTextAreaText((Container)c, text);
if(l != null) {
return l;
}
}
}
return null;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy