1561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes/*
2561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * Licensed to the Apache Software Foundation (ASF) under one or more
3561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * contributor license agreements.  See the NOTICE file distributed with
4561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * this work for additional information regarding copyright ownership.
5561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * The ASF licenses this file to You under the Apache License, Version 2.0
6561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * (the "License"); you may not use this file except in compliance with
7561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * the License.  You may obtain a copy of the License at
8561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
9561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *     http://www.apache.org/licenses/LICENSE-2.0
10561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes *
11561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * Unless required by applicable law or agreed to in writing, software
12561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * distributed under the License is distributed on an "AS IS" BASIS,
13561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * See the License for the specific language governing permissions and
15561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes * limitations under the License.
16561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes */
17561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
18561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespackage org.apache.harmony.sql.tests.java.sql;
19561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
20561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.lang.reflect.Field;
21561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.lang.reflect.Modifier;
22561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport java.util.HashMap;
23561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
24561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughesimport junit.framework.TestCase;
25561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
26561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughespublic class ResultSetMetaDataTest extends TestCase {
27561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
28561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    /*
29561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes     * Public statics test
30561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes     */
31561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    public void testPublicStatics() {
32561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
33561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        HashMap<String, Integer> thePublicStatics = new HashMap<String, Integer>();
34561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        thePublicStatics.put("columnNullableUnknown", new Integer(2));
35561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        thePublicStatics.put("columnNullable", new Integer(1));
36561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        thePublicStatics.put("columnNoNulls", new Integer(0));
37561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
38561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        /*
39561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         * System.out.println( "columnNullableUnknown: " +
40561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         * ResultSetMetaData.columnNullableUnknown ); System.out.println(
41561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         * "columnNullable: " + ResultSetMetaData.columnNullable );
42561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         * System.out.println( "columnNoNulls: " +
43561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         * ResultSetMetaData.columnNoNulls );
44561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes         */
45561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
46561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        Class<?> resultSetMetaDataClass;
47561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        try {
48561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            resultSetMetaDataClass = Class
49561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    .forName("java.sql.ResultSetMetaData");
50561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        } catch (ClassNotFoundException e) {
51561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            fail("java.sql.ResultSetMetaData class not found!");
52561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            return;
53561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        } // end try
54561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
55561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        Field[] theFields = resultSetMetaDataClass.getDeclaredFields();
56561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        int requiredModifier = Modifier.PUBLIC + Modifier.STATIC
57561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                + Modifier.FINAL;
58561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
59561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        int countPublicStatics = 0;
60561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        for (Field element : theFields) {
61561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            String fieldName = element.getName();
62561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            int theMods = element.getModifiers();
63561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            if (Modifier.isPublic(theMods) && Modifier.isStatic(theMods)) {
64561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                try {
65561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    Object fieldValue = element.get(null);
66561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    Object expectedValue = thePublicStatics.get(fieldName);
67561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    if (expectedValue == null) {
68561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                        fail("Field " + fieldName + " missing!");
69561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    } // end
70561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    assertEquals("Field " + fieldName + " value mismatch: ",
71561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                            expectedValue, fieldValue);
72561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    assertEquals("Field " + fieldName + " modifier mismatch: ",
73561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                            requiredModifier, theMods);
74561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    countPublicStatics++;
75561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                } catch (IllegalAccessException e) {
76561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                    fail("Illegal access to Field " + fieldName);
77561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes                } // end try
78561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes            } // end if
79561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes        } // end for
80561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
81561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes    } // end method testPublicStatics
82561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
83561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes} // end class ResultSetMetaDataTest
84561ee011997c6c2f1befbfaa9d5f0a99771c1d63Elliott Hughes
85