7184365: closed/java/awt/event/TextEvent/TextEventSequenceTest/TextEventSequenceTest fails
Reviewed-by: serb, bagiras
This commit is contained in:
parent
3851c96f71
commit
26f36a5cd0
@ -128,16 +128,6 @@ final class LWTextAreaPeer
|
||||
repaintPeer();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setText(final String l) {
|
||||
// Please note that we do not want to post an event
|
||||
// if TextArea.setText() replaces an empty text by an empty text,
|
||||
// that is, if component's text remains unchanged.
|
||||
if (!l.isEmpty() || getTextComponent().getDocument().getLength() != 0) {
|
||||
super.setText(l);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void replaceRange(final String text, final int start,
|
||||
final int end) {
|
||||
|
@ -124,7 +124,7 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setText(final String l) {
|
||||
public final void setText(final String l) {
|
||||
synchronized (getDelegateLock()) {
|
||||
// JTextArea.setText() posts two different events (remove & insert).
|
||||
// Since we make no differences between text events,
|
||||
|
@ -235,9 +235,14 @@ public class TextComponent extends Component implements Accessible {
|
||||
* @see java.awt.TextComponent#getText
|
||||
*/
|
||||
public synchronized void setText(String t) {
|
||||
boolean skipTextEvent = (text == null || text.isEmpty())
|
||||
&& (t == null || t.isEmpty());
|
||||
text = (t != null) ? t : "";
|
||||
TextComponentPeer peer = (TextComponentPeer)this.peer;
|
||||
if (peer != null) {
|
||||
// Please note that we do not want to post an event
|
||||
// if TextArea.setText() or TextField.setText() replaces an empty text
|
||||
// by an empty text, that is, if component's text remains unchanged.
|
||||
if (peer != null && !skipTextEvent) {
|
||||
peer.setText(text);
|
||||
}
|
||||
}
|
||||
|
@ -463,13 +463,6 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
|
||||
|
||||
protected boolean setTextImpl(String txt) {
|
||||
if (jtext != null) {
|
||||
// Please note that we do not want to post an event
|
||||
// if setText() replaces an empty text by an empty text,
|
||||
// that is, if component's text remains unchanged.
|
||||
if (jtext.getDocument().getLength() == 0 && txt.length() == 0) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// JTextArea.setText() posts two different events (remove & insert).
|
||||
// Since we make no differences between text events,
|
||||
// the document listener has to be disabled while
|
||||
|
@ -0,0 +1,138 @@
|
||||
/*
|
||||
* Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||
*
|
||||
* This code is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License version 2 only, as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* This code 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
|
||||
* version 2 for more details (a copy is included in the LICENSE file that
|
||||
* accompanied this code).
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License version
|
||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||
* or visit www.oracle.com if you need additional information or have any
|
||||
* questions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* @test
|
||||
* @bug 4028580
|
||||
* @summary TextArea does not send TextEvent when setText. Does for insert
|
||||
* @author kdm@sparc.spb.su: area= awt.TextAvent
|
||||
* @run main TextEventSequenceTest
|
||||
*/
|
||||
import java.awt.*;
|
||||
import java.awt.event.*;
|
||||
import sun.awt.SunToolkit;
|
||||
|
||||
public class TextEventSequenceTest {
|
||||
|
||||
private static Frame f;
|
||||
private static TextField tf;
|
||||
private static TextArea t;
|
||||
private static int cntEmptyStrings = 0;
|
||||
private static int cntNonEmptyStrings = 0;
|
||||
|
||||
public static void main(String[] args) {
|
||||
|
||||
test("non-empty text string");
|
||||
test("");
|
||||
test(null);
|
||||
}
|
||||
|
||||
private static void test(String test) {
|
||||
SunToolkit toolkit = (SunToolkit) Toolkit.getDefaultToolkit();
|
||||
|
||||
createAndShowGUI(test);
|
||||
toolkit.realSync();
|
||||
|
||||
initCounts();
|
||||
t.setText("Hello ");
|
||||
toolkit.realSync();
|
||||
t.append("World! !");
|
||||
toolkit.realSync();
|
||||
t.insert("from Roger Pham", 13);
|
||||
toolkit.realSync();
|
||||
t.replaceRange("Java Duke", 18, 28);
|
||||
toolkit.realSync();
|
||||
checkCounts(0, 4);
|
||||
|
||||
initCounts();
|
||||
t.setText("");
|
||||
toolkit.realSync();
|
||||
t.setText("");
|
||||
toolkit.realSync();
|
||||
t.setText("");
|
||||
toolkit.realSync();
|
||||
checkCounts(1, 0);
|
||||
|
||||
initCounts();
|
||||
tf.setText("Hello There!");
|
||||
toolkit.realSync();
|
||||
checkCounts(0, 1);
|
||||
|
||||
initCounts();
|
||||
tf.setText("");
|
||||
toolkit.realSync();
|
||||
tf.setText("");
|
||||
toolkit.realSync();
|
||||
tf.setText("");
|
||||
toolkit.realSync();
|
||||
checkCounts(1, 0);
|
||||
|
||||
f.dispose();
|
||||
}
|
||||
|
||||
private static void createAndShowGUI(String text) {
|
||||
f = new Frame("TextEventSequenceTest");
|
||||
f.setLayout(new FlowLayout());
|
||||
|
||||
TextListener listener = new MyTextListener();
|
||||
|
||||
tf = new TextField(text);
|
||||
tf.addTextListener(listener);
|
||||
f.add(tf);
|
||||
|
||||
t = new TextArea(text, 10, 30);
|
||||
t.addTextListener(listener);
|
||||
f.add(t);
|
||||
|
||||
f.pack();
|
||||
f.setVisible(true);
|
||||
}
|
||||
|
||||
static class MyTextListener implements TextListener {
|
||||
|
||||
public synchronized void textValueChanged(TextEvent e) {
|
||||
TextComponent tc = (TextComponent) e.getSource();
|
||||
String text = tc.getText();
|
||||
if (text.length() == 0) {
|
||||
cntEmptyStrings++;
|
||||
} else {
|
||||
cntNonEmptyStrings++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
synchronized static void initCounts() {
|
||||
cntEmptyStrings = 0;
|
||||
cntNonEmptyStrings = 0;
|
||||
}
|
||||
|
||||
synchronized static void checkCounts(int empty, int nonempty) {
|
||||
if (empty != cntEmptyStrings || nonempty != cntNonEmptyStrings) {
|
||||
throw new RuntimeException(
|
||||
String.format("Expected events: empty = %d, nonempty = %d, "
|
||||
+ "actual events: empty = %d, nonempty = %d",
|
||||
empty, nonempty, cntEmptyStrings, cntNonEmptyStrings));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user