FR [2799327] - Allow testing of accounting posting in development mode

https://sourceforge.net/tracker/?func=detail&aid=2799327&group_id=176962&atid=879335
Revert revisions 10154 and 10157
This commit is contained in:
Carlos Ruiz 2009-09-13 00:46:54 +00:00
parent 95dd9ab501
commit 77ca1c2603
6 changed files with 13 additions and 50 deletions

View File

@ -28,7 +28,6 @@ import java.util.Iterator;
import java.util.Properties; import java.util.Properties;
import java.util.logging.Level; import java.util.logging.Level;
import org.compiere.db.CConnection;
import org.compiere.model.MAccount; import org.compiere.model.MAccount;
import org.compiere.model.MAcctSchema; import org.compiere.model.MAcctSchema;
import org.compiere.model.MAllocationHdr; import org.compiere.model.MAllocationHdr;
@ -57,7 +56,6 @@ import org.compiere.process.DocumentEngine;
import org.compiere.util.CLogger; import org.compiere.util.CLogger;
import org.compiere.util.DB; import org.compiere.util.DB;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Ini;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.compiere.util.Trx; import org.compiere.util.Trx;
@ -375,7 +373,7 @@ public abstract class Doc
* @param defaultDocumentType default document type or null * @param defaultDocumentType default document type or null
* @param trxName trx * @param trxName trx
*/ */
Doc (MAcctSchema[] ass, Class<?> clazz, ResultSet rs, String defaultDocumentType, String trxName) Doc (MAcctSchema[] ass, Class clazz, ResultSet rs, String defaultDocumentType, String trxName)
{ {
p_Status = STATUS_Error; p_Status = STATUS_Error;
m_ass = ass; m_ass = ass;
@ -386,7 +384,7 @@ public abstract class Doc
className = className.substring(className.lastIndexOf('.')+1); className = className.substring(className.lastIndexOf('.')+1);
try try
{ {
Constructor<?> constructor = clazz.getConstructor(new Class[]{Properties.class, ResultSet.class, String.class}); Constructor constructor = clazz.getConstructor(new Class[]{Properties.class, ResultSet.class, String.class});
p_po = (PO)constructor.newInstance(new Object[]{m_ctx, rs, trxName}); p_po = (PO)constructor.newInstance(new Object[]{m_ctx, rs, trxName});
} }
catch (Exception e) catch (Exception e)
@ -566,12 +564,7 @@ public abstract class Doc
sql.append(" AND (Processing='N' OR Processing IS NULL)"); sql.append(" AND (Processing='N' OR Processing IS NULL)");
if (!repost) if (!repost)
sql.append(" AND Posted='N'"); sql.append(" AND Posted='N'");
// Set transaction to lock record if (DB.executeUpdate(sql.toString(), null) == 1) // outside trx
String trxName = null; // outside trx
if (Ini.isClient() && CConnection.isServerEmbedded())
trxName = getTrxName(); // within trx if server embedded in client
//
if (DB.executeUpdate(sql.toString(), trxName) == 1)
log.info("Locked: " + get_TableName() + "_ID=" + get_ID()); log.info("Locked: " + get_TableName() + "_ID=" + get_ID());
else else
{ {

View File

@ -1604,9 +1604,7 @@ public class CConnection implements Serializable, Cloneable
* @return true if server is embedded in process * @return true if server is embedded in process
*/ */
public static boolean isServerEmbedded() { public static boolean isServerEmbedded() {
// defaults to true - it can be disabled passing this parameter to the JVM return "true".equalsIgnoreCase(System.getProperty(SERVER_EMBEDDED));
// -Dorg.adempiere.server.embedded=false
return ! "false".equalsIgnoreCase(System.getProperty(SERVER_EMBEDDED));
} }
public void setAppServerCredential(String principal, String credential) public void setAppServerCredential(String principal, String credential)

View File

@ -39,7 +39,7 @@ public class MFactAcct extends X_Fact_Acct
/** /**
* *
*/ */
private static final long serialVersionUID = -5110168625445057323L; private static final long serialVersionUID = 5251847162314796574L;
/** /**
* Delete Accounting * Delete Accounting
@ -134,20 +134,5 @@ public class MFactAcct extends X_Fact_Acct
acct.save(); acct.save();
return acct; return acct;
} // getMAccount } // getMAccount
/**
* Check if there are already accounting facts for the document
* @param AD_Table_ID table
* @param Record_ID record
* @param trxName transaction
* @return true/false meaning if there are records or not
* @throws DBException on database exception
*/
public static boolean thereAreFacts(int AD_Table_ID, int Record_ID, String trxName) throws DBException
{
final String sql = "SELECT 1 FROM Fact_Acct WHERE AD_Table_ID=? AND Record_ID=?";
int one = DB.getSQLValue(trxName, sql, new Object[]{AD_Table_ID, Record_ID});
return (one == 1);
}
} // MFactAcct } // MFactAcct

View File

@ -285,9 +285,8 @@ public class DocumentEngine implements DocAction
return false; return false;
} }
status = completeIt(); status = completeIt();
if (m_document != null if (m_document != null
&& ( (Ini.isClient() && CConnection.isServerEmbedded()) && !Ini.isClient()) // Post Immediate if on Server
|| !Ini.isClient())) // Post Immediate if on Server or embedded server
{ {
MClient client = MClient.get(m_document.getCtx(), m_document.getAD_Client_ID()); MClient client = MClient.get(m_document.getCtx(), m_document.getAD_Client_ID());
if (STATUS_Completed.equals(status) && client.isPostImmediate()) if (STATUS_Completed.equals(status) && client.isPostImmediate())
@ -465,13 +464,10 @@ public class DocumentEngine implements DocAction
Server server = CConnection.get().getServer(); Server server = CConnection.get().getServer();
if (server != null) if (server != null)
{ {
String trxName = null;
if (Ini.isClient() && CConnection.isServerEmbedded())
trxName = m_document.get_TrxName();
String error = server.postImmediate(Env.getRemoteCallCtx(Env.getCtx()), String error = server.postImmediate(Env.getRemoteCallCtx(Env.getCtx()),
m_document.getAD_Client_ID(), m_document.getAD_Client_ID(),
m_document.get_Table_ID(), m_document.get_ID(), m_document.get_Table_ID(), m_document.get_ID(),
true, trxName); true, null);
m_document.get_Logger().config("Server: " + error == null ? "OK" : error); m_document.get_Logger().config("Server: " + error == null ? "OK" : error);
return error == null; return error == null;
} }

View File

@ -38,7 +38,6 @@ import org.compiere.model.MBPartner;
import org.compiere.model.MClient; import org.compiere.model.MClient;
import org.compiere.model.MColumn; import org.compiere.model.MColumn;
import org.compiere.model.MConversionRate; import org.compiere.model.MConversionRate;
import org.compiere.model.MFactAcct;
import org.compiere.model.MMailText; import org.compiere.model.MMailText;
import org.compiere.model.MNote; import org.compiere.model.MNote;
import org.compiere.model.MOrg; import org.compiere.model.MOrg;
@ -58,9 +57,9 @@ import org.compiere.print.ReportEngine;
import org.compiere.process.DocAction; import org.compiere.process.DocAction;
import org.compiere.process.ProcessInfo; import org.compiere.process.ProcessInfo;
import org.compiere.process.StateEngine; import org.compiere.process.StateEngine;
import org.compiere.util.CLogger;
import org.compiere.util.DisplayType; import org.compiere.util.DisplayType;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Ini;
import org.compiere.util.Msg; import org.compiere.util.Msg;
import org.compiere.util.Trace; import org.compiere.util.Trace;
import org.compiere.util.Trx; import org.compiere.util.Trx;
@ -79,7 +78,8 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
/** /**
* *
*/ */
private static final long serialVersionUID = 1584816335412184476L; private static final long serialVersionUID = 2104882570953130237L;
/** /**
* Get Activities for table/record * Get Activities for table/record
@ -1504,11 +1504,6 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
*/ */
private void postImmediate() private void postImmediate()
{ {
String trxName = null;
if (Ini.isClient() && CConnection.isServerEmbedded())
trxName = m_postImmediate.get_TrxName();
if (MFactAcct.thereAreFacts(m_postImmediate.get_Table_ID(), m_postImmediate.get_ID(), trxName))
return; // the document was already posted in DocumentEngine.processIt
if (CConnection.get().isAppsServerOK(false)) if (CConnection.get().isAppsServerOK(false))
{ {
try try
@ -1519,7 +1514,7 @@ public class MWFActivity extends X_AD_WF_Activity implements Runnable
String error = server.postImmediate(Env.getRemoteCallCtx(Env.getCtx()), String error = server.postImmediate(Env.getRemoteCallCtx(Env.getCtx()),
m_postImmediate.getAD_Client_ID(), m_postImmediate.getAD_Client_ID(),
m_postImmediate.get_Table_ID(), m_postImmediate.get_ID(), m_postImmediate.get_Table_ID(), m_postImmediate.get_ID(),
true, trxName); true, null);
m_postImmediate.get_Logger().config("Server: " + error == null ? "OK" : error); m_postImmediate.get_Logger().config("Server: " + error == null ? "OK" : error);
return; return;
} }

View File

@ -31,7 +31,6 @@ import javax.ejb.Stateless;
import org.adempiere.util.ProcessUtil; import org.adempiere.util.ProcessUtil;
import org.compiere.Adempiere; import org.compiere.Adempiere;
import org.compiere.acct.Doc; import org.compiere.acct.Doc;
import org.compiere.db.CConnection;
import org.compiere.interfaces.Server; import org.compiere.interfaces.Server;
import org.compiere.interfaces.ServerLocal; import org.compiere.interfaces.ServerLocal;
import org.compiere.interfaces.ServerRemote; import org.compiere.interfaces.ServerRemote;
@ -44,7 +43,6 @@ import org.compiere.util.CLogger;
import org.compiere.util.CacheMgt; import org.compiere.util.CacheMgt;
import org.compiere.util.EMail; import org.compiere.util.EMail;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.Ini;
/** /**
* Adempiere Server Bean. * Adempiere Server Bean.
@ -99,9 +97,7 @@ public class ServerBean implements ServerRemote, ServerLocal
m_postCount++; m_postCount++;
MAcctSchema[] ass = MAcctSchema.getClientAcctSchema(ctx, AD_Client_ID); MAcctSchema[] ass = MAcctSchema.getClientAcctSchema(ctx, AD_Client_ID);
if (! (Ini.isClient() && CConnection.isServerEmbedded())) return Doc.postImmediate(ass, AD_Table_ID, Record_ID, force, null);
trxName = null;
return Doc.postImmediate(ass, AD_Table_ID, Record_ID, force, trxName);
} // postImmediate } // postImmediate
/************************************************************************* /*************************************************************************