samples/deadlock/test/org/apidesign/deadlock/LabelProviderTest.java
author Jaroslav Tulach <jtulach@netbeans.org>
Sat, 14 Jun 2008 09:58:08 +0200
changeset 153 b5cbb797ec0a
parent 132 3bc4c54f4bcc
child 154 0fd5e9c500b9
permissions -rw-r--r--
up to line 2000
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@105
    14
// BEGIN: deadlock.test.controlflow
jtulach@104
    15
public class LabelProviderTest extends NbTestCase {
jtulach@153
    16
    static final Logger LOG = Logger.getLogger(LabelProviderTest.class.getName());
jtulach@104
    17
    
jtulach@104
    18
    public LabelProviderTest(String n) {
jtulach@104
    19
        super(n);
jtulach@104
    20
    }
jtulach@104
    21
jtulach@104
    22
    @Override
jtulach@104
    23
    protected int timeOut() {
jtulach@104
    24
        return 10000;
jtulach@104
    25
    }
jtulach@104
    26
    
jtulach@104
    27
    
jtulach@104
    28
    public static class StrangePanel extends LabelProvider {
jtulach@104
    29
        @Override
jtulach@104
    30
        // BEGIN: deadlock.pref.size
jtulach@104
    31
        public Dimension getPreferredSize () {
jtulach@104
    32
            JLabel sampleLabel = createLabel();
jtulach@104
    33
            return sampleLabel.getPreferredSize ();
jtulach@104
    34
        }
jtulach@104
    35
        // END: deadlock.pref.size
jtulach@104
    36
    }
jtulach@104
    37
    
jtulach@104
    38
    
jtulach@104
    39
    
jtulach@104
    40
jtulach@104
    41
    public void testCreateLabel() {
jtulach@104
    42
        final LabelProvider instance = new StrangePanel();
jtulach@104
    43
        
jtulach@104
    44
        class R implements Runnable {
jtulach@104
    45
            public void run() {
jtulach@104
    46
                LOG.info("In AWT thread");
jtulach@104
    47
                JFrame f = new JFrame();
jtulach@104
    48
                f.add(instance);
jtulach@104
    49
                f.setVisible(true);
jtulach@104
    50
                f.pack();
jtulach@104
    51
            }
jtulach@104
    52
        }
jtulach@104
    53
jtulach@104
    54
        Log.controlFlow(
jtulach@104
    55
            Logger.getLogger("org.apidesign"),
jtulach@104
    56
            Logger.getLogger("global"), 
jtulach@104
    57
            "THREAD: main MSG: Begin" +
jtulach@104
    58
            "THREAD: .*AWT.* MSG: In.*thread" +
jtulach@104
    59
            "THREAD: main MSG: Will create JLabel" +
jtulach@104
    60
            "THREAD: .*AWT.* MSG: Will create JLabel", 
jtulach@104
    61
            300
jtulach@104
    62
        );
jtulach@104
    63
        
jtulach@104
    64
        R showFrame = new R();
jtulach@104
    65
        SwingUtilities.invokeLater(showFrame);
jtulach@104
    66
        
jtulach@104
    67
        LOG.info("Begin");
jtulach@104
    68
        JLabel result = instance.createLabel();
jtulach@104
    69
        assertNotNull("Creates the result", result);
jtulach@104
    70
    }
jtulach@104
    71
jtulach@105
    72
}
jtulach@105
    73
// END: deadlock.test.controlflow
jtulach@105
    74