01: /* ====================================================================
02: The Jicarilla Software License
03:
04: Copyright (c) 2003 Leo Simons.
05: All rights reserved.
06:
07: Permission is hereby granted, free of charge, to any person obtaining
08: a copy of this software and associated documentation files (the
09: "Software"), to deal in the Software without restriction, including
10: without limitation the rights to use, copy, modify, merge, publish,
11: distribute, sublicense, and/or sell copies of the Software, and to
12: permit persons to whom the Software is furnished to do so, subject to
13: the following conditions:
14:
15: The above copyright notice and this permission notice shall be
16: included in all copies or substantial portions of the Software.
17:
18: THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19: EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20: MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
21: IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
22: CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23: TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24: SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25: ==================================================================== */
26: package org.jicarilla.lang.test;
27:
28: import org.jicarilla.lang.AbstractReadonlyEnabled;
29: import junit.framework.TestCase;
30:
31: /**
32: * <a href="http://www.junit.org/">JUnit</a> {@link TestCase testcase} for
33: * AbstractReadonlyEnabled.
34: *
35: * @author <a href="lsimons at jicarilla dot org">Leo Simons</a>
36: * @version $Id: AbstracReadonlyEnabledTestCase.java,v 1.1 2003/11/17 21:11:10
37: * lsimons Exp $
38: */
39: public class AbstracReadonlyEnabledTestCase extends TestCase {
40: public static class Readonly extends AbstractReadonlyEnabled {
41: public void makeReadOnly() {
42: super .makeReadOnly();
43: }
44:
45: /**
46: * Determine whether makeReadOnly() has been called.
47: */
48: protected boolean isReadOnly() {
49: return super .isReadOnly();
50: }
51:
52: /**
53: * Throw an IllegalStateException if makeReadOnly() has been called.
54: */
55: protected void checkReadOnly() {
56: super .checkReadOnly();
57: }
58: }
59:
60: public void testIsReadonly() {
61: Readonly r = new Readonly();
62: assertFalse(r.isReadOnly());
63:
64: r.makeReadOnly();
65: assertTrue(r.isReadOnly());
66:
67: // multiple
68: r.makeReadOnly();
69: r.makeReadOnly();
70: r.makeReadOnly();
71: r.makeReadOnly();
72: assertTrue(r.isReadOnly());
73:
74: }
75:
76: public void testCheckReadonly() {
77: Readonly r = new Readonly();
78: r.checkReadOnly();
79:
80: // multiple
81: r.checkReadOnly();
82: r.checkReadOnly();
83: r.checkReadOnly();
84: r.checkReadOnly();
85:
86: r.makeReadOnly();
87:
88: // multiple
89: for (int i = 0; i < 5; i++) {
90: IllegalStateException ise = null;
91: try {
92: r.checkReadOnly();
93: } catch (IllegalStateException e) {
94: ise = e;
95: }
96: assertNotNull(ise);
97: }
98: }
99: }
|