Тестирование FEST JUnit-Swing noobQ: как протестировать основной класс? - PullRequest
2 голосов
/ 03 марта 2011

Несмотря на то, что я прочитал учебник здесь , я не могу понять, как заставить FEST работать с моим приложением.

У меня есть приложение Swing в большом классе с основным методом и пара классов SwingWorker. Я хочу протестировать свое приложение, как будто я запускаю его с помощью основного метода. Похоже, что в руководстве даются инструкции о том, как протестировать отдельный компонент.

Миниатюрная версия моего ApplicationWindow.class, который содержит основной метод:

private JFrame frmArtisol;
private JButton btnBrowseDB;
public static void main(String[] args) {
    EventQueue.invokeLater(new Runnable() {
        public void run() {
            try {
                ApplicationWindow window = new ApplicationWindow();
                window.frmArtisol.setVisible(true);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    });
}

/**
 * Create the application.
 */
public ApplicationWindow() {
    initialize();

}

И мой тестовый класс выдает ошибку.

public class ApplicationWindowTest {
private FrameFixture window;
@Before
public void setup() throws InitializationError{
    ApplicationWindow applicationWindow = new ApplicationWindow();
    JFrame frame = applicationWindow.getFrmArtisol(); 
    frame = GuiActionRunner.execute(new GuiQuery<JFrame>() {

        @Override
        protected JFrame executeInEDT() throws Throwable {
            return new JFrame();
        }
    });

    window = new FrameFixture(frame);
    window.show();

}

@Test
public void test(){
    window.button("btnBrowseDB").click();
}
@After
public void after(){
    window.cleanUp();
}

}

Ошибка при выполнении этого теста:

  org.fest.swing.exception.ComponentLookupException: Unable to find component using matcher org.fest.swing.core.NameMatcher[name='btnBrowseDB', type=javax.swing.JButton, requireShowing=true].

Component hierarchy:
javax.swing.JFrame[name='frame0', title='', enabled=true, visible=true, showing=true]
  javax.swing.JRootPane[]
    javax.swing.JPanel[name='null.glassPane']
    javax.swing.JLayeredPane[]
      javax.swing.JPanel[name='null.contentPane']

    at org.fest.swing.core.BasicComponentFinder.componentNotFound(BasicComponentFinder.java:271)
    at org.fest.swing.core.BasicComponentFinder.find(BasicComponentFinder.java:260)
    at org.fest.swing.core.BasicComponentFinder.find(BasicComponentFinder.java:254)
    at org.fest.swing.core.BasicComponentFinder.findByName(BasicComponentFinder.java:191)
    at org.fest.swing.fixture.ContainerFixture.findByName(ContainerFixture.java:527)
    at org.fest.swing.fixture.ContainerFixture.button(ContainerFixture.java:124)
    at ApplicationWindowTest.test(ApplicationWindowTest.java:34)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:49)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

Кажется, что бегун не находит мой компонент, и это заставляет меня поверить, что я неправильно понял, как проверять подобные вещи. Любая помощь, указывающая мне в правильном направлении, очень ценится.

1 Ответ

2 голосов
/ 24 мая 2011

Возможно, вы уже решили эту проблему, но я только что натолкнулся на ваш вопрос, когда искал помощь по связанной проблеме.

Проблема в том, что ваш метод setup() создает ApplicationWindow, но затем перезаписывает переменную frame ссылкой на совершенно новый и не связанный JFrame объект. То, что вы хотите сделать, это создать ApplicationWindow в методе executeInEDT() следующим образом:

@Before
public void setup() throws InitializationError{
    JFrame frame = GuiActionRunner.execute(new GuiQuery<JFrame>() {

        @Override
        protected JFrame executeInEDT() throws Throwable {
            return new ApplicationWindow().getFrmArtisol();
        }
    });

    window = new FrameFixture(frame);
    window.show();

}
...