blob: bcb65b8063430c99f09479af03c726da4ff99697 (
plain)
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
|
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
package ifc.text;
import lib.MultiMethodTest;
import com.sun.star.text.XTextContent;
import com.sun.star.text.XTextRange;
/**
* Testing <code>com.sun.star.text.XTextContent</code>
* interface methods :
* <ul>
* <li><code> attach()</code></li>
* <li><code> getAnchor()</code></li>
* </ul> <p>
* This test needs the following object relations :
* <ul>
* <li> <code>'CONTENT'</code> <b>optional</b>
* (of type <code>XTextContent</code>):
* if this relation exists than it is used as the
* tested object. </li>
* <li> <code>'TEXT'</code> <b>optional</b>
* (of type <code>XText</code>):
* the relation must be specified if the 'CONTENT'
* relation exists. From this relation an anchor
* for <code>attach()</code> method is obtained.</li>
* <ul> <p>
* Test is <b> NOT </b> multithread compliant. <p>
* @see com.sun.star.text.XTextContent
*/
public class _XTextContent extends MultiMethodTest {
public XTextContent oObj = null;
public XTextRange oAnchor = null;
/**
* Tries to get the anchor of the text content
* an XTextRange is returned. <p>
* The test is OK if a not null text range is returned
*/
public void _getAnchor() {
log.println("getAnchor()");
oAnchor = oObj.getAnchor();
tRes.tested("getAnchor()", oAnchor != null ) ;
} // end getAnchor()
/**
* Tries to attach the text content to the test range
* gotten with getAnchor(). If relations are found
* then they are used for testing. <p>
*
* The test is OK if the method works without error.
* @see #_getAnchor()
*/
public void _attach() {
requiredMethod("getAnchor()");
try {
XTextContent aContent = (XTextContent) tEnv.getObjRelation("CONTENT");
XTextRange aRange = (XTextRange) tEnv.getObjRelation("RANGE");
if ( aContent !=null) {
aContent.attach(aRange);
} else {
oObj.attach(aRange);
}
tRes.tested("attach()", true ) ;
}
catch (com.sun.star.lang.IllegalArgumentException ex) {
String noAttach = (String) tEnv.getObjRelation("NoAttach");
if (noAttach != null) {
log.println("Exception expected for "+noAttach);
log.println("This Component doesn't support attach");
tRes.tested("attach()",true);
} else {
ex.printStackTrace(log);
tRes.tested("attach()",false);
}
} catch (com.sun.star.uno.RuntimeException re) {
String noAttach = (String) tEnv.getObjRelation("NoAttach");
if (noAttach != null) {
log.println("Exception expected for "+noAttach);
log.println("This Component doesn't support attach");
tRes.tested("attach()",true);
} else {
re.printStackTrace(log);
tRes.tested("attach()",false);
}
}
}
}
|