Support SQL exception translation for MSSQL 209
SQL Server error 209 [1] will now raise a BadSqlGrammarException. [1]: http://www.sql-server-helper.com/error-messages/msg-1-500.aspx Issue: SPR-9946
This commit is contained in:
parent
1070e4d5c1
commit
74e86fe52f
|
@ -121,7 +121,7 @@
|
|||
<value>Microsoft SQL Server</value>
|
||||
</property>
|
||||
<property name="badSqlGrammarCodes">
|
||||
<value>156,170,207,208</value>
|
||||
<value>156,170,207,208,209</value>
|
||||
</property>
|
||||
<property name="permissionDeniedCodes">
|
||||
<value>229</value>
|
||||
|
|
|
@ -24,11 +24,14 @@ import java.util.Arrays;
|
|||
import javax.sql.DataSource;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
import org.easymock.MockControl;
|
||||
|
||||
import org.easymock.MockControl;
|
||||
import org.springframework.core.io.ClassPathResource;
|
||||
import org.springframework.core.io.Resource;
|
||||
|
||||
import static org.hamcrest.CoreMatchers.*;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Tests for SQLErrorCodes loading.
|
||||
*
|
||||
|
@ -64,6 +67,40 @@ public class SQLErrorCodesFactoryTests extends TestCase {
|
|||
assertFalse(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "9xx42") >= 0);
|
||||
}
|
||||
|
||||
private void assertIsSQLServer(SQLErrorCodes sec) {
|
||||
assertThat(sec.getDatabaseProductName(), equalTo("Microsoft SQL Server"));
|
||||
|
||||
assertTrue(sec.getBadSqlGrammarCodes().length > 0);
|
||||
|
||||
assertTrue(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "156") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "170") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "207") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "208") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "209") >= 0);
|
||||
assertFalse(Arrays.binarySearch(sec.getBadSqlGrammarCodes(), "9xx42") >= 0);
|
||||
|
||||
assertTrue(sec.getPermissionDeniedCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getPermissionDeniedCodes(), "229") >= 0);
|
||||
|
||||
assertTrue(sec.getDuplicateKeyCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDuplicateKeyCodes(), "2601") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDuplicateKeyCodes(), "2627") >= 0);
|
||||
|
||||
assertTrue(sec.getDataIntegrityViolationCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDataIntegrityViolationCodes(), "544") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDataIntegrityViolationCodes(), "8114") >= 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDataIntegrityViolationCodes(), "8115") >= 0);
|
||||
|
||||
assertTrue(sec.getDataAccessResourceFailureCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDataAccessResourceFailureCodes(), "4060") >= 0);
|
||||
|
||||
assertTrue(sec.getCannotAcquireLockCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getCannotAcquireLockCodes(), "1222") >= 0);
|
||||
|
||||
assertTrue(sec.getDeadlockLoserCodes().length > 0);
|
||||
assertTrue(Arrays.binarySearch(sec.getDeadlockLoserCodes(), "1205") >= 0);
|
||||
}
|
||||
|
||||
private void assertIsHsql(SQLErrorCodes sec) {
|
||||
assertTrue(sec.getBadSqlGrammarCodes().length > 0);
|
||||
assertTrue(sec.getDataIntegrityViolationCodes().length > 0);
|
||||
|
@ -252,6 +289,11 @@ public class SQLErrorCodesFactoryTests extends TestCase {
|
|||
return sec;
|
||||
}
|
||||
|
||||
public void testSQLServerRecognizedFromMetadata() throws Exception {
|
||||
SQLErrorCodes sec = getErrorCodesFromDataSource("MS-SQL", null);
|
||||
assertIsSQLServer(sec);
|
||||
}
|
||||
|
||||
public void testOracleRecognizedFromMetadata() throws Exception {
|
||||
SQLErrorCodes sec = getErrorCodesFromDataSource("Oracle", null);
|
||||
assertIsOracle(sec);
|
||||
|
|
Loading…
Reference in New Issue