Revision 35017
tags/v2_0_0_Build_2025/applications/appgvSIG/gpl.txt | ||
---|---|---|
1 |
GNU GENERAL PUBLIC LICENSE |
|
2 |
Version 2, June 1991 |
|
3 |
|
|
4 |
Copyright (C) 1989, 1991 Free Software Foundation, Inc. |
|
5 |
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
6 |
Everyone is permitted to copy and distribute verbatim copies |
|
7 |
of this license document, but changing it is not allowed. |
|
8 |
|
|
9 |
Preamble |
|
10 |
|
|
11 |
The licenses for most software are designed to take away your |
|
12 |
freedom to share and change it. By contrast, the GNU General Public |
|
13 |
License is intended to guarantee your freedom to share and change free |
|
14 |
software--to make sure the software is free for all its users. This |
|
15 |
General Public License applies to most of the Free Software |
|
16 |
Foundation's software and to any other program whose authors commit to |
|
17 |
using it. (Some other Free Software Foundation software is covered by |
|
18 |
the GNU Library General Public License instead.) You can apply it to |
|
19 |
your programs, too. |
|
20 |
|
|
21 |
When we speak of free software, we are referring to freedom, not |
|
22 |
price. Our General Public Licenses are designed to make sure that you |
|
23 |
have the freedom to distribute copies of free software (and charge for |
|
24 |
this service if you wish), that you receive source code or can get it |
|
25 |
if you want it, that you can change the software or use pieces of it |
|
26 |
in new free programs; and that you know you can do these things. |
|
27 |
|
|
28 |
To protect your rights, we need to make restrictions that forbid |
|
29 |
anyone to deny you these rights or to ask you to surrender the rights. |
|
30 |
These restrictions translate to certain responsibilities for you if you |
|
31 |
distribute copies of the software, or if you modify it. |
|
32 |
|
|
33 |
For example, if you distribute copies of such a program, whether |
|
34 |
gratis or for a fee, you must give the recipients all the rights that |
|
35 |
you have. You must make sure that they, too, receive or can get the |
|
36 |
source code. And you must show them these terms so they know their |
|
37 |
rights. |
|
38 |
|
|
39 |
We protect your rights with two steps: (1) copyright the software, and |
|
40 |
(2) offer you this license which gives you legal permission to copy, |
|
41 |
distribute and/or modify the software. |
|
42 |
|
|
43 |
Also, for each author's protection and ours, we want to make certain |
|
44 |
that everyone understands that there is no warranty for this free |
|
45 |
software. If the software is modified by someone else and passed on, we |
|
46 |
want its recipients to know that what they have is not the original, so |
|
47 |
that any problems introduced by others will not reflect on the original |
|
48 |
authors' reputations. |
|
49 |
|
|
50 |
Finally, any free program is threatened constantly by software |
|
51 |
patents. We wish to avoid the danger that redistributors of a free |
|
52 |
program will individually obtain patent licenses, in effect making the |
|
53 |
program proprietary. To prevent this, we have made it clear that any |
|
54 |
patent must be licensed for everyone's free use or not licensed at all. |
|
55 |
|
|
56 |
The precise terms and conditions for copying, distribution and |
|
57 |
modification follow. |
|
58 |
|
|
59 |
GNU GENERAL PUBLIC LICENSE |
|
60 |
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION |
|
61 |
|
|
62 |
0. This License applies to any program or other work which contains |
|
63 |
a notice placed by the copyright holder saying it may be distributed |
|
64 |
under the terms of this General Public License. The "Program", below, |
|
65 |
refers to any such program or work, and a "work based on the Program" |
|
66 |
means either the Program or any derivative work under copyright law: |
|
67 |
that is to say, a work containing the Program or a portion of it, |
|
68 |
either verbatim or with modifications and/or translated into another |
|
69 |
language. (Hereinafter, translation is included without limitation in |
|
70 |
the term "modification".) Each licensee is addressed as "you". |
|
71 |
|
|
72 |
Activities other than copying, distribution and modification are not |
|
73 |
covered by this License; they are outside its scope. The act of |
|
74 |
running the Program is not restricted, and the output from the Program |
|
75 |
is covered only if its contents constitute a work based on the |
|
76 |
Program (independent of having been made by running the Program). |
|
77 |
Whether that is true depends on what the Program does. |
|
78 |
|
|
79 |
1. You may copy and distribute verbatim copies of the Program's |
|
80 |
source code as you receive it, in any medium, provided that you |
|
81 |
conspicuously and appropriately publish on each copy an appropriate |
|
82 |
copyright notice and disclaimer of warranty; keep intact all the |
|
83 |
notices that refer to this License and to the absence of any warranty; |
|
84 |
and give any other recipients of the Program a copy of this License |
|
85 |
along with the Program. |
|
86 |
|
|
87 |
You may charge a fee for the physical act of transferring a copy, and |
|
88 |
you may at your option offer warranty protection in exchange for a fee. |
|
89 |
|
|
90 |
2. You may modify your copy or copies of the Program or any portion |
|
91 |
of it, thus forming a work based on the Program, and copy and |
|
92 |
distribute such modifications or work under the terms of Section 1 |
|
93 |
above, provided that you also meet all of these conditions: |
|
94 |
|
|
95 |
a) You must cause the modified files to carry prominent notices |
|
96 |
stating that you changed the files and the date of any change. |
|
97 |
|
|
98 |
b) You must cause any work that you distribute or publish, that in |
|
99 |
whole or in part contains or is derived from the Program or any |
|
100 |
part thereof, to be licensed as a whole at no charge to all third |
|
101 |
parties under the terms of this License. |
|
102 |
|
|
103 |
c) If the modified program normally reads commands interactively |
|
104 |
when run, you must cause it, when started running for such |
|
105 |
interactive use in the most ordinary way, to print or display an |
|
106 |
announcement including an appropriate copyright notice and a |
|
107 |
notice that there is no warranty (or else, saying that you provide |
|
108 |
a warranty) and that users may redistribute the program under |
|
109 |
these conditions, and telling the user how to view a copy of this |
|
110 |
License. (Exception: if the Program itself is interactive but |
|
111 |
does not normally print such an announcement, your work based on |
|
112 |
the Program is not required to print an announcement.) |
|
113 |
|
|
114 |
These requirements apply to the modified work as a whole. If |
|
115 |
identifiable sections of that work are not derived from the Program, |
|
116 |
and can be reasonably considered independent and separate works in |
|
117 |
themselves, then this License, and its terms, do not apply to those |
|
118 |
sections when you distribute them as separate works. But when you |
|
119 |
distribute the same sections as part of a whole which is a work based |
|
120 |
on the Program, the distribution of the whole must be on the terms of |
|
121 |
this License, whose permissions for other licensees extend to the |
|
122 |
entire whole, and thus to each and every part regardless of who wrote it. |
|
123 |
|
|
124 |
Thus, it is not the intent of this section to claim rights or contest |
|
125 |
your rights to work written entirely by you; rather, the intent is to |
|
126 |
exercise the right to control the distribution of derivative or |
|
127 |
collective works based on the Program. |
|
128 |
|
|
129 |
In addition, mere aggregation of another work not based on the Program |
|
130 |
with the Program (or with a work based on the Program) on a volume of |
|
131 |
a storage or distribution medium does not bring the other work under |
|
132 |
the scope of this License. |
|
133 |
|
|
134 |
3. You may copy and distribute the Program (or a work based on it, |
|
135 |
under Section 2) in object code or executable form under the terms of |
|
136 |
Sections 1 and 2 above provided that you also do one of the following: |
|
137 |
|
|
138 |
a) Accompany it with the complete corresponding machine-readable |
|
139 |
source code, which must be distributed under the terms of Sections |
|
140 |
1 and 2 above on a medium customarily used for software interchange; or, |
|
141 |
|
|
142 |
b) Accompany it with a written offer, valid for at least three |
|
143 |
years, to give any third party, for a charge no more than your |
|
144 |
cost of physically performing source distribution, a complete |
|
145 |
machine-readable copy of the corresponding source code, to be |
|
146 |
distributed under the terms of Sections 1 and 2 above on a medium |
|
147 |
customarily used for software interchange; or, |
|
148 |
|
|
149 |
c) Accompany it with the information you received as to the offer |
|
150 |
to distribute corresponding source code. (This alternative is |
|
151 |
allowed only for noncommercial distribution and only if you |
|
152 |
received the program in object code or executable form with such |
|
153 |
an offer, in accord with Subsection b above.) |
|
154 |
|
|
155 |
The source code for a work means the preferred form of the work for |
|
156 |
making modifications to it. For an executable work, complete source |
|
157 |
code means all the source code for all modules it contains, plus any |
|
158 |
associated interface definition files, plus the scripts used to |
|
159 |
control compilation and installation of the executable. However, as a |
|
160 |
special exception, the source code distributed need not include |
|
161 |
anything that is normally distributed (in either source or binary |
|
162 |
form) with the major components (compiler, kernel, and so on) of the |
|
163 |
operating system on which the executable runs, unless that component |
|
164 |
itself accompanies the executable. |
|
165 |
|
|
166 |
If distribution of executable or object code is made by offering |
|
167 |
access to copy from a designated place, then offering equivalent |
|
168 |
access to copy the source code from the same place counts as |
|
169 |
distribution of the source code, even though third parties are not |
|
170 |
compelled to copy the source along with the object code. |
|
171 |
|
|
172 |
4. You may not copy, modify, sublicense, or distribute the Program |
|
173 |
except as expressly provided under this License. Any attempt |
|
174 |
otherwise to copy, modify, sublicense or distribute the Program is |
|
175 |
void, and will automatically terminate your rights under this License. |
|
176 |
However, parties who have received copies, or rights, from you under |
|
177 |
this License will not have their licenses terminated so long as such |
|
178 |
parties remain in full compliance. |
|
179 |
|
|
180 |
5. You are not required to accept this License, since you have not |
|
181 |
signed it. However, nothing else grants you permission to modify or |
|
182 |
distribute the Program or its derivative works. These actions are |
|
183 |
prohibited by law if you do not accept this License. Therefore, by |
|
184 |
modifying or distributing the Program (or any work based on the |
|
185 |
Program), you indicate your acceptance of this License to do so, and |
|
186 |
all its terms and conditions for copying, distributing or modifying |
|
187 |
the Program or works based on it. |
|
188 |
|
|
189 |
6. Each time you redistribute the Program (or any work based on the |
|
190 |
Program), the recipient automatically receives a license from the |
|
191 |
original licensor to copy, distribute or modify the Program subject to |
|
192 |
these terms and conditions. You may not impose any further |
|
193 |
restrictions on the recipients' exercise of the rights granted herein. |
|
194 |
You are not responsible for enforcing compliance by third parties to |
|
195 |
this License. |
|
196 |
|
|
197 |
7. If, as a consequence of a court judgment or allegation of patent |
|
198 |
infringement or for any other reason (not limited to patent issues), |
|
199 |
conditions are imposed on you (whether by court order, agreement or |
|
200 |
otherwise) that contradict the conditions of this License, they do not |
|
201 |
excuse you from the conditions of this License. If you cannot |
|
202 |
distribute so as to satisfy simultaneously your obligations under this |
|
203 |
License and any other pertinent obligations, then as a consequence you |
|
204 |
may not distribute the Program at all. For example, if a patent |
|
205 |
license would not permit royalty-free redistribution of the Program by |
|
206 |
all those who receive copies directly or indirectly through you, then |
|
207 |
the only way you could satisfy both it and this License would be to |
|
208 |
refrain entirely from distribution of the Program. |
|
209 |
|
|
210 |
If any portion of this section is held invalid or unenforceable under |
|
211 |
any particular circumstance, the balance of the section is intended to |
|
212 |
apply and the section as a whole is intended to apply in other |
|
213 |
circumstances. |
|
214 |
|
|
215 |
It is not the purpose of this section to induce you to infringe any |
|
216 |
patents or other property right claims or to contest validity of any |
|
217 |
such claims; this section has the sole purpose of protecting the |
|
218 |
integrity of the free software distribution system, which is |
|
219 |
implemented by public license practices. Many people have made |
|
220 |
generous contributions to the wide range of software distributed |
|
221 |
through that system in reliance on consistent application of that |
|
222 |
system; it is up to the author/donor to decide if he or she is willing |
|
223 |
to distribute software through any other system and a licensee cannot |
|
224 |
impose that choice. |
|
225 |
|
|
226 |
This section is intended to make thoroughly clear what is believed to |
|
227 |
be a consequence of the rest of this License. |
|
228 |
|
|
229 |
8. If the distribution and/or use of the Program is restricted in |
|
230 |
certain countries either by patents or by copyrighted interfaces, the |
|
231 |
original copyright holder who places the Program under this License |
|
232 |
may add an explicit geographical distribution limitation excluding |
|
233 |
those countries, so that distribution is permitted only in or among |
|
234 |
countries not thus excluded. In such case, this License incorporates |
|
235 |
the limitation as if written in the body of this License. |
|
236 |
|
|
237 |
9. The Free Software Foundation may publish revised and/or new versions |
|
238 |
of the General Public License from time to time. Such new versions will |
|
239 |
be similar in spirit to the present version, but may differ in detail to |
|
240 |
address new problems or concerns. |
|
241 |
|
|
242 |
Each version is given a distinguishing version number. If the Program |
|
243 |
specifies a version number of this License which applies to it and "any |
|
244 |
later version", you have the option of following the terms and conditions |
|
245 |
either of that version or of any later version published by the Free |
|
246 |
Software Foundation. If the Program does not specify a version number of |
|
247 |
this License, you may choose any version ever published by the Free Software |
|
248 |
Foundation. |
|
249 |
|
|
250 |
10. If you wish to incorporate parts of the Program into other free |
|
251 |
programs whose distribution conditions are different, write to the author |
|
252 |
to ask for permission. For software which is copyrighted by the Free |
|
253 |
Software Foundation, write to the Free Software Foundation; we sometimes |
|
254 |
make exceptions for this. Our decision will be guided by the two goals |
|
255 |
of preserving the free status of all derivatives of our free software and |
|
256 |
of promoting the sharing and reuse of software generally. |
|
257 |
|
|
258 |
NO WARRANTY |
|
259 |
|
|
260 |
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY |
|
261 |
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN |
|
262 |
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES |
|
263 |
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED |
|
264 |
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
|
265 |
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS |
|
266 |
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE |
|
267 |
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, |
|
268 |
REPAIR OR CORRECTION. |
|
269 |
|
|
270 |
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING |
|
271 |
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR |
|
272 |
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, |
|
273 |
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING |
|
274 |
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED |
|
275 |
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY |
|
276 |
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER |
|
277 |
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE |
|
278 |
POSSIBILITY OF SUCH DAMAGES. |
|
279 |
|
|
280 |
END OF TERMS AND CONDITIONS |
|
281 |
|
|
282 |
How to Apply These Terms to Your New Programs |
|
283 |
|
|
284 |
If you develop a new program, and you want it to be of the greatest |
|
285 |
possible use to the public, the best way to achieve this is to make it |
|
286 |
free software which everyone can redistribute and change under these terms. |
|
287 |
|
|
288 |
To do so, attach the following notices to the program. It is safest |
|
289 |
to attach them to the start of each source file to most effectively |
|
290 |
convey the exclusion of warranty; and each file should have at least |
|
291 |
the "copyright" line and a pointer to where the full notice is found. |
|
292 |
|
|
293 |
<one line to give the program's name and a brief idea of what it does.> |
|
294 |
Copyright (C) <year> <name of author> |
|
295 |
|
|
296 |
This program is free software; you can redistribute it and/or modify |
|
297 |
it under the terms of the GNU General Public License as published by |
|
298 |
the Free Software Foundation; either version 2 of the License, or |
|
299 |
(at your option) any later version. |
|
300 |
|
|
301 |
This program is distributed in the hope that it will be useful, |
|
302 |
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
303 |
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
304 |
GNU General Public License for more details. |
|
305 |
|
|
306 |
You should have received a copy of the GNU General Public License |
|
307 |
along with this program; if not, write to the Free Software |
|
308 |
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
309 |
|
|
310 |
|
|
311 |
Also add information on how to contact you by electronic and paper mail. |
|
312 |
|
|
313 |
If the program is interactive, make it output a short notice like this |
|
314 |
when it starts in an interactive mode: |
|
315 |
|
|
316 |
Gnomovision version 69, Copyright (C) year name of author |
|
317 |
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. |
|
318 |
This is free software, and you are welcome to redistribute it |
|
319 |
under certain conditions; type `show c' for details. |
|
320 |
|
|
321 |
The hypothetical commands `show w' and `show c' should show the appropriate |
|
322 |
parts of the General Public License. Of course, the commands you use may |
|
323 |
be called something other than `show w' and `show c'; they could even be |
|
324 |
mouse-clicks or menu items--whatever suits your program. |
|
325 |
|
|
326 |
You should also get your employer (if you work as a programmer) or your |
|
327 |
school, if any, to sign a "copyright disclaimer" for the program, if |
|
328 |
necessary. Here is a sample; alter the names: |
|
329 |
|
|
330 |
Yoyodyne, Inc., hereby disclaims all copyright interest in the program |
|
331 |
`Gnomovision' (which makes passes at compilers) written by James Hacker. |
|
332 |
|
|
333 |
<signature of Ty Coon>, 1 April 1989 |
|
334 |
Ty Coon, President of Vice |
|
335 |
|
|
336 |
This General Public License does not permit incorporating your program into |
|
337 |
proprietary programs. If your program is a subroutine library, you may |
|
338 |
consider it more useful to permit linking proprietary applications with the |
|
339 |
library. If this is what you want to do, use the GNU Library General |
|
340 |
Public License instead of this License. |
|
0 | 341 |
tags/v2_0_0_Build_2025/applications/appgvSIG/buildNumber.properties | ||
---|---|---|
1 |
#maven.buildNumber.plugin properties file |
|
2 |
#Thu May 05 17:07:38 CEST 2011 |
|
3 |
buildNumber=2025 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/test/Persistence.java | ||
---|---|---|
1 |
package org.gvsig.app.test; |
|
2 |
|
|
3 |
import junit.framework.TestCase; |
|
4 |
|
|
5 |
import org.gvsig.app.extension.ProjectExtension; |
|
6 |
|
|
7 |
/** |
|
8 |
* @author Fernando Gonz?lez Cort?s |
|
9 |
*/ |
|
10 |
//TODO comentado para que compile |
|
11 |
public class Persistence extends TestCase { |
|
12 |
private ProjectExtension pe; |
|
13 |
|
|
14 |
/* |
|
15 |
* @see TestCase#setUp() |
|
16 |
*/ |
|
17 |
protected void setUp() throws Exception { |
|
18 |
pe = new ProjectExtension(); |
|
19 |
// pe.inicializar(); |
|
20 |
// LayerFactory.setDriversPath( |
|
21 |
// "/root/workspace/Andami/gvSIG/extensiones/com.iver.cit.gvsig/drivers"); |
|
22 |
// |
|
23 |
// LayerFactory.getDataSourceFactory().addFileDataSource("gdbms dbf driver", "prueba", |
|
24 |
// "test/cities.dbf"); |
|
25 |
|
|
26 |
} |
|
27 |
|
|
28 |
public void testPersist() throws Throwable { |
|
29 |
// Project p = new Project(); |
|
30 |
// |
|
31 |
// /* |
|
32 |
// * A?adimos una vista con una capa |
|
33 |
// */ |
|
34 |
// ProjectView v = new ProjectView(); |
|
35 |
// ViewPort vp = new ViewPort( CRSFactory.getCRS("EPSG:23030")); |
|
36 |
// vp.setImageSize(new Dimension(500, 500)); |
|
37 |
// |
|
38 |
// MapContext fmap = new MapContext(vp); |
|
39 |
// v.setMapContext(fmap); |
|
40 |
// FLayer l = LayerFactory.createLayer("Vias", |
|
41 |
// (VectorialFileDriver) LayerFactory.getDM().getDriver("gvSIG shp driver"), |
|
42 |
// new File("test/cities.shp"), |
|
43 |
// CRSFactory.getCRS("EPSG:23030")); |
|
44 |
// fmap.getLayers().addLayer(l); |
|
45 |
// |
|
46 |
// /* |
|
47 |
// * A?adimos la tabla del tema anterior |
|
48 |
// */ |
|
49 |
// SelectableDataSource sds1 = ((FLyrVect) l).getRecordset(); |
|
50 |
// EditableAdapter ea1 = new EditableAdapter(); |
|
51 |
// ea1.setOriginalDataSource(sds1); |
|
52 |
// |
|
53 |
// ProjectTable pt1 = ProjectFactory.createTable("tabla", ea1); |
|
54 |
// p.addDocument(pt1); |
|
55 |
// |
|
56 |
// /* |
|
57 |
// * A?adimos otra tabla |
|
58 |
// */ |
|
59 |
// SelectableDataSource sds2 = new SelectableDataSource(LayerFactory.getDataSourceFactory().createRandomDataSource("prueba", DataSourceFactory.MANUAL_OPENING)); |
|
60 |
// EditableAdapter ea2 = new EditableAdapter(); |
|
61 |
// ea2.setOriginalDataSource(sds2); |
|
62 |
// ProjectTable pt2 = ProjectFactory.createTable("tabla2", ea2); |
|
63 |
// p.addTable(pt2); |
|
64 |
// |
|
65 |
// /* |
|
66 |
// * Creamos un join |
|
67 |
// */ |
|
68 |
// String sql = "custom com_iver_cit_gvsig_arcjoin tables '"+ |
|
69 |
// sds1.getName()+"', '"+sds1.getName()+"' values(NAME,NAME);"; |
|
70 |
// |
|
71 |
// SelectableDataSource result = new SelectableDataSource( |
|
72 |
// LayerFactory.getDataSourceFactory() |
|
73 |
// .executeSQL(sql, DataSourceFactory.MANUAL_OPENING)); |
|
74 |
// EditableAdapter auxea=new EditableAdapter(); |
|
75 |
// auxea.setOriginalDataSource(result); |
|
76 |
// |
|
77 |
// pt1.replaceDataSource(auxea); |
|
78 |
// |
|
79 |
// /* |
|
80 |
// * Guardamos y cargamos |
|
81 |
// */ |
|
82 |
// File temp = File.createTempFile("junit-", ".gvp"); |
|
83 |
// temp.deleteOnExit(); |
|
84 |
// pe.writeProject(temp, p); |
|
85 |
// |
|
86 |
// Project p2 = pe.readProject(temp); |
|
87 |
// |
|
88 |
// /* |
|
89 |
// * Comprobamos que las dos tablas son id?nticas |
|
90 |
// */ |
|
91 |
// assertTrue(((ProjectTable)p2.getDocumentsByType(ProjectTableFactory.registerName).get(0)).getModel().getRecordset().getAsString().equals(((ProjectTable)p.getTables().get(0)).getModel().getRecordset().getAsString())); |
|
92 |
// assertTrue(((ProjectTable)p2.getDocumentsByType(ProjectTableFactory.registerName).get(1)).getModel().getRecordset().getAsString().equals(((ProjectTable)p.getTables().get(1)).getModel().getRecordset().getAsString())); |
|
93 |
} |
|
94 |
} |
|
0 | 95 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/sqlQueryValidation/TestSQLQueryValidation.java | ||
---|---|---|
1 |
package org.gvsig.app.sqlQueryValidation; |
|
2 |
|
|
3 |
import junit.framework.TestCase; |
|
4 |
|
|
5 |
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana |
|
6 |
* |
|
7 |
* Copyright (C) 2004 IVER T.I. and Generalitat Valenciana. |
|
8 |
* |
|
9 |
* This program is free software; you can redistribute it and/or |
|
10 |
* modify it under the terms of the GNU General Public License |
|
11 |
* as published by the Free Software Foundation; either version 2 |
|
12 |
* of the License, or (at your option) any later version. |
|
13 |
* |
|
14 |
* This program is distributed in the hope that it will be useful, |
|
15 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
16 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
17 |
* GNU General Public License for more details. |
|
18 |
* |
|
19 |
* You should have received a copy of the GNU General Public License |
|
20 |
* along with this program; if not, write to the Free Software |
|
21 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA. |
|
22 |
* |
|
23 |
* For more information, contact: |
|
24 |
* |
|
25 |
* Generalitat Valenciana |
|
26 |
* Conselleria d'Infraestructures i Transport |
|
27 |
* Av. Blasco Ib??ez, 50 |
|
28 |
* 46010 VALENCIA |
|
29 |
* SPAIN |
|
30 |
* |
|
31 |
* +34 963862235 |
|
32 |
* gvsig@gva.es |
|
33 |
* www.gvsig.gva.es |
|
34 |
* |
|
35 |
* or |
|
36 |
* |
|
37 |
* IVER T.I. S.A |
|
38 |
* Salamanca 50 |
|
39 |
* 46005 Valencia |
|
40 |
* Spain |
|
41 |
* |
|
42 |
* +34 963163400 |
|
43 |
* dac@iver.es |
|
44 |
*/ |
|
45 |
|
|
46 |
/** |
|
47 |
* Tests the methods of the class SQLQueryValidation |
|
48 |
* (This class is made without inner static methods for don't create problems to Zql, in this way, |
|
49 |
* it's possible to add more tests, with or without long queries.) |
|
50 |
* |
|
51 |
* @author Pablo Piqueras Bartolom? (p_queras@hotmail.com) |
|
52 |
*/ |
|
53 |
public class TestSQLQueryValidation extends TestCase{ |
|
54 |
|
|
55 |
/* |
|
56 |
* (non-Javadoc) |
|
57 |
* @see junit.framework.TestCase#setUp() |
|
58 |
*/ |
|
59 |
protected void setUp() throws Exception { |
|
60 |
super.setUp(); |
|
61 |
} |
|
62 |
|
|
63 |
/* |
|
64 |
* (non-Javadoc) |
|
65 |
* @see junit.framework.TestCase#tearDown() |
|
66 |
*/ |
|
67 |
protected void tearDown() throws Exception { |
|
68 |
super.tearDown(); |
|
69 |
} |
|
70 |
|
|
71 |
/** |
|
72 |
* A test (Correct) |
|
73 |
*/ |
|
74 |
public void test1() { |
|
75 |
String query = "SELECT r.name, f.id FROM room r, flat f WHERE (r.user_name LIKE 'P%') AND (r.flat = f.id) AND (r.color_wall LIKE 'white') AND (r.height < 2.20);"; |
|
76 |
|
|
77 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
78 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, false); |
|
79 |
|
|
80 |
if (sqlQueryValidation.validateQuery()) { |
|
81 |
System.out.println("Yes."); |
|
82 |
} |
|
83 |
else { |
|
84 |
System.out.println("No."); |
|
85 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
86 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
87 |
fail(); |
|
88 |
} |
|
89 |
} |
|
90 |
|
|
91 |
/** |
|
92 |
* A test (Correct) |
|
93 |
*/ |
|
94 |
public void test2() { |
|
95 |
String query = "SELECT * FROM House;"; |
|
96 |
|
|
97 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
98 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, false); |
|
99 |
|
|
100 |
if (sqlQueryValidation.validateQuery()) { |
|
101 |
System.out.println("Yes."); |
|
102 |
} |
|
103 |
else { |
|
104 |
System.out.println("No."); |
|
105 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
106 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
107 |
fail(); |
|
108 |
} |
|
109 |
} |
|
110 |
|
|
111 |
/** |
|
112 |
* A test (Incorrect) |
|
113 |
*/ |
|
114 |
public void test3() { |
|
115 |
String query = "SELECT a* FROM House;"; |
|
116 |
|
|
117 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
118 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, false); |
|
119 |
|
|
120 |
if (sqlQueryValidation.validateQuery()) { |
|
121 |
System.out.println("Yes."); |
|
122 |
} |
|
123 |
else { |
|
124 |
System.out.println("No."); |
|
125 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
126 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
127 |
fail(); |
|
128 |
} |
|
129 |
} |
|
130 |
|
|
131 |
/** |
|
132 |
* A test (Correct) |
|
133 |
*/ |
|
134 |
public void test4() { |
|
135 |
String query = "SELECT * FROM House;"; |
|
136 |
|
|
137 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
138 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, false); |
|
139 |
|
|
140 |
if (sqlQueryValidation.validateQuery()) { |
|
141 |
System.out.println("Yes."); |
|
142 |
} |
|
143 |
else { |
|
144 |
System.out.println("No."); |
|
145 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
146 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
147 |
fail(); |
|
148 |
} |
|
149 |
} |
|
150 |
|
|
151 |
/** |
|
152 |
* A test (Correct) |
|
153 |
*/ |
|
154 |
public void test5() { |
|
155 |
String query = "r.level = f.level AND r.user_name LIKE \'P%\';"; |
|
156 |
|
|
157 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
158 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
159 |
|
|
160 |
if (sqlQueryValidation.validateQuery()) { |
|
161 |
System.out.println("Yes."); |
|
162 |
} |
|
163 |
else { |
|
164 |
System.out.println("No."); |
|
165 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
166 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
167 |
fail(); |
|
168 |
} |
|
169 |
} |
|
170 |
|
|
171 |
/** |
|
172 |
* A test (Incorrect) |
|
173 |
*/ |
|
174 |
public void test6() { |
|
175 |
String query = "r.level = f.level a e3 w q3 ?32 9'}97AND r.user_name LIKE \'P%\';"; |
|
176 |
|
|
177 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
178 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
179 |
|
|
180 |
if (sqlQueryValidation.validateQuery()) { |
|
181 |
System.out.println("Yes."); |
|
182 |
} |
|
183 |
else { |
|
184 |
System.out.println("No."); |
|
185 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
186 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
187 |
fail(); |
|
188 |
} |
|
189 |
} |
|
190 |
|
|
191 |
/** |
|
192 |
* A test (Correct) |
|
193 |
*/ |
|
194 |
public void test7() { |
|
195 |
String query = "\"codigo\" = 'Canal d'Elx'"; |
|
196 |
|
|
197 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
198 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
199 |
|
|
200 |
if (sqlQueryValidation.validateQuery()) { |
|
201 |
System.out.println("Yes."); |
|
202 |
} |
|
203 |
else { |
|
204 |
System.out.println("No."); |
|
205 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
206 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
207 |
fail(); |
|
208 |
} |
|
209 |
} |
|
210 |
|
|
211 |
/** |
|
212 |
* A test (Correct) |
|
213 |
*/ |
|
214 |
public void test8() { |
|
215 |
String query = "\"codigo\" = 'Canal de la M?nega'"; |
|
216 |
|
|
217 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
218 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
219 |
|
|
220 |
if (sqlQueryValidation.validateQuery()) { |
|
221 |
System.out.println("Yes."); |
|
222 |
} |
|
223 |
else { |
|
224 |
System.out.println("No."); |
|
225 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
226 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
227 |
fail(); |
|
228 |
} |
|
229 |
} |
|
230 |
|
|
231 |
/** |
|
232 |
* A test (Correct) |
|
233 |
*/ |
|
234 |
public void test9() { |
|
235 |
String query = "\"codigo\" = 'Espa?a'"; |
|
236 |
|
|
237 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
238 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
239 |
|
|
240 |
if (sqlQueryValidation.validateQuery()) { |
|
241 |
System.out.println("Yes."); |
|
242 |
} |
|
243 |
else { |
|
244 |
System.out.println("No."); |
|
245 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
246 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
247 |
fail(); |
|
248 |
} |
|
249 |
} |
|
250 |
|
|
251 |
/** |
|
252 |
* A test (Correct) |
|
253 |
*/ |
|
254 |
public void test10() { |
|
255 |
String query = "\"codigo\" = ('Canal d'Elx')"; |
|
256 |
|
|
257 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
258 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
259 |
|
|
260 |
if (sqlQueryValidation.validateQuery()) { |
|
261 |
System.out.println("Yes."); |
|
262 |
} |
|
263 |
else { |
|
264 |
System.out.println("No."); |
|
265 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
266 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
267 |
fail(); |
|
268 |
} |
|
269 |
} |
|
270 |
|
|
271 |
/** |
|
272 |
* A test (Correct) |
|
273 |
*/ |
|
274 |
public void test11() { |
|
275 |
String query = "\"codigo\" = ( 'Canal d'Elx' )"; |
|
276 |
|
|
277 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
278 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
279 |
|
|
280 |
if (sqlQueryValidation.validateQuery()) { |
|
281 |
System.out.println("Yes."); |
|
282 |
} |
|
283 |
else { |
|
284 |
System.out.println("No."); |
|
285 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
286 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
287 |
fail(); |
|
288 |
} |
|
289 |
} |
|
290 |
|
|
291 |
/** |
|
292 |
* A test (Correct) |
|
293 |
*/ |
|
294 |
public void test12() { |
|
295 |
String query = "\"codigo\" = ( 'Canal d'Elx')"; |
|
296 |
|
|
297 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
298 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
299 |
|
|
300 |
if (sqlQueryValidation.validateQuery()) { |
|
301 |
System.out.println("Yes."); |
|
302 |
} |
|
303 |
else { |
|
304 |
System.out.println("No."); |
|
305 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
306 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
307 |
fail(); |
|
308 |
} |
|
309 |
} |
|
310 |
|
|
311 |
/** |
|
312 |
* A test (Correct) |
|
313 |
*/ |
|
314 |
public void test13() { |
|
315 |
String query = "\"codigo\" = ('Canal d'Elx' )"; |
|
316 |
|
|
317 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
318 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
319 |
|
|
320 |
if (sqlQueryValidation.validateQuery()) { |
|
321 |
System.out.println("Yes."); |
|
322 |
} |
|
323 |
else { |
|
324 |
System.out.println("No."); |
|
325 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
326 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
327 |
fail(); |
|
328 |
} |
|
329 |
} |
|
330 |
|
|
331 |
/** |
|
332 |
* A test (Incorrect) |
|
333 |
*/ |
|
334 |
public void test14() { |
|
335 |
String query = "\"codigo\" = ('Canal d' Elx' )"; |
|
336 |
|
|
337 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
338 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
339 |
|
|
340 |
if (sqlQueryValidation.validateQuery()) { |
|
341 |
System.out.println("Yes."); |
|
342 |
} |
|
343 |
else { |
|
344 |
System.out.println("No."); |
|
345 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
346 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
347 |
fail(); |
|
348 |
} |
|
349 |
} |
|
350 |
|
|
351 |
/** |
|
352 |
* A test (Incorrect) |
|
353 |
*/ |
|
354 |
public void test15() { |
|
355 |
String query = "\"codigo\" = ('Canal d'Elx d'Alacant' )"; |
|
356 |
|
|
357 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
358 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
359 |
|
|
360 |
if (sqlQueryValidation.validateQuery()) { |
|
361 |
System.out.println("Yes."); |
|
362 |
} |
|
363 |
else { |
|
364 |
System.out.println("No."); |
|
365 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
366 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
367 |
fail(); |
|
368 |
} |
|
369 |
} |
|
370 |
|
|
371 |
/** |
|
372 |
* A test (Incorrect) |
|
373 |
*/ |
|
374 |
public void test16() { |
|
375 |
String query = "\"fecha\" = Date(11-ene-2004)"; |
|
376 |
|
|
377 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
378 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
379 |
|
|
380 |
if (sqlQueryValidation.validateQuery()) { |
|
381 |
System.out.println("Yes."); |
|
382 |
} |
|
383 |
else { |
|
384 |
System.out.println("No."); |
|
385 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
386 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
387 |
fail(); |
|
388 |
} |
|
389 |
} |
|
390 |
|
|
391 |
/** |
|
392 |
* A test (Correct) |
|
393 |
*/ |
|
394 |
public void test17() { |
|
395 |
String query = "\"fecha\" = 11-ene-2004"; |
|
396 |
|
|
397 |
System.out.println("?Es v?lida '" + query + "' ?"); |
|
398 |
SQLQueryValidation sqlQueryValidation = new SQLQueryValidation(query, true); |
|
399 |
|
|
400 |
if (sqlQueryValidation.validateQuery()) { |
|
401 |
System.out.println("Yes."); |
|
402 |
} |
|
403 |
else { |
|
404 |
System.out.println("No."); |
|
405 |
System.out.println(sqlQueryValidation.getErrorPositionAsMessage()); |
|
406 |
System.out.println(sqlQueryValidation.getErrorMessage()); |
|
407 |
fail(); |
|
408 |
} |
|
409 |
} |
|
410 |
} |
|
0 | 411 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/gui/filter/TestFilterExpressionFromWhereIsEmpty_Method.java | ||
---|---|---|
1 |
package org.gvsig.app.gui.filter; |
|
2 |
|
|
3 |
import junit.framework.TestCase; |
|
4 |
|
|
5 |
|
|
6 |
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana |
|
7 |
* |
|
8 |
* Copyright (C) 2004 IVER T.I. and Generalitat Valenciana. |
|
9 |
* |
|
10 |
* This program is free software; you can redistribute it and/or |
|
11 |
* modify it under the terms of the GNU General Public License |
|
12 |
* as published by the Free Software Foundation; either version 2 |
|
13 |
* of the License, or (at your option) any later version. |
|
14 |
* |
|
15 |
* This program is distributed in the hope that it will be useful, |
|
16 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
17 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
18 |
* GNU General Public License for more details. |
|
19 |
* |
|
20 |
* You should have received a copy of the GNU General Public License |
|
21 |
* along with this program; if not, write to the Free Software |
|
22 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA. |
|
23 |
* |
|
24 |
* For more information, contact: |
|
25 |
* |
|
26 |
* Generalitat Valenciana |
|
27 |
* Conselleria d'Infraestructures i Transport |
|
28 |
* Av. Blasco Ib??ez, 50 |
|
29 |
* 46010 VALENCIA |
|
30 |
* SPAIN |
|
31 |
* |
|
32 |
* +34 963862235 |
|
33 |
* gvsig@gva.es |
|
34 |
* www.gvsig.gva.es |
|
35 |
* |
|
36 |
* or |
|
37 |
* |
|
38 |
* IVER T.I. S.A |
|
39 |
* Salamanca 50 |
|
40 |
* 46005 Valencia |
|
41 |
* Spain |
|
42 |
* |
|
43 |
* +34 963163400 |
|
44 |
* dac@iver.es |
|
45 |
*/ |
|
46 |
|
|
47 |
/** |
|
48 |
* @author Pablo Piqueras Bartolom? (p_queras@hotmail.com) |
|
49 |
*/ |
|
50 |
public class TestFilterExpressionFromWhereIsEmpty_Method extends TestCase { |
|
51 |
/* |
|
52 |
* (non-Javadoc) |
|
53 |
* @see junit.framework.TestCase#setUp() |
|
54 |
*/ |
|
55 |
protected void setUp() throws Exception { |
|
56 |
super.setUp(); |
|
57 |
} |
|
58 |
|
|
59 |
/* |
|
60 |
* (non-Javadoc) |
|
61 |
* @see junit.framework.TestCase#tearDown() |
|
62 |
*/ |
|
63 |
protected void tearDown() throws Exception { |
|
64 |
super.tearDown(); |
|
65 |
} |
|
66 |
|
|
67 |
/** |
|
68 |
* Test 1 (valid) |
|
69 |
*/ |
|
70 |
public void test1() { |
|
71 |
String expression = new String("select * from 'gdbms144426c_10fc90fa1aa__7c18' where ;"); |
|
72 |
|
|
73 |
System.out.println("? Es vac?o el filtro en: " + expression + " ? "); |
|
74 |
|
|
75 |
if (this.filterExpressionFromWhereIsEmpty(expression)) |
|
76 |
System.out.println("Si."); |
|
77 |
else |
|
78 |
System.out.println("No."); |
|
79 |
} |
|
80 |
|
|
81 |
/** |
|
82 |
* Test 2 (invalid) |
|
83 |
*/ |
|
84 |
public void test2() { |
|
85 |
String expression = new String("select * from 'gdbms158fd70_10fc92ee61e__7c18' where layer < '61';"); |
|
86 |
|
|
87 |
System.out.println("? Es vac?o el filtro en: " + expression + " ? "); |
|
88 |
|
|
89 |
if (this.filterExpressionFromWhereIsEmpty(expression)) |
|
90 |
System.out.println("Si."); |
|
91 |
else |
|
92 |
System.out.println("No."); |
|
93 |
} |
|
94 |
|
|
95 |
/** |
|
96 |
* Returns true if the WHERE subconsultation of the filterExpression is empty ("") |
|
97 |
* |
|
98 |
* @param expression An string |
|
99 |
* @return A boolean value |
|
100 |
*/ |
|
101 |
private boolean filterExpressionFromWhereIsEmpty(String expression) { |
|
102 |
String subExpression = expression.trim(); |
|
103 |
int pos; |
|
104 |
|
|
105 |
// Remove last ';' if exists |
|
106 |
if (subExpression.charAt(subExpression.length() -1) == ';') |
|
107 |
subExpression = subExpression.substring(0, subExpression.length() -1).trim(); |
|
108 |
|
|
109 |
// If there is no 'where' clause |
|
110 |
if ((pos = subExpression.indexOf("where")) == -1) |
|
111 |
return false; |
|
112 |
|
|
113 |
// If there is no subexpression in the WHERE clause -> true |
|
114 |
subExpression = subExpression.substring(pos + 5, subExpression.length()).trim(); // + 5 is the length of 'where' |
|
115 |
if ( subExpression.length() == 0 ) |
|
116 |
return true; |
|
117 |
else |
|
118 |
return false; |
|
119 |
} |
|
120 |
} |
|
0 | 121 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/project/documents/layout/LayoutDocumentTest.java | ||
---|---|---|
1 |
/* gvSIG. Geographic Information System of the Valencian Government |
|
2 |
* |
|
3 |
* Copyright (C) 2007-2008 Infrastructures and Transports Department |
|
4 |
* of the Valencian Government (CIT) |
|
5 |
* |
|
6 |
* This program is free software; you can redistribute it and/or |
|
7 |
* modify it under the terms of the GNU General Public License |
|
8 |
* as published by the Free Software Foundation; either version 2 |
|
9 |
* of the License, or (at your option) any later version. |
|
10 |
* |
|
11 |
* This program is distributed in the hope that it will be useful, |
|
12 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
13 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
14 |
* GNU General Public License for more details. |
|
15 |
* |
|
16 |
* You should have received a copy of the GNU General Public License |
|
17 |
* along with this program; if not, write to the Free Software |
|
18 |
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, |
|
19 |
* MA 02110-1301, USA. |
|
20 |
* |
|
21 |
*/ |
|
22 |
|
|
23 |
/* |
|
24 |
* AUTHORS (In addition to CIT): |
|
25 |
* 2010 {Prodevelop} {Task} |
|
26 |
*/ |
|
27 |
|
|
28 |
package org.gvsig.app.project.documents.layout; |
|
29 |
|
|
30 |
import org.cresques.cts.IProjection; |
|
31 |
import org.gvsig.app.ApplicationLocator; |
|
32 |
import org.gvsig.app.ApplicationManager; |
|
33 |
import org.gvsig.app.project.ProjectManager; |
|
34 |
import org.gvsig.tools.ToolsLocator; |
|
35 |
import org.gvsig.tools.junit.AbstractLibraryAutoInitTestCase; |
|
36 |
import org.gvsig.tools.locator.LocatorException; |
|
37 |
import org.gvsig.tools.persistence.PersistentState; |
|
38 |
import org.gvsig.tools.persistence.exception.PersistenceClassNotRegistered; |
|
39 |
import org.gvsig.tools.persistence.exception.PersistenceException; |
|
40 |
import org.gvsig.tools.persistence.exception.PersistenceTypeNotSupportedException; |
|
41 |
import org.gvsig.tools.persistence.exception.PersistenceValidateExceptions; |
|
42 |
|
|
43 |
/** |
|
44 |
* @author <a href="mailto:jpiera@gvsig.org">Jorge Piera Llodrá</a> |
|
45 |
*/ |
|
46 |
public class LayoutDocumentTest extends AbstractLibraryAutoInitTestCase { |
|
47 |
|
|
48 |
@Override |
|
49 |
protected void doSetUp() throws Exception { |
|
50 |
DefaultLayoutManager.register(); |
|
51 |
} |
|
52 |
|
|
53 |
public void testPersistence() throws PersistenceTypeNotSupportedException, PersistenceClassNotRegistered, PersistenceException, PersistenceValidateExceptions, LocatorException{ |
|
54 |
ApplicationManager applicationManager = ApplicationLocator.getManager(); |
|
55 |
assertNotNull(applicationManager); |
|
56 |
|
|
57 |
ProjectManager projectManager = applicationManager.getProjectManager(); |
|
58 |
assertNotNull(projectManager); |
|
59 |
|
|
60 |
// Project project = projectManager.createProject(); |
|
61 |
// assertNotNull(project); |
|
62 |
|
|
63 |
LayoutManager layoutManager = (LayoutManager) projectManager.getDocumentManagers(DefaultLayoutManager.TYPENAME); |
|
64 |
LayoutDocument layoutDocument1 = (LayoutDocument) layoutManager.createDocument(); |
|
65 |
layoutDocument1.setName("My Layout"); |
|
66 |
|
|
67 |
// project.add(document); |
|
68 |
|
|
69 |
|
|
70 |
//Save and load the layout |
|
71 |
PersistentState persistentState = ToolsLocator.getPersistenceManager().getState(layoutDocument1); |
|
72 |
|
|
73 |
LayoutDocument layoutDocument2 = (LayoutDocument) ToolsLocator.getPersistenceManager().create(persistentState); |
|
74 |
|
|
75 |
assertEquals(layoutDocument1.getName(), layoutDocument2.getName()); |
|
76 |
|
|
77 |
IProjection projection = null; |
|
78 |
} |
|
79 |
|
|
80 |
} |
|
81 |
|
|
0 | 82 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/project/ProjectTest.java | ||
---|---|---|
1 |
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana |
|
2 |
* |
|
3 |
* Copyright (C) 2005 IVER T.I. and Generalitat Valenciana. |
|
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or |
|
6 |
* modify it under the terms of the GNU General Public License |
|
7 |
* as published by the Free Software Foundation; either version 2 |
|
8 |
* of the License, or (at your option) any later version. |
|
9 |
* |
|
10 |
* This program is distributed in the hope that it will be useful, |
|
11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
13 |
* GNU General Public License for more details. |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License |
|
16 |
* along with this program; if not, write to the Free Software |
|
17 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA. |
|
18 |
* |
|
19 |
* For more information, contact: |
|
20 |
* |
|
21 |
* Generalitat Valenciana |
|
22 |
* Conselleria d'Infraestructures i Transport |
|
23 |
* Av. Blasco Ib??ez, 50 |
|
24 |
* 46010 VALENCIA |
|
25 |
* SPAIN |
|
26 |
* |
|
27 |
* +34 963862235 |
|
28 |
* gvsig@gva.es |
|
29 |
* www.gvsig.gva.es |
|
30 |
* |
|
31 |
* or |
|
32 |
* |
|
33 |
* IVER T.I. S.A |
|
34 |
* Salamanca 50 |
|
35 |
* 46005 Valencia |
|
36 |
* Spain |
|
37 |
* |
|
38 |
* +34 963163400 |
|
39 |
* dac@iver.es |
|
40 |
*/ |
|
41 |
|
|
42 |
/* CVS MESSAGES: |
|
43 |
* |
|
44 |
* $Id$ |
|
45 |
* $Log$ |
|
46 |
* Revision 1.1 2006-11-08 10:57:55 jaume |
|
47 |
* remove unecessary imports |
|
48 |
* |
|
49 |
* |
|
50 |
*/ |
|
51 |
package org.gvsig.app.project; |
|
52 |
|
|
53 |
import junit.framework.TestCase; |
|
54 |
|
|
55 |
//TODO comentado para que compile |
|
56 |
public class ProjectTest extends TestCase { |
|
57 |
static final String projectFile1 = "test/test.gvp"; |
|
58 |
static final String projectFile2 = "test/test.gvp"; |
|
59 |
static final String projectFile3 = null; |
|
60 |
static final String projectFile4 = null; |
|
61 |
|
|
62 |
static final String driversPath = "lib-test/drivers"; |
|
63 |
Project p1, p2; |
|
64 |
|
|
65 |
public void setUp() { |
|
66 |
|
|
67 |
// LayerFactory.setDriversPath(driversPath); |
|
68 |
// |
|
69 |
// Reader reader; |
|
70 |
// |
|
71 |
// // TODO Install drivers support for testing |
|
72 |
// try { |
|
73 |
// reader = new FileReader(new File(projectFile1)); |
|
74 |
// |
|
75 |
// XmlTag tag = (XmlTag) XmlTag.unmarshal(reader); |
|
76 |
// XMLEntity xml=new XMLEntity(tag); |
|
77 |
// p1 = Project.createFromXML(xml); |
|
78 |
// p2 = Project.createFromXML(xml); |
|
79 |
// } catch (Exception e) { |
|
80 |
// e.printStackTrace(); |
|
81 |
// } |
|
82 |
|
|
83 |
} |
|
84 |
|
|
85 |
// public void testSignature() { |
|
86 |
// try { |
|
87 |
// assertTrue(p1.computeSignature() == p2.computeSignature()); |
|
88 |
// } catch (SaveException e) {} |
|
89 |
//// assertTrue(p1.equals(p2)); |
|
90 |
// } |
|
91 |
} |
|
0 | 92 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/project/TableTest.java | ||
---|---|---|
1 |
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana |
|
2 |
* |
|
3 |
* Copyright (C) 2005 IVER T.I. and Generalitat Valenciana. |
|
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or |
|
6 |
* modify it under the terms of the GNU General Public License |
|
7 |
* as published by the Free Software Foundation; either version 2 |
|
8 |
* of the License, or (at your option) any later version. |
|
9 |
* |
|
10 |
* This program is distributed in the hope that it will be useful, |
|
11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
13 |
* GNU General Public License for more details. |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License |
|
16 |
* along with this program; if not, write to the Free Software |
|
17 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA. |
|
18 |
* |
|
19 |
* For more information, contact: |
|
20 |
* |
|
21 |
* Generalitat Valenciana |
|
22 |
* Conselleria d'Infraestructures i Transport |
|
23 |
* Av. Blasco Ib??ez, 50 |
|
24 |
* 46010 VALENCIA |
|
25 |
* SPAIN |
|
26 |
* |
|
27 |
* +34 963862235 |
|
28 |
* gvsig@gva.es |
|
29 |
* www.gvsig.gva.es |
|
30 |
* |
|
31 |
* or |
|
32 |
* |
|
33 |
* IVER T.I. S.A |
|
34 |
* Salamanca 50 |
|
35 |
* 46005 Valencia |
|
36 |
* Spain |
|
37 |
* |
|
38 |
* +34 963163400 |
|
39 |
* dac@iver.es |
|
40 |
*/ |
|
41 |
|
|
42 |
/* CVS MESSAGES: |
|
43 |
* |
|
44 |
* $Id$ |
|
45 |
* $Log$ |
|
46 |
* Revision 1.2 2007-07-30 12:56:04 jaume |
|
47 |
* organize imports, java 5 code downgraded to 1.4 and added PictureFillSymbol |
|
48 |
* |
|
49 |
* Revision 1.1 2007/07/13 12:31:03 caballero |
|
50 |
* TableTest |
|
51 |
* |
|
52 |
* Revision 1.1.2.1 2006/11/15 04:10:44 jjdelcerro |
|
53 |
* *** empty log message *** |
|
54 |
* |
|
55 |
* Revision 1.1 2006/11/08 10:57:55 jaume |
|
56 |
* remove unecessary imports |
|
57 |
* |
|
58 |
* |
|
59 |
*/ |
|
60 |
package org.gvsig.app.project; |
|
61 |
|
|
62 |
import junit.framework.TestCase; |
|
63 |
//TODO comentado para que compile |
|
64 |
public class TableTest extends TestCase { |
|
65 |
public void testTable() { |
|
66 |
// DriverManager dm = new DriverManager(); |
|
67 |
// dm.setValidation(new DriverValidation() { |
|
68 |
// public boolean validate(Driver d) { |
|
69 |
// return ((d instanceof ObjectDriver) || |
|
70 |
// (d instanceof FileDriver) || |
|
71 |
// (d instanceof DBDriver)); |
|
72 |
// } |
|
73 |
// }); |
|
74 |
// dm.loadDrivers(new File("../_fwAndami/gvSIG/extensiones/com.iver.cit.gvsig/drivers")); |
|
75 |
// |
|
76 |
// String[] Campos= {"Tipo_Via","Nombre","Numero","Sexo","CoorX","CoorY"}; |
|
77 |
// int [] fieldTypes={12,12,12,12,12,12}; |
|
78 |
// DBFDriver driver = new DBFDriver(); |
|
79 |
// String name = "Tabla"; |
|
80 |
// DataSourceFactory dsf =LayerFactory.getDataSourceFactory(); |
|
81 |
// dsf.setDriverManager(dm); |
|
82 |
// dsf.createFileDataSource(driver.getName(), name, "Archivo", Campos, fieldTypes); |
|
83 |
// DataSource dataSource = null; |
|
84 |
// dsf.createFileDataSource(driver.getName(), name, "MYTABLA.dbf", Campos, fieldTypes); |
|
85 |
// |
|
86 |
// try { |
|
87 |
// dataSource = dsf.createRandomDataSource(name, DataSourceFactory.AUTOMATIC_OPENING); |
|
88 |
// |
|
89 |
// dataSource.setDataSourceFactory(dsf); |
|
90 |
// SelectableDataSource sds = new SelectableDataSource(dataSource); |
|
91 |
// EditableAdapter auxea = new EditableAdapter(); |
|
92 |
// auxea.setOriginalDataSource(sds); |
|
93 |
// |
|
94 |
// |
|
95 |
// ProjectTable projectTables = ProjectFactory.createTable(name, |
|
96 |
// auxea); |
|
97 |
// |
|
98 |
// ProjectExtension ext = (ProjectExtension)PluginServices.getExtension(ProjectExtension.class); |
|
99 |
// ext.getProject().addDocument(projectTables); |
|
100 |
// } catch (DriverLoadException e) { |
|
101 |
// // TODO Auto-generated catch block |
|
102 |
// e.printStackTrace(); |
|
103 |
// } catch (NoSuchTableException e) { |
|
104 |
// // TODO Auto-generated catch block |
|
105 |
// e.printStackTrace(); |
|
106 |
// } catch (ReadDriverException e) { |
|
107 |
// // TODO Auto-generated catch block |
|
108 |
// e.printStackTrace(); |
|
109 |
// } |
|
110 |
} |
|
111 |
|
|
112 |
// public void testSignature() { |
|
113 |
// try { |
|
114 |
// assertTrue(p1.computeSignature() == p2.computeSignature()); |
|
115 |
// } catch (SaveException e) {} |
|
116 |
//// assertTrue(p1.equals(p2)); |
|
117 |
// } |
|
118 |
} |
|
0 | 119 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/AllTests.java | ||
---|---|---|
1 |
package org.gvsig.app; |
|
2 |
|
|
3 |
import junit.framework.Test; |
|
4 |
import junit.framework.TestSuite; |
|
5 |
|
|
6 |
import org.gvsig.app.gui.filter.TestFilterExpressionFromWhereIsEmpty_Method; |
|
7 |
import org.gvsig.app.panelGroup.Test2ExceptionsUsingTabbedPanel; |
|
8 |
import org.gvsig.app.panelGroup.Test2ExceptionsUsingTreePanel; |
|
9 |
import org.gvsig.app.panelGroup.TestPanelGroupLoaderFromExtensionPoint; |
|
10 |
import org.gvsig.app.project.ProjectTest; |
|
11 |
import org.gvsig.app.project.TableTest; |
|
12 |
import org.gvsig.app.sqlQueryValidation.TestSQLQueryValidation; |
|
13 |
import org.gvsig.app.test.Persistence; |
|
14 |
|
|
15 |
public class AllTests { |
|
16 |
|
|
17 |
public static Test suite() { |
|
18 |
TestSuite suite = new TestSuite("Test for org.gvsig.app"); |
|
19 |
//$JUnit-BEGIN$ |
|
20 |
suite.addTestSuite(Persistence.class); |
|
21 |
suite.addTestSuite(ProjectTest.class); |
|
22 |
suite.addTestSuite(TableTest.class); |
|
23 |
suite.addTestSuite(TestFilterExpressionFromWhereIsEmpty_Method.class); |
|
24 |
suite.addTestSuite(TestSQLQueryValidation.class); |
|
25 |
suite.addTestSuite(TestPanelGroupLoaderFromExtensionPoint.class); |
|
26 |
suite.addTestSuite(Test2ExceptionsUsingTabbedPanel.class); |
|
27 |
suite.addTestSuite(Test2ExceptionsUsingTreePanel.class); |
|
28 |
|
|
29 |
//$JUnit-END$ |
|
30 |
return suite; |
|
31 |
} |
|
32 |
|
|
33 |
} |
|
0 | 34 |
tags/v2_0_0_Build_2025/applications/appgvSIG/src-test/org/gvsig/app/panelGroup/Test2ExceptionsUsingTabbedPanel.java | ||
---|---|---|
1 |
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana |
|
2 |
* |
|
3 |
* Copyright (C) 2007 IVER T.I. and Generalitat Valenciana. |
|
4 |
* |
|
5 |
* This program is free software; you can redistribute it and/or |
|
6 |
* modify it under the terms of the GNU General Public License |
|
7 |
* as published by the Free Software Foundation; either version 2 |
|
8 |
* of the License, or (at your option) any later version. |
|
9 |
* |
|
10 |
* This program is distributed in the hope that it will be useful, |
|
11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
13 |
* GNU General Public License for more details. |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License |
|
16 |
* along with this program; if not, write to the Free Software |
|
17 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,USA. |
|
18 |
*/ |
|
19 |
|
|
20 |
package org.gvsig.app.panelGroup; |
|
21 |
|
|
22 |
import junit.framework.TestCase; |
|
23 |
|
|
24 |
import org.gvsig.gui.beans.Messages; |
|
25 |
import org.gvsig.gui.beans.panelGroup.PanelGroupManager; |
|
26 |
import org.gvsig.gui.beans.panelGroup.tabbedPanel.TabbedPanel; |
|
27 |
import org.gvsig.tools.exception.BaseException; |
|
28 |
|
|
29 |
import org.gvsig.app.panelGroup.loaders.PanelGroupLoaderFromExtensionPoint; |
|
30 |
import org.gvsig.app.panelGroup.samples.Samples_ExtensionPointsOfIPanels; |
|
31 |
|
|
32 |
/** |
|
33 |
* <p> |
|
34 |
* Tests the loading of layers using a {@link TabbedPanel TabbedPanel} object |
|
35 |
* and a {@link PanelGroupLoaderFromExtensionPoint |
|
36 |
* PanelGroupLoaderFromExtensionPoint} loader Tests also the managing of the |
|
37 |
* different kind of exceptions which could be launched during this process. |
|
38 |
* </p> |
|
39 |
* |
|
40 |
* @version 11/12/2007 |
|
41 |
* @author Pablo Piqueras Bartolom? (pablo.piqueras@iver.es) |
|
42 |
*/ |
|
43 |
public class Test2ExceptionsUsingTabbedPanel extends TestCase { |
|
44 |
private TabbedPanel panelGroup; |
|
45 |
private PanelGroupManager manager; |
|
46 |
private PanelGroupLoaderFromExtensionPoint loader; |
|
47 |
private String validationText; |
|
48 |
private String localizedMessage; |
|
49 |
|
|
50 |
/* |
|
51 |
* (non-Javadoc) |
|
52 |
* @see junit.framework.TestCase#setUp() |
|
53 |
*/ |
|
54 |
protected void setUp() throws Exception { |
|
55 |
super.setUp(); |
|
56 |
|
|
57 |
manager = PanelGroupManager.getManager(); |
|
58 |
manager.registerPanelGroup(TabbedPanel.class); |
|
59 |
manager.setDefaultType(TabbedPanel.class); |
|
60 |
panelGroup = (TabbedPanel) manager.getPanelGroup(Samples_ExtensionPointsOfIPanels.REFERENCE3); |
|
61 |
} |
|
62 |
|
|
63 |
/* |
|
64 |
* (non-Javadoc) |
|
65 |
* @see junit.framework.TestCase#tearDown() |
|
66 |
*/ |
|
67 |
protected void tearDown() throws Exception { |
|
68 |
super.tearDown(); |
|
69 |
manager.deregisterPanelGroup(TabbedPanel.class); |
|
70 |
} |
|
71 |
|
|
72 |
/** |
|
73 |
* <p>Test the 'PanelGroup' exceptions </p> |
|
74 |
*/ |
|
75 |
public void test1() { |
|
76 |
Samples_ExtensionPointsOfIPanels.loadSample(); |
|
77 |
|
|
78 |
validationText = Messages.getText("couldnt_add_some_panel_exception") + "\n " + Messages.getText("couldnt_load_panels_from_extension_point_exception") + "\n Error cargando un panel: / by zero."; |
|
79 |
|
|
80 |
try { |
|
81 |
System.out.println("----- Test 1 -----"); |
|
82 |
loader = new PanelGroupLoaderFromExtensionPoint(Samples_ExtensionPointsOfIPanels.EXTENSIONPOINT4_NAME); |
|
83 |
|
|
84 |
// Begin: Test the normal load |
|
85 |
panelGroup.loadPanels(loader); |
|
86 |
// End: Test the normal load |
|
87 |
} catch (BaseException bE) { |
|
88 |
localizedMessage = bE.getLocalizedMessageStack(); |
|
89 |
System.out.println(localizedMessage); |
|
90 |
System.out.println("------------------"); |
|
91 |
assertEquals(localizedMessage, validationText); |
|
92 |
return; |
|
93 |
} catch (Exception e) { |
|
94 |
e.printStackTrace(); |
|
95 |
System.out.println("------------------"); |
|
96 |
fail(); |
|
97 |
return; |
|
98 |
} |
|
99 |
|
|
100 |
System.out.println("------------------"); |
|
101 |
fail(); |
|
102 |
} |
Also available in: Unified diff