This is an automated email from the ASF dual-hosted git repository.

aleks pushed a commit to branch develop
in repository https://gitbox.apache.org/repos/asf/fineract.git


The following commit(s) were added to refs/heads/develop by this push:
     new aa24599  FINERACT-984-7: Explicit ordering fix for moving ResultSets
aa24599 is described below

commit aa24599244f44a6ceb3e1d86b0eea882e4eb2272
Author: Arnold Galovics <[email protected]>
AuthorDate: Wed Feb 23 19:19:50 2022 +0100

    FINERACT-984-7: Explicit ordering fix for moving ResultSets
---
 .github/workflows/build-postgresql.yml                              | 2 +-
 .../service/InterestRateChartReadPlatformServiceImpl.java           | 2 +-
 .../guarantor/service/GuarantorReadPlatformServiceImpl.java         | 6 ++++--
 .../shareaccounts/service/ShareAccountReadPlatformServiceImpl.java  | 3 ++-
 4 files changed, 8 insertions(+), 5 deletions(-)

diff --git a/.github/workflows/build-postgresql.yml 
b/.github/workflows/build-postgresql.yml
index d22eb56..e992031 100644
--- a/.github/workflows/build-postgresql.yml
+++ b/.github/workflows/build-postgresql.yml
@@ -59,7 +59,7 @@ jobs:
             sudo apt-get install ghostscript -y
 
       - name: Basic Auth Build & Test
-        run: ./gradlew --no-daemon -q --console=plain licenseMain licenseTest 
check build test --fail-fast doc -x :twofactor-tests:test -x :oauth2-test:test 
-PdbType=postgresql 
-PexcludeTests=org.apache.fineract.integrationtests.guarantor.GuarantorTest.testGuarantor_UNDO_DISBURSAL
+        run: ./gradlew --no-daemon -q --console=plain licenseMain licenseTest 
check build test --fail-fast doc -x :twofactor-tests:test -x :oauth2-test:test 
-PdbType=postgresql
 
       - name: 2FA Build & Test
         run: ./gradlew --no-daemon -q --console=plain :twofactor-tests:test 
--fail-fast -PdbType=postgresql
diff --git 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/interestratechart/service/InterestRateChartReadPlatformServiceImpl.java
 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/interestratechart/service/InterestRateChartReadPlatformServiceImpl.java
index e2479f4..cb84594 100644
--- 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/interestratechart/service/InterestRateChartReadPlatformServiceImpl.java
+++ 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/interestratechart/service/InterestRateChartReadPlatformServiceImpl.java
@@ -104,7 +104,7 @@ public class InterestRateChartReadPlatformServiceImpl 
implements InterestRateCha
         sql.append("END");
 
         return this.jdbcTemplate.query(
-                con -> con.prepareStatement(sql.toString(), 
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_UPDATABLE),
+                con -> con.prepareStatement(sql.toString(), 
ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE),
                 ps -> ps.setLong(1, productId), this.chartExtractor);
 
     }
diff --git 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/guarantor/service/GuarantorReadPlatformServiceImpl.java
 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/guarantor/service/GuarantorReadPlatformServiceImpl.java
index 8a56002..938eb10 100644
--- 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/guarantor/service/GuarantorReadPlatformServiceImpl.java
+++ 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/loanaccount/guarantor/service/GuarantorReadPlatformServiceImpl.java
@@ -48,8 +48,10 @@ import 
org.springframework.dao.EmptyResultDataAccessException;
 import org.springframework.jdbc.core.JdbcTemplate;
 import org.springframework.jdbc.core.RowMapper;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 @Service
+@Transactional(readOnly = true)
 public class GuarantorReadPlatformServiceImpl implements 
GuarantorReadPlatformService {
 
     private final JdbcTemplate jdbcTemplate;
@@ -76,7 +78,7 @@ public class GuarantorReadPlatformServiceImpl implements 
GuarantorReadPlatformSe
     public List<GuarantorData> retrieveGuarantorsForLoan(final Long loanId) {
         final GuarantorMapper rm = new GuarantorMapper();
         String sql = "select " + rm.schema();
-        sql += " where loan_id = ?  group by g.id,gfd.id, gt.id, sa.id, 
oht.id, cv.id";
+        sql += " where loan_id = ?  group by g.id,gfd.id, gt.id, sa.id, 
oht.id, cv.id order by g.id";
         String finalSql = sql;
         final List<GuarantorData> guarantorDatas = this.jdbcTemplate.query(con 
-> {
             PreparedStatement preparedStatement = 
con.prepareStatement(finalSql, ResultSet.TYPE_SCROLL_SENSITIVE,
@@ -98,7 +100,7 @@ public class GuarantorReadPlatformServiceImpl implements 
GuarantorReadPlatformSe
     public GuarantorData retrieveGuarantor(final Long loanId, final Long 
guarantorId) {
         final GuarantorMapper rm = new GuarantorMapper();
         String sql = "select " + rm.schema();
-        sql += " where g.loan_id = ? and g.id = ? group by g.id, gfd.id, 
gt.id, sa.id, oht.id, cv.id";
+        sql += " where g.loan_id = ? and g.id = ? group by g.id, gfd.id, 
gt.id, sa.id, oht.id, cv.id order by g.id";
         String finalSql = sql;
         final GuarantorData guarantorData = this.jdbcTemplate.query(con -> {
             PreparedStatement preparedStatement = 
con.prepareStatement(finalSql, ResultSet.TYPE_SCROLL_SENSITIVE,
diff --git 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/shareaccounts/service/ShareAccountReadPlatformServiceImpl.java
 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/shareaccounts/service/ShareAccountReadPlatformServiceImpl.java
index a82cb18..8484a59 100644
--- 
a/fineract-provider/src/main/java/org/apache/fineract/portfolio/shareaccounts/service/ShareAccountReadPlatformServiceImpl.java
+++ 
b/fineract-provider/src/main/java/org/apache/fineract/portfolio/shareaccounts/service/ShareAccountReadPlatformServiceImpl.java
@@ -233,10 +233,11 @@ public class ShareAccountReadPlatformServiceImpl 
implements ShareAccountReadPlat
             sb.append(" and sa.status_enum = ? ");
         }
         sb.append(" and saps.status_enum = ?");
+        sb.append(" order by sa.id");
         params.add(PurchasedSharesStatusType.APPROVED.getValue());
         Object[] whereClauseItems = params.toArray();
         return this.jdbcTemplate.query(con -> {
-            PreparedStatement preparedStatement = 
con.prepareStatement(sb.toString(), ResultSet.TYPE_SCROLL_INSENSITIVE,
+            PreparedStatement preparedStatement = 
con.prepareStatement(sb.toString(), ResultSet.TYPE_SCROLL_SENSITIVE,
                     ResultSet.CONCUR_UPDATABLE);
             for (int i = 0; i < whereClauseItems.length; i++) {
                 preparedStatement.setObject(i + 1, whereClauseItems[i]);

Reply via email to