BF [ 1990856 ] PO.set_Value* : truncate string more than needed

* fixed minor saveEx/deleteEx issue
This commit is contained in:
teo_sarca 2008-06-11 14:22:55 +00:00
parent c473d0d1a9
commit b71f4b88c3
2 changed files with 56 additions and 7 deletions

View File

@ -69,6 +69,7 @@ import org.w3c.dom.Element;
* <li>FR [ 1675490 ] ModelValidator on modelChange after events
* <li>BF [ 1704828 ] PO.is_Changed() and PO.is_ValueChanged are not consistent
* <li>FR [ 1720995 ] Add PO.saveEx() and PO.deleteEx() methods
* <li>BF [ 1990856 ] PO.set_Value* : truncate string more than needed
*/
public abstract class PO
implements Serializable, Comparator, Evaluatee
@ -765,10 +766,11 @@ public abstract class PO
if (stringValue.length() > length && length > 0)
{
log.warning(ColumnName + " - Value too long - truncated to length=" + length);
m_newValues[index] = stringValue.substring(0,length-1);
m_newValues[index] = stringValue.substring(0,length);
}
}
log.finest(ColumnName + " = " + m_newValues[index]);
if (CLogMgt.isLevelFinest())
log.finest(ColumnName + " = " + m_newValues[index] + " (OldValue="+m_oldValues[index]+")");
}
set_Keys (ColumnName, m_newValues[index]);
return true;
@ -841,7 +843,7 @@ public abstract class PO
if (stringValue.length() > length && length > 0)
{
log.warning(ColumnName + " - Value too long - truncated to length=" + length);
m_newValues[index] = stringValue.substring(0,length-1);
m_newValues[index] = stringValue.substring(0,length);
}
}
}
@ -1965,7 +1967,7 @@ public abstract class PO
ValueNamePair err = CLogger.retrieveError();
if (err != null)
msg = err.getName();
if (msg == null)
if (msg == null || msg.length() == 0)
msg = "SaveError";
throw new AdempiereException(msg);
}
@ -2842,7 +2844,7 @@ public abstract class PO
ValueNamePair err = CLogger.retrieveError();
if (err != null)
msg = err.getName();
if (msg == null)
if (msg == null || msg.length() == 0)
msg = "DeleteError";
throw new AdempiereException(msg);
}

View File

@ -1,13 +1,13 @@
package test.functional;
import org.compiere.model.MTest;
import org.compiere.model.POInfo;
import test.AdempiereTestCase;
/**
* Tests for {@link org.compiere.model.PO} class.
* @author Teo Sarca
*
* @author Teo Sarca, SC ARHIPAC SERVICE SRL
*/
public class POTest extends AdempiereTestCase
{
@ -58,4 +58,51 @@ public class POTest extends AdempiereTestCase
// Finally, delete the testPO
testPO.delete(true, getTrxName());
}
/**
* <li>BF [ 1990856 ] PO.set_Value* : truncate string more than needed
*/
public void testTruncatedStrings() {
//
// Creating a huge string for testing:
StringBuffer sb = new StringBuffer();
for (int i = 1; i <= 1000; i++) {
sb.append("0123456789");
}
String bigString = sb.toString();
//
// Create the test PO:
MTest testPO = new MTest(getCtx(), getClass().getName(), 1);
testPO.set_TrxName(getTrxName());
//
// Getting Max Length:
POInfo info = POInfo.getPOInfo(getCtx(), MTest.Table_ID);
int maxLength = info.getFieldLength(info.getColumnIndex(MTest.COLUMNNAME_Name));
//
// Test with a string that has less then maxLength
{
testPO.set_ValueOfColumn(MTest.COLUMNNAME_Name, bigString.substring(0, maxLength - 1));
String resultString = (String) testPO.get_Value(MTest.COLUMNNAME_Name);
assertEquals("String was not truncated correctly (1)", maxLength - 1, resultString.length());
}
//
// Test with a string that has maxLength
{
testPO.set_ValueOfColumn(MTest.COLUMNNAME_Name, bigString.substring(0, maxLength));
String resultString = (String) testPO.get_Value(MTest.COLUMNNAME_Name);
assertEquals("String was not truncated correctly (2)", maxLength, resultString.length());
}
//
// Test with a string that has more than maxLength
{
testPO.set_ValueOfColumn(MTest.COLUMNNAME_Name, bigString);
String resultString = (String) testPO.get_Value(MTest.COLUMNNAME_Name);
assertEquals("String was not truncated correctly (3)", maxLength, resultString.length());
}
//
// Finally, delete the testPO
testPO.delete(true, getTrxName());
}
}