org.pdfsam.ui.log.LogPaneTest.java Source code

Java tutorial

Introduction

Here is the source code for org.pdfsam.ui.log.LogPaneTest.java

Source

/* 
 * This file is part of the PDF Split And Merge source code
 * Created on 22/ago/2014
 * Copyright 2013-2014 by Andrea Vacondio (andrea.vacondio@gmail.com).
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as 
 * published by the Free Software Foundation, either version 3 of the 
 * License, or (at your option) any later version.
 *
 * This program 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 for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
package org.pdfsam.ui.log;

import static org.apache.commons.lang3.StringUtils.isBlank;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import javafx.scene.Parent;
import javafx.scene.input.Clipboard;

import javax.inject.Inject;

import org.junit.ClassRule;
import org.junit.Test;
import org.junit.experimental.categories.Category;
import org.junit.runner.RunWith;
import org.loadui.testfx.GuiTest;
import org.loadui.testfx.categories.TestFX;
import org.loadui.testfx.utils.FXTestUtils;
import org.pdfsam.context.UserContext;
import org.pdfsam.test.ClearEventStudioRule;
import org.springframework.beans.factory.config.ConfigurableBeanFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Lazy;
import org.springframework.context.annotation.Scope;
import org.springframework.test.annotation.DirtiesContext;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

/**
 * @author Andrea Vacondio
 *
 */
@Category(TestFX.class)
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration
public class LogPaneTest extends GuiTest {

    @Inject
    private ApplicationContext applicationContext;
    @ClassRule
    public static ClearEventStudioRule clearStudio = new ClearEventStudioRule();

    @Configuration
    @Lazy
    static class Config {
        @Bean
        public UserContext context() {
            UserContext userContext = mock(UserContext.class);
            when(userContext.getNumberOfLogRows()).thenReturn(200);
            return userContext;
        }

        @Bean
        @Scope(value = ConfigurableBeanFactory.SCOPE_PROTOTYPE)
        public LogPane pane() {
            return new LogPane(view());
        }

        @Bean
        public LogListView view() {
            LogListView view = new LogListView(context());
            view.appendLog(LogLevel.INFO, "A message");
            view.appendLog(LogLevel.ERROR, "An Error message");
            return view;
        }
    }

    @Override
    protected Parent getRootNode() {
        return applicationContext.getBean(LogPane.class);
    }

    @Test
    @DirtiesContext
    public void clear() throws Exception {
        LogListView view = applicationContext.getBean(LogListView.class);
        assertEquals(2, view.getItems().size());
        rightClick("A message").click("#clearLogMenuItem");
        assertEquals(0, view.getItems().size());
    }

    @Test
    public void copy() throws Exception {
        FXTestUtils.invokeAndWait(() -> {
            Clipboard.getSystemClipboard().clear();
            assertTrue(isBlank(Clipboard.getSystemClipboard().getString()));
        }, 2);
        click("A message").rightClick("A message").click("#copyLogMenuItem");
        FXTestUtils.invokeAndWait(
                () -> assertTrue(Clipboard.getSystemClipboard().getString().contains("A message")), 1);
    }

    @Test
    public void selectAll() throws Exception {
        LogListView view = applicationContext.getBean(LogListView.class);
        rightClick("A message").click("#selectAllLogMenuItem");
        assertEquals(2, view.getSelectionModel().getSelectedItems().size());
    }

}