AbstractColoredConsole.java

1
package com.jsql.view.swing.console;
2
3
import com.jsql.util.LogLevelUtil;
4
import com.jsql.view.swing.text.JPopupTextPane;
5
import com.jsql.view.swing.util.MediatorHelper;
6
import org.apache.commons.lang3.StringUtils;
7
import org.apache.logging.log4j.LogManager;
8
import org.apache.logging.log4j.Logger;
9
10
import javax.swing.*;
11
import javax.swing.text.SimpleAttributeSet;
12
import java.awt.*;
13
import java.awt.event.FocusAdapter;
14
import java.awt.event.FocusEvent;
15
16
/**
17
 * A JTextPane which displays colored strings.
18
 */
19
public abstract class AbstractColoredConsole extends JPopupTextPane {
20
    
21
    private static final Logger LOGGER = LogManager.getRootLogger();
22
23
    /**
24
     * Text name of tab.
25
     */
26
    private final String tabName;
27
28
    /**
29
     * Create a JTextPane which displays colored strings.
30
     * @param tabName Text name of tab
31
     */
32
    protected AbstractColoredConsole(final String tabName, String placeholder) {
33
        super(placeholder);
34
        this.tabName = tabName;
35 1 1. <init> : removed call to com/jsql/view/swing/console/AbstractColoredConsole::addFocusListener → NO_COVERAGE
        this.addFocusListener(new FocusAdapter() {
36
            @Override
37
            public void focusGained(FocusEvent focusEvent) {
38 1 1. focusGained : removed call to javax/swing/text/Caret::setVisible → NO_COVERAGE
                AbstractColoredConsole.this.getProxy().getCaret().setVisible(true);
39 1 1. focusGained : removed call to javax/swing/text/Caret::setSelectionVisible → NO_COVERAGE
                AbstractColoredConsole.this.getProxy().getCaret().setSelectionVisible(true);
40
            }
41
        });
42 1 1. <init> : removed call to com/jsql/view/swing/console/AbstractColoredConsole::setCursor → NO_COVERAGE
        this.setCursor(Cursor.getPredefinedCursor(Cursor.TEXT_CURSOR));
43
    }
44
    
45
    protected abstract SimpleAttributeSet getColorAttribute();
46
47
    /**
48
     * Add a string to the end of JTextPane.
49
     * @param message Text to add
50
     * @param attribut Font
51
     */
52
    public void append(String message, SimpleAttributeSet attribut) {
53
        try {
54 1 1. append : negated conditional → NO_COVERAGE
            boolean isCaretAtEnd = this.getProxy().getCaretPosition() == this.getProxy().getDocument().getLength();
55
            
56
            JScrollPane scrollPane = (JScrollPane) this.getProxy().getParent().getParent();
57
            JScrollBar scrollBar = scrollPane.getVerticalScrollBar();
58
            int extent = scrollBar.getModel().getExtent();
59 3 1. append : Replaced integer subtraction with addition → NO_COVERAGE
2. append : changed conditional boundary → NO_COVERAGE
3. append : negated conditional → NO_COVERAGE
            boolean isScrollBarAtEnd = scrollBar.getValue() >= scrollBar.getMaximum() - extent;
60
            
61
            var logMessage = message.substring(15);
62
            var logTimestamp = message.substring(0, 15);
63
            
64 1 1. append : removed call to javax/swing/text/Document::insertString → NO_COVERAGE
            this.getProxy().getDocument().insertString(
65
                this.getProxy().getDocument().getLength(),
66 1 1. append : negated conditional → NO_COVERAGE
                (this.getProxy().getDocument().getLength() == 0 ? StringUtils.EMPTY : "\n") + logTimestamp,
67
                this.getColorAttribute()
68
            );
69
            
70 1 1. append : removed call to javax/swing/text/Document::insertString → NO_COVERAGE
            this.getProxy().getDocument().insertString(
71
                this.getProxy().getDocument().getLength(),
72
                logMessage,
73
                attribut
74
            );
75
            
76 2 1. append : negated conditional → NO_COVERAGE
2. append : negated conditional → NO_COVERAGE
            if (isCaretAtEnd || isScrollBarAtEnd) {
77 2 1. append : removed call to javax/swing/JScrollBar::setValue → NO_COVERAGE
2. append : Replaced integer addition with subtraction → NO_COVERAGE
                scrollBar.setValue(scrollBar.getMaximum() + 1);
78
            }
79
80
            var foregroundColor = UIManager.getColor("TextArea.foreground");
81 1 1. append : negated conditional → NO_COVERAGE
            if (attribut == JTextPaneAppender.ATTRIBUTE_WARN) {
82
                foregroundColor = LogLevelUtil.COLOR_RED;
83 1 1. append : negated conditional → NO_COVERAGE
            } else if (attribut == JTextPaneAppender.ATTRIBUTE_SUCCESS) {
84
                foregroundColor = LogLevelUtil.COLOR_GREEN;
85
            }
86
            
87
            int tabIndex = MediatorHelper.tabConsoles().indexOfTab(this.tabName);
88 4 1. append : changed conditional boundary → NO_COVERAGE
2. append : changed conditional boundary → NO_COVERAGE
3. append : negated conditional → NO_COVERAGE
4. append : negated conditional → NO_COVERAGE
            if (0 <= tabIndex && tabIndex < MediatorHelper.tabConsoles().getTabCount()) {
89
                var tabHeader = MediatorHelper.tabConsoles().getTabComponentAt(tabIndex);
90 1 1. append : negated conditional → NO_COVERAGE
                if (MediatorHelper.tabConsoles().getSelectedIndex() != tabIndex) {
91 1 1. append : removed call to java/awt/Component::setFont → NO_COVERAGE
                    tabHeader.setFont(tabHeader.getFont().deriveFont(Font.BOLD));
92 1 1. append : negated conditional → NO_COVERAGE
                    if (foregroundColor != UIManager.getColor("TextArea.foreground")) {  // keep tab colored until user clicks
93 1 1. append : removed call to java/awt/Component::setForeground → NO_COVERAGE
                        tabHeader.setForeground(foregroundColor);
94
                    }
95
                }
96
            }
97
        } catch (Exception e) {
98
            // Report #863: exception during report of exception
99
            LOGGER.log(LogLevelUtil.CONSOLE_JAVA, message, e);
100
        }
101
    }
102
}

Mutations

35

1.1
Location : <init>
Killed by : none
removed call to com/jsql/view/swing/console/AbstractColoredConsole::addFocusListener → NO_COVERAGE

38

1.1
Location : focusGained
Killed by : none
removed call to javax/swing/text/Caret::setVisible → NO_COVERAGE

39

1.1
Location : focusGained
Killed by : none
removed call to javax/swing/text/Caret::setSelectionVisible → NO_COVERAGE

42

1.1
Location : <init>
Killed by : none
removed call to com/jsql/view/swing/console/AbstractColoredConsole::setCursor → NO_COVERAGE

54

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

59

1.1
Location : append
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : append
Killed by : none
changed conditional boundary → NO_COVERAGE

3.3
Location : append
Killed by : none
negated conditional → NO_COVERAGE

64

1.1
Location : append
Killed by : none
removed call to javax/swing/text/Document::insertString → NO_COVERAGE

66

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

70

1.1
Location : append
Killed by : none
removed call to javax/swing/text/Document::insertString → NO_COVERAGE

76

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

2.2
Location : append
Killed by : none
negated conditional → NO_COVERAGE

77

1.1
Location : append
Killed by : none
removed call to javax/swing/JScrollBar::setValue → NO_COVERAGE

2.2
Location : append
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

81

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

83

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

88

1.1
Location : append
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : append
Killed by : none
changed conditional boundary → NO_COVERAGE

3.3
Location : append
Killed by : none
negated conditional → NO_COVERAGE

4.4
Location : append
Killed by : none
negated conditional → NO_COVERAGE

90

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

91

1.1
Location : append
Killed by : none
removed call to java/awt/Component::setFont → NO_COVERAGE

92

1.1
Location : append
Killed by : none
negated conditional → NO_COVERAGE

93

1.1
Location : append
Killed by : none
removed call to java/awt/Component::setForeground → NO_COVERAGE

Active mutators

Tests examined


Report generated by PIT 1.19.1