/*
Copyright (c) 2002, 2011, Oracle and/or its affiliates. All rights reserved.
The MySQL Connector/J is licensed under the terms of the GPLv2
<http://www.gnu.org/licenses/old-licenses/gpl-2.0.html>, like most MySQL Connectors.
There are special exceptions to the terms and conditions of the GPLv2 as it is applied to
this software, see the FLOSS License Exception
<http://www.mysql.com/about/legal/licensing/foss-exception.html>.
This program is free software; you can redistribute it and/or modify it under the terms
of the GNU General Public License as published by the Free Software Foundation; version 2
of the License.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this
program; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth
Floor, Boston, MA 02110-1301 USA
*/
package testsuite.regression;
import java.lang.reflect.Method;
import java.sql.ResultSet;
import javax.sql.RowSet;
import testsuite.BaseTestCase;
/**
* Regression test cases for the ResultSet class.
*
* @author Eric Herman
*/
public class CachedRowsetTest extends BaseTestCase {
/**
* Creates a new CachedRowsetTest
*
* @param name
* the name of the test to run
*/
public CachedRowsetTest(String name) {
super(name);
}
/**
* Runs all test cases in this test suite
*
* @param args
*/
public static void main(String[] args) {
junit.textui.TestRunner.run(CachedRowsetTest.class);
}
/**
* Tests fix for BUG#5188, CachedRowSet errors using PreparedStatement. Uses
* Sun's "com.sun.rowset.CachedRowSetImpl"
*
* @throws Exception
*/
public void testBug5188() throws Exception {
String implClass = "com.sun.rowset.CachedRowSetImpl";
Class<?> c;
Method populate;
try {
c = Class.forName(implClass);
} catch (ClassNotFoundException e) {
System.out.println("skipping testBug5188. Requires: " + implClass);
return;
}
populate = c.getMethod("populate", new Class[] { ResultSet.class });
createTable("testBug5188", "(ID int NOT NULL AUTO_INCREMENT, "
+ "datafield VARCHAR(64), " + "PRIMARY KEY(ID))");
this.stmt.executeUpdate("INSERT INTO testBug5188(datafield) "
+ "values('test data stuff !')");
String sql = "SELECT * FROM testBug5188 where ID = ?";
this.pstmt = this.conn.prepareStatement(sql);
this.pstmt.setString(1, "1");
this.rs = this.pstmt.executeQuery();
// create a CachedRowSet and populate it
RowSet cachedRowSet = (RowSet) c.newInstance();
// cachedRowSet.populate(rs);
populate.invoke(cachedRowSet, new Object[] { this.rs });
// scroll through CachedRowSet ...
assertTrue(cachedRowSet.next());
assertEquals("1", cachedRowSet.getString("ID"));
assertEquals("test data stuff !", cachedRowSet.getString("datafield"));
assertFalse(cachedRowSet.next());
}
}