forked from DrJavaAtRice/drjava
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDrJavaTestCase.java
More file actions
109 lines (96 loc) · 5.03 KB
/
DrJavaTestCase.java
File metadata and controls
109 lines (96 loc) · 5.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*BEGIN_COPYRIGHT_BLOCK
*
* Copyright (c) 2001-2019, JavaPLT group at Rice University (drjava@rice.edu). All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
* following conditions are met:
* * Redistributions of source code must retain the above copyright notice, this list of conditions and the following
* disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the
* following disclaimer in the documentation and/or other materials provided with the distribution.
* * Neither the names of DrJava, the JavaPLT group, Rice University, nor the names of its contributors may be used
* to endorse or promote products derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software is Open Source Initiative approved Open Source Software. Open Source Initative Approved is a trademark
* of the Open Source Initiative.
*
* This file is part of DrJava. Download the current version of this project from http://www.drjava.org/ or
* http://sourceforge.net/projects/drjava/
*
* END_COPYRIGHT_BLOCK*/
package edu.rice.cs.drjava;
import javax.swing.text.BadLocationException;
import junit.framework.TestCase;
import edu.rice.cs.drjava.config.Option;
import edu.rice.cs.drjava.model.AbstractDJDocument;
import edu.rice.cs.util.UnexpectedException;
import edu.rice.cs.util.swing.Utilities;
import edu.rice.cs.util.Log;
/** Test case class for all DrJava test cases. DrJava test cases should extend this class, potentially override setUp()
* and tearDown(), but make sure to invoke super.setUp() and super.tearDown() appropriately. That ensures that the
* system is correctly initialized for every test.
*/
public class DrJavaTestCase extends TestCase {
/** Create a new DrJava test case. */
/** Normal default constructor; required because unary constructor is declared below. */
public DrJavaTestCase() { super(); }
/** Create a new DrJava test case.
* @param name name of the test case
*/
public DrJavaTestCase(String name) { super(name); }
private static Log _log = new Log("DrJavaTestCase.txt", false);
/** Set up for every test.
* @throws Exception This convention is mandated by JUnit.TestCase, the superclass of this class.
*/
protected void setUp() throws Exception {
super.setUp(); // declared to throw Exception, forcing throws clause on preceding line
Utilities.TEST_MODE = true;
final String newName = System.getProperty("drjava.test.config");
assert newName != null;
// Utilities.show("newName = '" + newName + "'");
if (newName != null) { // in deployed code, assertion checking may be turned off
Utilities.invokeAndWait(new Runnable() {
public void run() {
DrJava.setPropertiesFile(newName); // spawns change updates which should run in event thread
// Utilities.clearEventQueue();
DrJava._initConfig(); // spawns change updates which should run in event thread
}
});
}
}
/** Clean up for every test case. Only used in unit tests. Added because Windows would intermittently throw
* a java.util.concurrent.RejectedExecutionException during cleanup.
* @throws Exception if an exception occurs during cleanup
*/
protected void tearDown() throws Exception {
DrJava.cleanUp();
super.tearDown();
}
protected <T> void setConfigSetting(final Option<T> op, final T value) {
Utilities.invokeAndWait(new Runnable() { public void run() { DrJava.getConfig().setSetting(op, value); } });
}
/** Clears the text of the _doc field and sets it to the given string.
* @param doc the document whose text should be set to "text"
* @param text the text to set
*/
protected static final void setDocText(final AbstractDJDocument doc, final String text) {
Utilities.invokeAndWait(new Runnable() {
public void run() {
try {
doc.clear();
doc.insertString(0, text, null);
}
catch(BadLocationException e) { throw new UnexpectedException(e); }
}
});
Utilities.clearEventQueue(); // ensure that all listener actions triggered by this document update have completed
}
}