samples/deadlock/test/org/apidesign/deadlock/LabelProviderTest.java
author Jaroslav Tulach <jtulach@netbeans.org>
Sat, 14 Jun 2008 09:54:28 +0200
changeset 104 0ec9eb8bcd03
child 105 5c7a65ed657a
permissions -rw-r--r--
Onward! Towards deadlock tests.
jtulach@104
     1
package org.apidesign.deadlock;
jtulach@104
     2
jtulach@104
     3
import java.awt.Dimension;
jtulach@104
     4
import java.util.logging.Logger;
jtulach@104
     5
import javax.swing.JFrame;
jtulach@104
     6
import javax.swing.JLabel;
jtulach@104
     7
import javax.swing.JPanel;
jtulach@104
     8
import javax.swing.SwingUtilities;
jtulach@104
     9
import org.junit.Test;
jtulach@104
    10
import org.netbeans.junit.Log;
jtulach@104
    11
import org.netbeans.junit.NbTestCase;
jtulach@104
    12
import static org.junit.Assert.*;
jtulach@104
    13
jtulach@104
    14
public class LabelProviderTest extends NbTestCase {
jtulach@104
    15
    static final Logger LOG = Logger.getLogger(LabelProviderTest.class.getName());
jtulach@104
    16
    
jtulach@104
    17
    public LabelProviderTest(String n) {
jtulach@104
    18
        super(n);
jtulach@104
    19
    }
jtulach@104
    20
jtulach@104
    21
    @Override
jtulach@104
    22
    protected int timeOut() {
jtulach@104
    23
        return 10000;
jtulach@104
    24
    }
jtulach@104
    25
    
jtulach@104
    26
    
jtulach@104
    27
    public static class StrangePanel extends LabelProvider {
jtulach@104
    28
        @Override
jtulach@104
    29
        // BEGIN: deadlock.pref.size
jtulach@104
    30
        public Dimension getPreferredSize () {
jtulach@104
    31
            JLabel sampleLabel = createLabel();
jtulach@104
    32
            return sampleLabel.getPreferredSize ();
jtulach@104
    33
        }
jtulach@104
    34
        // END: deadlock.pref.size
jtulach@104
    35
    }
jtulach@104
    36
    
jtulach@104
    37
    
jtulach@104
    38
    
jtulach@104
    39
jtulach@104
    40
    public void testCreateLabel() {
jtulach@104
    41
        final LabelProvider instance = new StrangePanel();
jtulach@104
    42
        
jtulach@104
    43
        class R implements Runnable {
jtulach@104
    44
            public void run() {
jtulach@104
    45
                LOG.info("In AWT thread");
jtulach@104
    46
                JFrame f = new JFrame();
jtulach@104
    47
                f.add(instance);
jtulach@104
    48
                f.setVisible(true);
jtulach@104
    49
                f.pack();
jtulach@104
    50
            }
jtulach@104
    51
        }
jtulach@104
    52
jtulach@104
    53
        Log.controlFlow(
jtulach@104
    54
            Logger.getLogger("org.apidesign"),
jtulach@104
    55
            Logger.getLogger("global"), 
jtulach@104
    56
            "THREAD: main MSG: Begin" +
jtulach@104
    57
            "THREAD: .*AWT.* MSG: In.*thread" +
jtulach@104
    58
            "THREAD: main MSG: Will create JLabel" +
jtulach@104
    59
            "THREAD: .*AWT.* MSG: Will create JLabel", 
jtulach@104
    60
            300
jtulach@104
    61
        );
jtulach@104
    62
        
jtulach@104
    63
        R showFrame = new R();
jtulach@104
    64
        SwingUtilities.invokeLater(showFrame);
jtulach@104
    65
        
jtulach@104
    66
        LOG.info("Begin");
jtulach@104
    67
        JLabel result = instance.createLabel();
jtulach@104
    68
        assertNotNull("Creates the result", result);
jtulach@104
    69
    }
jtulach@104
    70
jtulach@104
    71
}