• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2008 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package tests.SQLite;
18 
19 import SQLite.Constants;
20 import SQLite.Database;
21 import SQLite.Exception;
22 import SQLite.Stmt;
23 import SQLite.TableResult;
24 import dalvik.annotation.BrokenTest;
25 import dalvik.annotation.KnownFailure;
26 import dalvik.annotation.TestLevel;
27 import dalvik.annotation.TestTargetNew;
28 import dalvik.annotation.TestTargetClass;
29 
30 
31 import tests.support.DatabaseCreator;
32 import tests.support.Support_SQL;
33 
34 import java.sql.Connection;
35 import java.sql.SQLException;
36 
37 @TestTargetClass(Stmt.class)
38 public class StmtTest extends SQLiteTest {
39 
40     private static Database db = null;
41 
42     private static Stmt st = null;
43 
44     private static final String createAllTypes =
45     "create table type (" +
46 
47     " BoolVal BOOLEAN," + " IntVal INT," + " LongVal LONG,"
48             + " Bint BIGINT," + " Tint TINYINT," + " Sint SMALLINT,"
49             + " Mint MEDIUMINT, " +
50 
51             " IntegerVal INTEGER, " + " RealVal REAL, "
52             + " DoubleVal DOUBLE, " + " FloatVal FLOAT, "
53             + " DecVal DECIMAL, " +
54 
55             " NumVal NUMERIC, " + " charStr CHAR(20), "
56             + " dateVal DATE, " + " timeVal TIME, " + " TS TIMESTAMP, "
57             +
58 
59             " DT DATETIME, " + " TBlob TINYBLOB, " + " BlobVal BLOB, "
60             + " MBlob MEDIUMBLOB, " + " LBlob LONGBLOB, " +
61 
62             " TText TINYTEXT, " + " TextVal TEXT, "
63             + " MText MEDIUMTEXT, " + " LText LONGTEXT, " +
64 
65             " MaxLongVal BIGINT, MinLongVal BIGINT, "+
66 
67             " validURL URL, invalidURL URL "+
68 
69             ");";
70 
71     static final String insertAllTypes =
72         "insert into type (BoolVal, IntVal, LongVal, Bint, Tint, Sint, Mint,"
73         + "IntegerVal, RealVal, DoubleVal, FloatVal, DecVal,"
74         + "NumVal, charStr, dateVal, timeVal, TS,"
75         + "DT, TBlob, BlobVal, MBlob, LBlob,"
76         + "TText, TextVal, MText, LText, MaxLongVal, MinLongVal,"
77         + " validURL, invalidURL"
78         + ") "
79         + "values (1, -1, 22, 2, 33,"
80         + "3, 1, 2, 3.9, 23.2, 33.3, 44,"
81         + "5, 'test string', '1799-05-26', '12:35:45', '2007-10-09 14:28:02.0',"
82         + "'1221-09-22 10:11:55', 1, 2, 3, 4,"
83         + "'Test text message tiny', 'Test text',"
84         + " 'Test text message medium', 'Test text message long', "
85         + Long.MAX_VALUE+", "+Long.MIN_VALUE+", "
86         + "null, null "+
87         ");";
88 
89     static final String allTypesTable = "type";
90 
setUp()91     public void setUp() throws java.lang.Exception {
92         super.setUp();
93         Support_SQL.loadDriver();
94         db = new Database();
95         db.open(dbFile.getPath(), 0);
96         db.exec(DatabaseCreator.CREATE_TABLE_SIMPLE1, null);
97         DatabaseCreator.fillSimpleTable1(conn);
98 
99     }
100 
tearDown()101     public void tearDown() {
102         if (st != null) {
103             try {
104             st.close();
105             } catch (Exception e) {
106 
107             }
108         }
109         try {
110             db.close();
111             Connection con = Support_SQL.getConnection();
112             con.close();
113 //            dbFile.delete();
114         } catch (Exception e) {
115             fail("Exception in tearDown: "+e.getMessage());
116         } catch (SQLException e) {
117             fail("SQLException in tearDown: "+e.getMessage());
118         }
119         super.tearDown();
120     }
121 
122     /**
123      * @tests {@link Stmt#Stmt()}
124      */
125     @TestTargetNew(
126         level = TestLevel.COMPLETE,
127         notes = "constructor test",
128         method = "Stmt",
129         args = {}
130     )
testStmt()131     public void testStmt() {
132         Stmt st = new Stmt();
133         assertNotNull(st);
134         try {
135             Stmt actual = db.prepare("");
136             assertNotNull(st);
137             // no black box test assertEquals(actual.error_code,st.error_code);
138         } catch (Exception e) {
139             fail("Statement setup fails: "+e.getMessage());
140             e.printStackTrace();
141         }
142 
143         try {
144                st.step();
145                fail("Cannot execute non prepared Stmt");
146         } catch (Exception e) {
147             //ok
148         }
149     }
150 
151     /**
152      * @tests {@link Stmt#finalize()}
153      */
154     @TestTargetNew(
155         level = TestLevel.NOT_FEASIBLE,
156         notes = "method test",
157         method = "finalize",
158         args = {}
159     )
testFinalize()160     public void testFinalize() {
161 
162     }
163 
164     /**
165      * @tests {@link Stmt#prepare()}
166      */
167     @TestTargetNew(
168         level = TestLevel.COMPLETE,
169         notes = "method test",
170         method = "prepare",
171         args = {}
172     )
testPrepare()173     public void testPrepare() {
174         try {
175             st = db.prepare("");
176             st.prepare();
177             fail("statement is closed");
178         } catch (Exception e) {
179             assertEquals("stmt already closed", e.getMessage());
180         }
181 
182         try {
183             st = new Stmt();
184             st = db.prepare("select * from " + DatabaseCreator.SIMPLE_TABLE1);
185             assertFalse(st.prepare());
186             st = new Stmt();
187             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
188                     + " values (:one,:two,:three)");
189             assertFalse(st.prepare());
190             st = new Stmt();
191             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
192                     + " values (:one,:two,:three)");
193             st.bind(1, 1);
194             st.bind(2, 10);
195             st.bind(3, 30);
196             assertFalse(st.prepare());
197             st = db.prepare("select * from " + DatabaseCreator.SIMPLE_TABLE1
198                     + "; " + "delete from " + DatabaseCreator.SIMPLE_TABLE1
199                     + " where id = 5; " + "insert into "
200                     + DatabaseCreator.SIMPLE_TABLE1 + " values(5, 10, 20); "
201                     + "select * from " + DatabaseCreator.SIMPLE_TABLE1 + ";");
202             assertTrue(st.prepare());
203             assertTrue(st.prepare());
204             assertTrue(st.prepare());
205             assertFalse(st.prepare());
206         } catch (Exception e) {
207             fail("statement should be ready for execution: "
208                     + e.getMessage());
209             e.printStackTrace();
210         }
211     }
212 
213     /**
214      * @tests {@link Stmt#step()}
215      */
216     @TestTargetNew(
217         level = TestLevel.COMPLETE,
218         notes = "method test",
219         method = "step",
220         args = {}
221     )
testStep()222     public void testStep() {
223         try {
224             st.step();
225             fail("Exception expected");
226         } catch (Exception e) {
227             assertEquals("stmt already closed", e.getMessage());
228         }
229 
230         try {
231             st = new Stmt();
232             st = db.prepare("select name from sqlite_master where type = 'table'");
233             st.step();
234         } catch (Exception e) {
235            fail("test fails");
236         }
237 
238     }
239 
240     /**
241      * @tests {@link Stmt#close()}
242      */
243     @TestTargetNew(
244         level = TestLevel.COMPLETE,
245         notes = "method test",
246         method = "close",
247         args = {}
248     )
testClose()249     public void testClose() {
250         try {
251             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
252                     + " values (:one,:two,:three)");
253             st.close();
254         } catch (Exception e) {
255             fail("Test fails");
256             e.printStackTrace();
257         }
258 
259         try {
260             st.step();
261             fail("Test fails");
262         } catch (Exception e) {
263             assertEquals("stmt already closed", e.getMessage());
264         }
265     }
266 
267     /**
268      * @throws Exception
269      * @tests {@link Stmt#reset()}
270      */
271     @TestTargetNew(
272         level = TestLevel.COMPLETE,
273         notes = "method test",
274         method = "reset",
275         args = {}
276     )
testReset()277     public void testReset() throws Exception {
278         db.exec("create table TEST (res integer not null)", null);
279 
280         st = db.prepare("insert into TEST values (:one);");
281         st.bind(1, 1);
282         st.step();
283 
284         // verify that parameter is still bound
285         st.reset();
286         assertEquals(1,st.bind_parameter_count());
287         st.step();
288 
289         TableResult count = db.get_table("select count(*) from TEST where res=1", null);
290 
291         String[] row0 = (String[]) count.rows.elementAt(0);
292         assertEquals(2, Integer.parseInt(row0[0]));
293     }
294 
295     /**
296      * @tests {@link Stmt#clear_bindings()}
297      */
298     @TestTargetNew(
299         level = TestLevel.COMPLETE,
300         notes = "not supported",
301         method = "clear_bindings",
302         args = {}
303     )
testClear_bindings()304     public void testClear_bindings() {
305         try {
306             st.clear_bindings();
307         } catch (Exception e) {
308             assertEquals("unsupported", e.getMessage());
309         }
310     }
311 
312     /**
313      * @tests {@link Stmt#bind(int, int)}
314      */
315     @TestTargetNew(
316         level = TestLevel.COMPLETE,
317         notes = "method test",
318         method = "bind",
319         args = {int.class, int.class}
320     )
testBindIntInt()321     public void testBindIntInt() {
322         try {
323             int input = 0;
324             int maxVal = Integer.MAX_VALUE;
325             int minVal = Integer.MIN_VALUE;
326 
327             db.exec("create table TEST (res integer)", null);
328             st = db.prepare("insert into TEST values (:one);");
329             st.bind(1, input);
330             st.step();
331 
332             st.reset();
333             st.bind(1,maxVal);
334             st.step();
335 
336             st.reset();
337             st.bind(1,minVal);
338             st.step();
339 
340             TableResult r = db.get_table("select * from TEST");
341 
342             String[] row0 = (String[]) r.rows.elementAt(0);
343             assertEquals(input,Integer.parseInt(row0[0]));
344 
345             String[] row1 = (String[]) r.rows.elementAt(1);
346             assertEquals(maxVal,Integer.parseInt(row1[0]));
347 
348             String[] row2 = (String[]) r.rows.elementAt(2);
349             assertEquals(minVal,Integer.parseInt(row2[0]));
350 
351         } catch (Exception e) {
352             fail("Error in test setup: "+e.getMessage());
353             e.printStackTrace();
354         }
355 
356         try {
357             st.close();
358             st.bind(1,Integer.MIN_VALUE);
359             fail("Exception expected");
360         } catch (Exception e) {
361             //ok
362         }
363     }
364 
365     /**
366      * @tests {@link Stmt#bind(int, long)}
367      */
368     @TestTargetNew(
369         level = TestLevel.COMPLETE,
370         notes = "method test",
371         method = "bind",
372         args = {int.class, long.class}
373     )
testBindIntLong()374     public void testBindIntLong() {
375         try {
376             long input = 0;
377             long maxVal = Long.MAX_VALUE;
378             long minVal = Long.MIN_VALUE;
379 
380             db.exec("create table TEST (res long)", null);
381             st = db.prepare("insert into TEST values (:one);");
382             st.bind(1, input);
383             st.step();
384 
385             st.reset();
386             st.bind(1,maxVal);
387             st.step();
388 
389             st.reset();
390             st.bind(1,minVal);
391             st.step();
392 
393             TableResult r = db.get_table("select * from TEST");
394 
395             String[] row0 = (String[]) r.rows.elementAt(0);
396             assertEquals(input,Long.parseLong(row0[0]));
397 
398             String[] row1 = (String[]) r.rows.elementAt(1);
399             assertEquals(maxVal,Long.parseLong(row1[0]));
400 
401             String[] row2 = (String[]) r.rows.elementAt(2);
402             assertEquals(minVal,Long.parseLong(row2[0]));
403 
404         } catch (Exception e) {
405             fail("Error in test setup: "+e.getMessage());
406             e.printStackTrace();
407         }
408 
409         try {
410             st.close();
411             st.bind(1,Long.MIN_VALUE);
412             fail("Exception expected");
413         } catch (Exception e) {
414             //ok
415         }
416     }
417 
418     /**
419      * @tests {@link Stmt#bind(int, double)}
420      */
421     @TestTargetNew(
422         level = TestLevel.COMPLETE,
423         notes = "method test",
424         method = "bind",
425         args = {int.class, double.class}
426     )
testBindIntDouble()427     public void testBindIntDouble() {
428         try {
429             double input = 0.0;
430             double maxVal = Double.MAX_VALUE;
431             double minVal = Double.MIN_VALUE;
432             double negInf = Double.NEGATIVE_INFINITY;
433             double posInf = Double.POSITIVE_INFINITY;
434             double nan = Double.NaN;
435 
436             db.exec("create table TEST (res double)", null);
437             st = db.prepare("insert into TEST values (:one);");
438             st.bind(1, input);
439             st.step();
440 
441             st.reset();
442             st.bind(1, maxVal);
443             st.step();
444 
445             st.reset();
446             st.bind(1, minVal);
447             st.step();
448 
449             st.reset();
450             st.bind(1, negInf);
451             st.step();
452 
453             st.reset();
454             st.bind(1, posInf);
455             st.step();
456 
457             st.reset();
458             st.bind(1, nan);
459             st.step();
460 
461 
462             TableResult r = db.get_table("select * from TEST");
463 
464             String[] row0 = (String[]) r.rows.elementAt(0);
465             assertTrue(Double.compare(input, Double.parseDouble(row0[0])) == 0);
466 
467             String[] row1 = (String[]) r.rows.elementAt(1);
468             assertFalse(Double.compare(maxVal, Double.parseDouble(row1[0])) == 0);
469             assertTrue(Double.compare(maxVal, Double.parseDouble(row1[0])) < 0);
470             assertTrue(Double.isInfinite(Double.parseDouble(row1[0])));
471 
472             String[] row2 = (String[]) r.rows.elementAt(2);
473             assertTrue(Double.compare(minVal, Double.parseDouble(row2[0])) == 0);
474 
475             String[] row3 = (String[]) r.rows.elementAt(3);
476             assertEquals("Double.NEGATIVE_INFINITY SQLite representation",
477                     "-Inf", row3[0]);
478 
479             String[] row4 = (String[]) r.rows.elementAt(4);
480             assertEquals("Double.POSITIVE_INFINITY SQLite representation",
481                     "Inf", row4[0]);
482 
483             String[] row5 = (String[]) r.rows.elementAt(4);
484             assertEquals("Double.Nan SQLite representation", "Inf", row5[0]);
485 
486         } catch (Exception e) {
487             fail("Error in test setup: " + e.getMessage());
488             e.printStackTrace();
489         }
490 
491         try {
492             st.close();
493             st.bind(1,0.0);
494             fail("Exception expected");
495         } catch (Exception e) {
496             //ok
497         }
498     }
499 
500     /**
501      * @tests {@link Stmt#bind(int, byte[])}
502      */
503     @TestTargetNew(
504         level = TestLevel.COMPLETE,
505         notes = "",
506         method = "bind",
507         args = {int.class, byte[].class}
508     )
509     public void testBindIntByteArray() {
510 
511         String name = "Hello World";
512 
513         try {
514             byte[] b = new byte[name.getBytes().length];
515             b = name.getBytes();
516             String stringInHex = "";
517 
518             db.exec(DatabaseCreator.CREATE_TABLE_PARENT, null);
519             st = db.prepare("insert into " + DatabaseCreator.PARENT_TABLE
520                     + " values (:one, :two);");
521             st.bind(1, 2);
522             st.bind(2, b);
523             st.step();
524 
525             //compare what was stored with input based on Hex representation
526             // since type of column is CHAR
527             TableResult r = db.get_table("select * from "
528                     + DatabaseCreator.PARENT_TABLE);
529             String[] row = (String[]) r.rows.elementAt(0);
530 
531             for (byte aByte : b) {
532                 stringInHex += Integer.toHexString(aByte);
533             }
534             stringInHex = "X'" + stringInHex + "'";
535             assertTrue(stringInHex.equalsIgnoreCase(row[1]));
536 
537         } catch (Exception e) {
538             fail("Error in test setup: "+e.getMessage());
539             e.printStackTrace();
540         }
541 
542         try {
543             st.close();
544             st.bind(1,name.getBytes());
545             fail("Exception expected");
546         } catch (Exception e) {
547             //ok
548         }
549     }
550 
551     /**
552      * @tests {@link Stmt#bind(int, String)}
553      */
554     @TestTargetNew(
555         level = TestLevel.COMPLETE,
556         notes = "method test",
557         method = "bind",
558         args = {int.class, java.lang.String.class}
559     )
560     public void testBindIntString() {
561         String name = "Hello World";
562 
563         try {
564 
565             db.exec(DatabaseCreator.CREATE_TABLE_PARENT, null);
566             st = db.prepare("insert into " + DatabaseCreator.PARENT_TABLE
567                     + " values (:one, :two);");
568             st.bind(1, 2);
569             st.bind(2, name);
570             st.step();
571 
572             TableResult r = db.get_table("select * from "
573                     + DatabaseCreator.PARENT_TABLE);
574             String[] row = (String[]) r.rows.elementAt(0);
575             assertEquals(name,row[1]);
576 
577         } catch (Exception e) {
578             fail("Error in test setup: "+e.getMessage());
579             e.printStackTrace();
580         }
581 
582         try {
583             st.close();
584             st.bind(1,name);
585             fail("Exception expected");
586         } catch (Exception e) {
587             //ok
588         }
589     }
590 
591     /**
592      * @tests {@link Stmt#bind(int)}
593      */
594     @TestTargetNew(
595         level = TestLevel.COMPLETE,
596         notes = "method test",
597         method = "bind",
598         args = {int.class}
599     )
600     public void testBindInt() {
601 
602         try {
603             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
604                     + " values (:one,:two,:three)");
605             st.bind(4);
606             st.bind(1, 4);
607             st.bind(2, 10);
608             st.bind(3, 30);
609             st.step();
610             fail("Test failes");
611         } catch (Exception e) {
612             // What happens if null is bound to non existing variable position
613             assertEquals("parameter position out of bounds" , e.getMessage());
614         }
615 
616         // functional tests
617 
618         try {
619             st.reset();
620             st.bind(1);
621             st.bind(2, 10);
622             st.bind(3, 30);
623             st.step();
624             fail("Test failes");
625         } catch (Exception e) {
626             // What happens if null is bound to NON NULL field
627             assertEquals("SQL logic error or missing database", e.getMessage());
628         }
629 
630         try {
631             st.reset();
632             st.bind(1, 3);
633             st.bind(2);
634             st.bind(3, 30);
635             st.step();
636         } catch (Exception e) {
637             fail("Error in test setup : " + e.getMessage());
638         }
639 
640     }
641 
642     /**
643      * @tests {@link Stmt#bind_zeroblob(int, int)}
644      */
645     @TestTargetNew(
646         level = TestLevel.NOT_FEASIBLE,
647         notes = "not supported",
648         method = "bind_zeroblob",
649         args = {int.class, int.class}
650     )
651     public void testBind_zeroblob() {
652         try {
653             st.bind_zeroblob(1, 128);
654         } catch (Exception e) {
655             assertEquals("unsupported", e.getMessage());
656         }
657     }
658 
659     /**
660      * @tests {@link Stmt#bind_parameter_count()}
661      */
662     @TestTargetNew(
663         level = TestLevel.COMPLETE,
664         notes = "method test",
665         method = "bind_parameter_count",
666         args = {}
667     )
668     public void testBind_parameter_count() {
669         try {
670             st.bind_parameter_count();
671         } catch (Exception e) {
672             assertEquals("stmt already closed", e.getMessage());
673         }
674 
675         try {
676             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
677                     + " values (:one,:two,:three)");
678             assertEquals(3, st.bind_parameter_count());
679         } catch (Exception e) {
680             fail("Error in test setup : " + e.getMessage());
681             e.printStackTrace();
682         }
683 
684         try {
685             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
686                     + " values (?, ?, ?)");
687             assertEquals(3, st.bind_parameter_count());
688         } catch (Exception e) {
689             fail("Error in test setup : " + e.getMessage());
690             e.printStackTrace();
691         }
692 
693         try {
694             st = db.prepare("select * from " + DatabaseCreator.SIMPLE_TABLE1);
695             assertEquals(0, st.bind_parameter_count());
696         } catch (Exception e) {
697             fail("Error in test setup : " + e.getMessage());
698             e.printStackTrace();
699         }
700 
701         try {
702             st.close();
703             st.bind_parameter_count();
704             fail("Exception expected");
705         } catch (Exception e) {
706             //ok
707         }
708 
709     }
710 
711     /**
712      * @tests {@link Stmt#bind_parameter_name(int)}
713      */
714     @TestTargetNew(
715         level = TestLevel.COMPLETE,
716         notes = "method test",
717         method = "bind_parameter_name",
718         args = {int.class}
719     )
720     public void testBind_parameter_name() {
721         try {
722             st.bind_parameter_name(1);
723             fail("Exception expected");
724         } catch (Exception e) {
725             assertEquals("stmt already closed", e.getMessage());
726         }
727 
728         try {
729             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
730                     + " values (:one,:two,:three)");
731             assertEquals(":one", st.bind_parameter_name(1));
732             assertEquals(":two", st.bind_parameter_name(2));
733             assertEquals(":three", st.bind_parameter_name(3));
734             String name = st.bind_parameter_name(4);
735         } catch (Exception e) {
736             assertEquals("parameter position out of bounds",e.getMessage());
737         }
738     }
739 
740     /**
741      * @tests {@link Stmt#bind_parameter_index(String)}
742      */
743     @TestTargetNew(
744         level = TestLevel.COMPLETE,
745         notes = "method test",
746         method = "bind_parameter_index",
747         args = {java.lang.String.class}
748     )
749     public void testBind_parameter_index() {
750 
751         try {
752             st.bind_parameter_index("");
753             fail("Exception expected");
754         } catch (Exception e) {
755             assertEquals("stmt already closed", e.getMessage());
756         }
757 
758         try {
759             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
760                     + " values (:one,:two,:three)");
761             assertEquals(3, st.bind_parameter_index(":three"));
762         } catch (Exception e) {
763             fail("Error in test setup : " + e.getMessage());
764             e.printStackTrace();
765         }
766 
767         try {
768             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
769                     + " values (:one,:two,:three)");
770             assertEquals(0, st.bind_parameter_index(":t"));
771         } catch (Exception e) {
772             fail("Error in test setup : " + e.getMessage());
773             e.printStackTrace();
774         }
775 
776         try {
777             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
778                     + " values (?, ?, ?)");
779             assertEquals(0, st.bind_parameter_index("?"));
780         } catch (Exception e) {
781             fail("Error in test setup : " + e.getMessage());
782             e.printStackTrace();
783         }
784 
785     }
786 
787     /**
788      * @throws Exception
789      * @tests {@link Stmt#column_int(int)}
790      */
791     @TestTargetNew(
792         level = TestLevel.COMPLETE,
793         notes = "method test",
794         method = "column_int",
795         args = {int.class}
796     )
797     public void testColumn_int() throws Exception {
798         db.exec(createAllTypes, null);
799         db.exec(insertAllTypes, null);
800 
801         int columnObjectCastFromLong;
802         Object columnObject  = null;
803         int intColumn = 0;
804         String selectStmt = "select * from "+DatabaseCreator.SIMPLE_TABLE1;
805 
806         st = db.prepare(selectStmt);
807         st.step();
808         // select 'speed' value
809         columnObject = st.column(1);
810         intColumn = st.column_int(1);
811         assertNotNull(intColumn);
812 
813         assertTrue("Integer".equalsIgnoreCase(st.column_decltype(1)));
814         int stSpeed = Integer.parseInt(columnObject.toString());
815         assertNotNull(stSpeed);
816         assertEquals( intColumn, stSpeed);
817         assertEquals(10,stSpeed);
818 
819         selectStmt = "select TextVal from "+allTypesTable;
820 
821         st = db.prepare(selectStmt);
822         st.step();
823         // select double value
824         try {
825             st.column_int(0);
826         } catch (Exception e) {
827             //ok
828         }
829     }
830 
831     /**
832      * @tests {@link Stmt#column_long(int)}
833      */
834     @TestTargetNew(
835         level = TestLevel.COMPLETE,
836         notes = "method test",
837         method = "column_long",
838         args = {int.class}
839     )
840     public void testColumn_long() {
841         Object columnObject  = null;
842         int columnObjectCastFromLong;
843         long longColumn = 0;
844         try {
845             String selectStmt = "select * from "+DatabaseCreator.SIMPLE_TABLE1;
846             st = db.prepare(selectStmt);
847             st.step();
848             columnObject = st.column(1);
849             longColumn = st.column_long(1);
850             assertNotNull(longColumn);
851             // column declared as integer
852             assertTrue("Integer".equalsIgnoreCase(st.column_decltype(1)));
853             int stSpeed = Integer.parseInt(columnObject.toString());
854             assertNotNull(stSpeed);
855             assertEquals( longColumn, stSpeed);
856         } catch (Exception e) {
857             fail("Error in test setup : " + e.getMessage());
858             e.printStackTrace();
859         }
860 
861         try {
862             st.column_long(4);
863             fail("Exception expected");
864         } catch (Exception e) {
865             assertEquals( "column out of bounds" , e.getMessage());
866         }
867 
868         try {
869             st.column_long(-1);
870             fail("Exception expected");
871         } catch (Exception e) {
872             assertEquals( "column out of bounds" , e.getMessage());
873         }
874     }
875 
876     /**
877      * @throws Exception
878      * @tests {@link Stmt#column_double(int)}
879      */
880     @TestTargetNew(
881         level = TestLevel.COMPLETE,
882         notes = "method test",
883         method = "column_double",
884         args = {int.class}
885     )
886     public void testColumn_double() throws Exception {
887         db.exec(createAllTypes, null);
888         db.exec(insertAllTypes, null);
889 
890         Object columnObject  = null;
891         double doubleColumn = 0;
892         double actualVal = 23.2;
893         String selectStmt = "select DoubleVal from "+allTypesTable;
894 
895         st = db.prepare(selectStmt);
896         st.step();
897         // select double value
898         doubleColumn = st.column_double(0);
899         assertNotNull(doubleColumn);
900 
901         assertTrue("DOUBLE".equalsIgnoreCase(st.column_decltype(0)));
902         assertNotNull(doubleColumn);
903         assertEquals( actualVal, doubleColumn);
904 
905         // Exception test
906         selectStmt = "select dateVal from "+allTypesTable;
907 
908         st = db.prepare(selectStmt);
909         st.step();
910         // select double value
911         try {
912         st.column_double(0);
913         } catch (Exception e) {
914             //ok
915         }
916 
917 
918     }
919 
920     /**
921      * @throws Exception
922      * @tests {@link Stmt#column_bytes(int)}
923      */
924     @TestTargetNew(
925         level = TestLevel.NOT_FEASIBLE,
926         notes = "not supported",
927         method = "column_bytes",
928         args = {int.class}
929     )
930     public void testColumn_bytes() throws Exception {
931 
932         db.exec("create table B(id integer primary key, val blob)",null);
933         db.exec("insert into B values(1, zeroblob(128))", null);
934         st = db.prepare("select val from B where id = 1");
935         assertTrue(st.step());
936         try {
937             st.column_bytes(0);
938         } catch (Exception e) {
939             assertEquals("unsupported", e.getMessage());
940         }
941     }
942 
943     /**
944      * @throws Exception
945      * @tests {@link Stmt#column_string(int)}
946      */
947     @TestTargetNew(
948         level = TestLevel.COMPLETE,
949         notes = "method test",
950         method = "column_string",
951         args = {int.class}
952     )
953     public void testColumn_string() throws Exception {
954         db.exec(createAllTypes, null);
955         db.exec(insertAllTypes, null);
956 
957         Object columnObject  = null;
958         String stringColumn = "";
959         String actualVal = "test string";
960         String selectStmt = "select charStr from "+allTypesTable;
961 
962         st = db.prepare(selectStmt);
963         st.step();
964         // select string value
965         stringColumn = st.column_string(0);
966         assertNotNull(stringColumn);
967 
968         assertTrue("CHAR(20)".equalsIgnoreCase(st.column_decltype(0)));
969         assertNotNull(stringColumn);
970         assertEquals( actualVal, stringColumn);
971 
972         // Exception test
973         selectStmt = "select DoubleVal from "+allTypesTable;
974 
975         st = db.prepare(selectStmt);
976         st.step();
977         // select double value
978         try {
979         st.column_string(0);
980         } catch (Exception e) {
981             //ok
982         }
983     }
984 
985     public void testColumn_type() throws Exception {
986         db.exec(createAllTypes, null);
987         db.exec(insertAllTypes, null);
988         st = db.prepare("select * from " + allTypesTable);
989         st.step();
990 
991         // Exception test
992         try {
993             st.column_type(100);
994         } catch (Exception e) {
995             // ok
996         }
997 
998         /*
999         Dictionary
1000 
1001         public static final int SQLITE_INTEGER = 1;
1002         public static final int SQLITE_FLOAT = 2;
1003         public static final int SQLITE_BLOB = 4;
1004         public static final int SQLITE_NULL = 5;
1005         public static final int SQLITE3_TEXT = 3;
1006         public static final int SQLITE_NUMERIC = -1;
1007         */
1008 
1009         assertEquals(Constants.SQLITE3_TEXT, st.column_type(23)); // ok TEXT
1010         assertEquals(Constants.SQLITE3_TEXT, st.column_type(13)); // CHAR(20)
1011 
1012         assertEquals(Constants.SQLITE_FLOAT, st.column_type(8));
1013         assertEquals(Constants.SQLITE_FLOAT, st.column_type(9));
1014         assertEquals(Constants.SQLITE_FLOAT, st.column_type(10)); // FLOAT
1015 
1016         for (int i = 0; i < 8; i++) {
1017             assertEquals("Expected Integer at position " + i,
1018                     Constants.SQLITE_INTEGER, st.column_type(i));
1019         }
1020 
1021         assertEquals(Constants.SQLITE_NULL, st.column_type(28));
1022         assertEquals(Constants.SQLITE_NULL, st.column_type(29));
1023 
1024         // Failing tests
1025         assertTrue("INTEGER".equalsIgnoreCase(st.column_decltype(12)));
1026         assertEquals(Constants.SQLITE_INTEGER, st.column_type(12));
1027 
1028         assertTrue("FLOAT".equalsIgnoreCase(st.column_decltype(11)));
1029         assertEquals(Constants.SQLITE_FLOAT, st.column_type(11)); // FLOAT ->
1030                                                                   // got INTEGER
1031         assertTrue("BLOB".equalsIgnoreCase(st.column_decltype(19)));
1032         assertEquals(Constants.SQLITE_BLOB, st.column_type(19)); // Blob got
1033                                                                  // INTEGER
1034 
1035     }
1036 
1037     /**
1038      * @throws Exception
1039      * @tests {@link Stmt#column_count() )}
1040      */
1041     @TestTargetNew(
1042         level = TestLevel.COMPLETE,
1043         notes = "method test",
1044         method = "column_count",
1045         args = {}
1046     )
1047     @KnownFailure("Wrong value is returned in case of a prepared statment to "+
1048             "which a '*' bound ")
1049     public void testColumn_count() throws Exception {
1050 
1051         String selectStmt = "select * from "+DatabaseCreator.SIMPLE_TABLE1;
1052         st = db.prepare(selectStmt);
1053 
1054         assertEquals(3, st.column_count());
1055 
1056         st.step();
1057         int columnCount = st.column_count();
1058         assertNotNull(columnCount);
1059         assertEquals( 3, columnCount);
1060 
1061         // actual prepared statement
1062         selectStmt = "select ? from "+DatabaseCreator.SIMPLE_TABLE1;
1063         st = db.prepare(selectStmt);
1064 
1065         assertEquals(3, st.column_count());
1066 
1067         st.bind(1, "*");
1068         st.step();
1069         columnCount = st.column_count();
1070         assertNotNull(columnCount);
1071         assertEquals( 3, columnCount);
1072 
1073     }
1074 
1075     /**
1076      * @throws Exception
1077      * @tests {@link Stmt#column(int) )}
1078      */
1079     @TestTargetNew(
1080         level = TestLevel.COMPLETE,
1081         notes = "method test",
1082         method = "column",
1083         args = {int.class}
1084     )
1085     public void testColumn() throws Exception {
1086         Object columnObject  = null;
1087         int columnObjectCastFromLong;
1088         int intColumn = 0;
1089         try {
1090             String selectStmt = "select * from "+DatabaseCreator.SIMPLE_TABLE1;
1091             TableResult res = db.get_table(selectStmt);
1092             st = db.prepare(selectStmt);
1093             st.step();
1094             columnObject = st.column(1);
1095             intColumn = st.column_int(1);
1096             assertNotNull(intColumn);
1097             assertTrue("Integer".equalsIgnoreCase(st.column_decltype(1)));
1098             int stSpeed = Integer.parseInt(columnObject.toString());
1099             assertNotNull(stSpeed);
1100             assertEquals( intColumn, stSpeed);
1101         } catch (Exception e) {
1102             fail("Error in test setup : " + e.getMessage());
1103             e.printStackTrace();
1104         }
1105 
1106         try {
1107             assertNotNull(columnObject);
1108             int dummy = ((Integer) columnObject).intValue();
1109             fail("Cast to Integer should fail");
1110         } catch (ClassCastException e) {
1111             assertEquals("java.lang.Long", e.getMessage());
1112         }
1113 
1114         try {
1115             st.column(4);
1116             fail("Exception expected");
1117         } catch (Exception e) {
1118             assertEquals( "column out of bounds" , e.getMessage());
1119         }
1120 
1121         try {
1122             st.column(-1);
1123             fail("Exception expected");
1124         } catch (Exception e) {
1125             assertEquals( "column out of bounds" , e.getMessage());
1126         }
1127     }
1128 
1129     /**
1130      * @tests {@link Stmt#column_table_name(int)}
1131      */
1132     @TestTargetNew(
1133         level = TestLevel.NOT_FEASIBLE,
1134         notes = "not supported",
1135         method = "column_table_name",
1136         args = {int.class}
1137     )
1138     public void testColumn_table_name() {
1139         try {
1140             st = db.prepare("select * from " + DatabaseCreator.SIMPLE_TABLE1);
1141             String name = st.column_table_name(1);
1142            fail("Function is now supported.");
1143         } catch (Exception e) {
1144             assertEquals("unsupported", e.getMessage());
1145         }
1146     }
1147 
1148     /**
1149      * @tests {@link Stmt#column_database_name(int)}
1150      */
1151     @TestTargetNew(
1152         level = TestLevel.NOT_FEASIBLE,
1153         notes = "not supported",
1154         method = "column_database_name",
1155         args = {int.class}
1156     )
1157     public void testColumn_database_name() {
1158         try {
1159             st = db.prepare("insert into " + DatabaseCreator.SIMPLE_TABLE1
1160                     + " values (:one,:two,:three)");
1161             String name = st.column_database_name(1);
1162            fail("Function is now supported.");
1163         } catch (Exception e) {
1164             assertEquals("unsupported", e.getMessage());
1165         }
1166 
1167     }
1168 
1169     /**
1170      * @throws Exception
1171      * @tests {@link Stmt#column_decltype(int)}
1172      */
1173     @TestTargetNew(
1174         level = TestLevel.SUFFICIENT,
1175         notes = "method test",
1176         method = "column_decltype",
1177         args = {int.class}
1178     )
1179     public void testColumn_decltype() throws Exception {
1180         db.exec(createAllTypes, null);
1181         db.exec(insertAllTypes, null);
1182         st = db.prepare("select * from " + allTypesTable);
1183         st.step();
1184 
1185         // Exception test
1186         try {
1187             st.column_decltype(100);
1188         } catch (Exception e) {
1189             // ok
1190         }
1191 
1192         assertTrue(st.column_decltype(0), "BOOLEAN".equalsIgnoreCase(st
1193                 .column_decltype(0)));
1194         assertTrue(st.column_decltype(1), "INT".equalsIgnoreCase(st
1195                 .column_decltype(1)));
1196         assertTrue(st.column_decltype(2), "LONG".equalsIgnoreCase(st
1197                 .column_decltype(2)));
1198         assertTrue(st.column_decltype(3), "BIGINT".equalsIgnoreCase(st
1199                 .column_decltype(3)));
1200         assertTrue(st.column_decltype(4), "TINYINT".equalsIgnoreCase(st
1201                 .column_decltype(4)));
1202         assertTrue(st.column_decltype(5), "SMALLINT".equalsIgnoreCase(st
1203                 .column_decltype(5)));
1204         assertTrue(st.column_decltype(6), "MEDIUMINT".equalsIgnoreCase(st
1205                 .column_decltype(6)));
1206         assertTrue(st.column_decltype(7), "INTEGER".equalsIgnoreCase(st
1207                 .column_decltype(7)));
1208         assertTrue(st.column_decltype(8), "REAL".equalsIgnoreCase(st
1209                 .column_decltype(8)));
1210         assertTrue(st.column_decltype(9), "DOUBLE".equalsIgnoreCase(st
1211                 .column_decltype(9)));
1212         assertTrue(st.column_decltype(10), "FLOAT".equalsIgnoreCase(st
1213                 .column_decltype(10)));
1214         assertTrue(st.column_decltype(11), "DECIMAL".equalsIgnoreCase(st
1215                 .column_decltype(11)));
1216         assertTrue(st.column_decltype(12), "NUMERIC".equalsIgnoreCase(st
1217                 .column_decltype(12)));
1218         assertTrue(st.column_decltype(13), "CHAR(20)".equalsIgnoreCase(st
1219                 .column_decltype(13)));
1220 
1221         assertTrue(st.column_decltype(19), "BLOB".equalsIgnoreCase(st
1222                 .column_decltype(19)));
1223 
1224         assertTrue(st.column_decltype(23), "TEXT".equalsIgnoreCase(st
1225                 .column_decltype(23)));
1226         assertTrue(st.column_decltype(28), "URL".equalsIgnoreCase(st
1227                 .column_decltype(28)));
1228         assertTrue(st.column_decltype(29), "URL".equalsIgnoreCase(st
1229                 .column_decltype(29)));
1230     }
1231 
1232     /**
1233      * @tests {@link Stmt#column_origin_name(int)}
1234      */
1235     @TestTargetNew(
1236         level = TestLevel.NOT_FEASIBLE,
1237         notes = "not supported",
1238         method = "column_origin_name",
1239         args = {int.class}
1240     )
1241     public void testColumn_origin_name() {
1242         try {
1243             st = db.prepare("select * from " + DatabaseCreator.SIMPLE_TABLE1);
1244             String name = st.column_origin_name(1);
1245            fail("Function is now supported.");
1246         } catch (Exception e) {
1247             assertEquals("unsupported", e.getMessage());
1248         }
1249     }
1250 }
1251