Skip to content

Commit

Permalink
8294989: ResourceBundle naming convention issue in JdbcRowSetResource…
Browse files Browse the repository at this point in the history
…Bundle.java

Reviewed-by: naoto, lancea, bchristi
  • Loading branch information
justin-curtis-lu authored and naotoj committed Oct 25, 2022
1 parent 0caea81 commit d393e05
Show file tree
Hide file tree
Showing 3 changed files with 150 additions and 1 deletion.
Expand Up @@ -80,7 +80,7 @@ public class JdbcRowSetResourceBundle implements Serializable {
* The variable where the default resource bundle will
* be placed.
**/
private static final String PATH = "com/sun/rowset/RowSetResourceBundle";
private static final String PATH = "com.sun.rowset.RowSetResourceBundle";

/**
* The constructor which initializes the resource bundle.
Expand Down
77 changes: 77 additions & 0 deletions test/jdk/javax/sql/resourceBundleTests/ValidateGetBundle.java
@@ -0,0 +1,77 @@
/*
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/

import com.sun.rowset.JdbcRowSetResourceBundle;

import java.util.Locale;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import java.util.stream.Stream;
import org.junit.jupiter.params.ParameterizedTest;
import org.junit.jupiter.params.provider.MethodSource;
import org.junit.jupiter.params.provider.Arguments;

/**
* @test
* @bug 8294989
* @summary Check JDBC RowSet resource bundle access
* @modules java.sql.rowset/com.sun.rowset:+open
* @run junit/othervm ValidateGetBundle
*/
public class ValidateGetBundle{

// Data provider for testResourceBundleAccess
private static Stream<Arguments> bundleProvider() {
return Stream.of(
// The resource bundle should be found with the fully qualified class name
Arguments.of("com.sun.rowset.RowSetResourceBundle", true),
// The resource bundle will not be found when the path is specified
Arguments.of("com/sun/rowset/RowSetResourceBundle", false)
);
}

/**
* Test to validate whether the JDBC RowSet Resource bundle can be found
* @param bundleName the base name of the resource bundle
* @param expectBundle indicates whether the resource bundle should be found
*/
@ParameterizedTest
@MethodSource("bundleProvider")
void testResourceBundleAccess(String bundleName, boolean expectBundle) {
try {
var bundle = ResourceBundle.getBundle(bundleName,
Locale.US, JdbcRowSetResourceBundle.class.getModule());
if (!expectBundle) {
throw new RuntimeException(
String.format("$$$ Error: '%s' shouldn't have loaded!%n", bundleName));
}
System.out.printf("$$$ %s was found as expected!%n", bundleName);
} catch (MissingResourceException mr) {
if (expectBundle) {
throw new RuntimeException(
String.format("$$$ Error: '%s' should have loaded!", bundleName), mr);
}
System.out.printf("$$$ %s was not found as expected!", bundleName);
}
}
}
@@ -0,0 +1,72 @@
/*
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code 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
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package test.rowset;

import java.util.Locale;
import java.sql.SQLException;
import javax.sql.rowset.RowSetProvider;
import org.testng.annotations.Test;
import org.testng.annotations.BeforeClass;
import static org.testng.Assert.*;

/**
* @test
* @bug 8294989
* @summary Check that the resource bundle can be accessed
* @throws SQLException if an unexpected error occurs
* @run testng/othervm
*/
public class ValidateResourceBundleAccess{
// Expected JDBCResourceBundle message, jdbcrowsetimpl.invalstate
private static final String INVALIDSTATE = "Invalid state";
// Expected JDBCResourceBundle message, crsreader.connecterr
private static final String RSREADERERROR = "Internal Error in RowSetReader: no connection or command";

// Checking against English messages, set to US Locale
@BeforeClass
public void setEnglishEnvironment() {
Locale.setDefault(Locale.US);
}

@Test
public void testResourceBundleAccess() throws SQLException {
var rsr = RowSetProvider.newFactory();
var crs =rsr.createCachedRowSet();
var jrs = rsr.createJdbcRowSet();
// Simple test to force an Exception to validate the expected message
// is found from the resource bundle
try {
jrs.getMetaData();
throw new RuntimeException("$$$ Expected SQLException was not thrown!");
} catch (SQLException sqe) {
assertTrue(sqe.getMessage().equals(INVALIDSTATE));
}
// Now tests via CachedRowSet
try {
crs.execute();
throw new RuntimeException("$$$ Expected SQLException was not thrown!");
} catch (SQLException e) {
assertTrue(e.getMessage().equals(RSREADERERROR));
}
}
}

1 comment on commit d393e05

@openjdk-notifier
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.