📄 testcollation.java
字号:
/* Copyright (c) 2001-2005, The HSQL Development Group * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * Neither the name of the HSQL Development Group nor the names of its * contributors may be used to endorse or promote products derived from this * software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG, * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */package org.hsqldb.test;import junit.framework.TestCase;import junit.framework.TestResult;/** * Test HSQLDBs collation capabilities * @author frank.schoenheit@sun.com */public class TestCollation extends TestBase { java.sql.Statement statement; java.sql.Connection connection; org.hsqldb.Collation collation; org.hsqldb.lib.Iterator collIterator; org.hsqldb.lib.Iterator localeIterator; /** Creates a new instance of TestCollation */ public TestCollation(String name) { super(name); super.isNetwork = false; } protected void setUp() { super.setUp(); try { connection = super.newConnection(); statement = connection.createStatement(); } catch (Exception e) {} collation = new org.hsqldb.Collation(); collIterator = collation.getCollationsIterator(); localeIterator = collation.getLocalesIterator(); } protected void tearDown() { try { statement = connection.createStatement(); statement.execute("SHUTDOWN"); } catch (Exception e) {} super.tearDown(); } /** * checks whether expected locales are present and selectable */ public void verifyAvailability() { // let's check whether unknown collation identifiers are rejected try { statement.execute( getSetCollationStmt( "ThisIsDefinatelyNoValidCollationIdentifier")); fail("database did not reject invalid collation name"); } catch (java.sql.SQLException e) {} // let's check whether the DB accepts all known collations int count = 0; while (collIterator.hasNext()) { String collationName = (String) collIterator.next(); try { statement.execute(getSetCollationStmt(collationName)); } catch (java.sql.SQLException e) { fail("could not set collation '" + collationName + "'\n exception message: " + e.getMessage()); } ++count; } System.out.println("checked " + count + " collations for availability."); // even if the above worked, we cannot be sure that all locales are really supported. // The fact that SET DATABASE COLLATION succeeeded only means that a Collator could // be instantiated with a Locale matching the given collation name. But what if // Locale.Instance(...) lied, and returned a fallback Locale instance? // // Hmm, looking at the documentation of Locale.getAvailableLocales, I'm not sure // whether it is really feasible. The doc states "returns a list of all installed Locales". // The "installed" puzzles me - maybe this is really different per installation, and not only // per JDK version? java.util.Locale[] availableLocales = java.util.Locale.getAvailableLocales(); org.hsqldb.lib.Set existenceCheck = new org.hsqldb.lib.HashSet(); for (int i = 0; i < availableLocales.length; ++i) { String availaleName = availableLocales[i].getLanguage(); if (availableLocales[i].getCountry().length() > 0) { availaleName += "-" + availableLocales[i].getCountry(); } existenceCheck.add(availaleName); } String notInstalled = ""; int expected = 0, failed = 0; while (localeIterator.hasNext()) { String localeName = (String) localeIterator.next(); ++expected; if (!existenceCheck.contains(localeName)) { if (notInstalled.length() > 0) { notInstalled += "; "; } notInstalled += localeName; ++failed; } } if (notInstalled.length() > 0) { fail("the following locales are not installed:\n " + notInstalled + "\n (" + failed + " out of " + expected + ")"); } } /** * checks whether sorting via a given collation works as expected */ public void verifyCollation() { String failedCollations = ""; String failMessage = ""; while (collIterator.hasNext()) { String collationName = (String) collIterator.next(); String message = checkSorting(collationName); if (message.length() > 0) { if (failedCollations.length() > 0) { failedCollations += ", "; } failedCollations += collationName; failMessage += message; } } if (failedCollations.length() > 0) { fail("test failed for following collations:\n" + failedCollations + "\n" + failMessage); } } /** * returns an SQL statement to set the database collation */ protected final String getSetCollationStmt(String collationName) { final String setCollationStmtPre = "SET DATABASE COLLATION \""; final String setCollationStmtPost = "\""; return setCollationStmtPre + collationName + setCollationStmtPost; } /** * checks sorting a table with according to a given collation */ protected String checkSorting(String collationName) { String prepareStmt = "DROP TABLE WORDLIST IF EXISTS;" + "CREATE TEXT TABLE WORDLIST ( ID INTEGER, WORD VARCHAR );" + "SET TABLE WORDLIST SOURCE \"" + collationName + ".csv;encoding=UTF-8\""; String selectStmt = "SELECT ID, WORD FROM WORDLIST ORDER BY WORD"; String returnMessage = ""; try { // set database collation statement.execute(getSetCollationStmt(collationName)); statement.execute(prepareStmt); java.sql.ResultSet results = statement.executeQuery(selectStmt); while (results.next()) { int expectedPosition = results.getInt(1); int foundPosition = results.getRow(); if (expectedPosition != foundPosition) { String word = results.getString(2); return "testing collation '" + collationName + "' failed\n" + " word : " + word + "\n" + " expected position : " + expectedPosition + "\n" + " found position : " + foundPosition + "\n"; } } } catch (java.sql.SQLException e) { return "testing collation '" + collationName + "' failed\n exception message: " + e.getMessage() + "\n"; } return ""; } public static void main(String[] argv) { TestResult result = new TestResult(); TestCase availability = new TestCollation("verifyAvailability"); availability.run(result); TestCase sorting = new TestCollation("verifyCollation"); sorting.run(result); if (result.failureCount() != 0) { System.err.println("TestCollation encountered errors:"); java.util.Enumeration failures = result.failures(); while (failures.hasMoreElements()) { System.err.println(failures.nextElement().toString()); } } else { System.out.println("TestCollation: all fine."); } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -