Shubhendu Tripathi has uploaded a new change for review.

Change subject: gluster: Query to get gluster bricks by task id
......................................................................

gluster: Query to get gluster bricks by task id

Added a query to get gluster volume bricks by task id. This enables
listing the set of bricks participating in a single task of
remove-bricks action.

Change-Id: I91c5074f29f1913a1b39f00de277c74aacf8bf46
Bug-Url: https://bugzilla.redhat.com/1040686
Signed-off-by: Shubhendu Tripathi <shtri...@redhat.com>
---
A 
backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/gluster/GetGlusterVolumeBricksByTaskIdQuery.java
M 
backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
M 
backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDao.java
M 
backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoDbFacadeImpl.java
M 
backend/manager/modules/dal/src/test/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoTest.java
M backend/manager/modules/dal/src/test/resources/fixtures.xml
M packaging/dbscripts/gluster_volumes_sp.sql
A packaging/dbscripts/upgrade/03_04_0230_add_task_id_idx_gluster_bricks.sql
8 files changed, 58 insertions(+), 2 deletions(-)


  git pull ssh://gerrit.ovirt.org:29418/ovirt-engine refs/changes/44/22344/1

diff --git 
a/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/gluster/GetGlusterVolumeBricksByTaskIdQuery.java
 
b/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/gluster/GetGlusterVolumeBricksByTaskIdQuery.java
new file mode 100644
index 0000000..2e91827
--- /dev/null
+++ 
b/backend/manager/modules/bll/src/main/java/org/ovirt/engine/core/bll/gluster/GetGlusterVolumeBricksByTaskIdQuery.java
@@ -0,0 +1,14 @@
+package org.ovirt.engine.core.bll.gluster;
+
+import org.ovirt.engine.core.common.queries.IdQueryParameters;
+
+public class GetGlusterVolumeBricksByTaskIdQuery<P extends IdQueryParameters> 
extends GlusterQueriesCommandBase<P> {
+    public GetGlusterVolumeBricksByTaskIdQuery(P params) {
+        super(params);
+    }
+
+    @Override
+    protected void executeQueryCommand() {
+        
getQueryReturnValue().setReturnValue(getGlusterBrickDao().getGlusterVolumeBricksByTaskId(getParameters().getId()));
+    }
+}
diff --git 
a/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
 
b/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
index 90d154d..643d58d 100644
--- 
a/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
+++ 
b/backend/manager/modules/common/src/main/java/org/ovirt/engine/core/common/queries/VdcQueryType.java
@@ -259,6 +259,7 @@
     GetGlusterVolumeOptionsInfo,
     GetGlusterVolumeBricks,
     GetGlusterVolumeBricksByServerId,
+    GetGlusterVolumeBricksByTaskId,
     GetGlusterBrickById,
     GetGlusterServersForImport,
     GetAddedGlusterServers,
diff --git 
a/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDao.java
 
b/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDao.java
index 05e7094..e278b0c 100644
--- 
a/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDao.java
+++ 
b/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDao.java
@@ -33,6 +33,8 @@
 
     public GlusterBrickEntity getBrickByServerIdAndDirectory(Guid serverId, 
String brickDirectory);
 
+    public List<GlusterBrickEntity> getGlusterVolumeBricksByTaskId(Guid 
taskId);
+
     public void updateBrickTask(Guid brickId, Guid taskId);
 
     public void updateBrickTasksInBatch(Collection<GlusterBrickEntity> bricks);
diff --git 
a/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoDbFacadeImpl.java
 
b/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoDbFacadeImpl.java
index 92fa2f8..faabf91 100644
--- 
a/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoDbFacadeImpl.java
+++ 
b/backend/manager/modules/dal/src/main/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoDbFacadeImpl.java
@@ -135,6 +135,13 @@
     }
 
     @Override
+    public List<GlusterBrickEntity> getGlusterVolumeBricksByTaskId(Guid 
taskId) {
+        return getCallsHandler().executeReadList("GetBricksByTaskId",
+                brickRowMapper,
+                getCustomMapSqlParameterSource().addValue("task_id", taskId));
+    }
+
+    @Override
     protected MapSqlParameterSource 
createFullParametersMapper(GlusterBrickEntity brick) {
         return createBrickParams(brick);
     }
diff --git 
a/backend/manager/modules/dal/src/test/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoTest.java
 
b/backend/manager/modules/dal/src/test/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoTest.java
index c1650ec..a0d1682 100644
--- 
a/backend/manager/modules/dal/src/test/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoTest.java
+++ 
b/backend/manager/modules/dal/src/test/java/org/ovirt/engine/core/dao/gluster/GlusterBrickDaoTest.java
@@ -61,6 +61,13 @@
     }
 
     @Test
+    public void testGetBricksByTaskId() {
+        List<GlusterBrickEntity> bricks = 
dao.getGlusterVolumeBricksByTaskId(FixturesTool.GLUSTER_ASYNC_TASK_ID1);
+        assertNotNull(bricks);
+        assertEquals(2, bricks.size());
+    }
+
+    @Test
     public void testRemove() {
         GlusterBrickEntity existingBrick = 
dao.getById(FixturesTool.GLUSTER_BRICK_UUID1);
         assertNotNull(existingBrick);
@@ -94,6 +101,9 @@
         newBrick.setServerId(server.getId());
         newBrick.setServerName(server.getHostName());
         newBrick.setBrickDirectory("/export/test-vol-distribute-1/dir3");
+        GlusterAsyncTask asyncTask = new GlusterAsyncTask();
+        asyncTask.setTaskId(FixturesTool.GLUSTER_ASYNC_TASK_ID1);
+        newBrick.setAsyncTask(asyncTask);
         newBrick.setStatus(GlusterStatus.UP);
         newBrick.setBrickOrder(0);
 
@@ -204,7 +214,9 @@
         GlusterAsyncTask asyncTask = new GlusterAsyncTask();
         asyncTask.setTaskId(FixturesTool.GLUSTER_ASYNC_TASK_ID1);
 
-        dao.updateBrickTaskByHostIdBrickDir(existingBrick.getServerId(), 
existingBrick.getBrickDirectory(), FixturesTool.GLUSTER_ASYNC_TASK_ID1);
+        dao.updateBrickTaskByHostIdBrickDir(existingBrick.getServerId(),
+                existingBrick.getBrickDirectory(),
+                FixturesTool.GLUSTER_ASYNC_TASK_ID1);
 
         GlusterBrickEntity newEnity = 
dao.getById(FixturesTool.GLUSTER_BRICK_UUID1);
 
@@ -231,7 +243,6 @@
         List<GlusterBrickEntity> bricks = new ArrayList<>();
         bricks.add(updateBrick);
         bricks.add(updateBrick2);
-
 
         dao.updateAllBrickTasksByHostIdBrickDirInBatch(bricks);
 
diff --git a/backend/manager/modules/dal/src/test/resources/fixtures.xml 
b/backend/manager/modules/dal/src/test/resources/fixtures.xml
index 9a8de85..e5fc79d 100644
--- a/backend/manager/modules/dal/src/test/resources/fixtures.xml
+++ b/backend/manager/modules/dal/src/test/resources/fixtures.xml
@@ -5140,6 +5140,7 @@
         <column>id</column>
         <column>volume_id</column>
         <column>server_id</column>
+        <column>task_id</column>
         <column>brick_dir</column>
         <column>status</column>
         <column>brick_order</column>
@@ -5151,6 +5152,7 @@
             <value>6ccdc294-d77b-4929-809d-8afe7634b47d</value>
             <value>0c3f45f6-3fe9-4b35-a30c-be0d1a835ea8</value>
             <value>23f6d691-5dfb-472b-86dc-9e1d2d3c18f3</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a763</value>
             <value>/export/test-vol-distribute-1/dir1</value>
             <value>UP</value>
             <value>0</value>
@@ -5161,6 +5163,7 @@
             <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a754</value>
             <value>0c3f45f6-3fe9-4b35-a30c-be0d1a835ea8</value>
             <value>2001751e-549b-4e7a-aff6-32d36856c125</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a763</value>
             <value>/export/test-vol-distribute-1/dir2</value>
             <value>UP</value>
             <value>1</value>
@@ -5173,6 +5176,7 @@
             <value>65d327f8-5864-4330-be04-fe27e1ffb553</value>
             <value>b2cb2f73-fab3-4a42-93f0-d5e4c069a43e</value>
             <value>23f6d691-5dfb-472b-86dc-9e1d2d3c18f3</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a764</value>
             <value>/export/test-vol-replicate-1/r1dir1</value>
             <value>UP</value>
             <value>0</value>
@@ -5183,6 +5187,7 @@
             <value>2ab384da-6190-4668-aa2e-37bc5c5ff014</value>
             <value>b2cb2f73-fab3-4a42-93f0-d5e4c069a43e</value>
             <value>23f6d691-5dfb-472b-86dc-9e1d2d3c18f3</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a764</value>
             <value>/export/test-vol-replicate-1/r1dir2</value>
             <value>UP</value>
             <value>1</value>
@@ -5193,6 +5198,7 @@
             <value>2702bb49-3037-405c-81c5-14a38793164e</value>
             <value>b2cb2f73-fab3-4a42-93f0-d5e4c069a43e</value>
             <value>23f6d691-5dfb-472b-86dc-9e1d2d3c18f3</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a764</value>
             <value>/export/test-vol-replicate-1/r2dir1</value>
             <value>UP</value>
             <value>2</value>
@@ -5203,6 +5209,7 @@
             <value>41eb430f-c2ed-435c-b4eb-e1e19173754e</value>
             <value>b2cb2f73-fab3-4a42-93f0-d5e4c069a43e</value>
             <value>23f6d691-5dfb-472b-86dc-9e1d2d3c18f3</value>
+            <value>61c94fc7-26b0-43e3-9d26-fc9d8cd6a764</value>
             <value>/export/test-vol-replicate-1/r2dir2</value>
             <value>UP</value>
             <value>3</value>
diff --git a/packaging/dbscripts/gluster_volumes_sp.sql 
b/packaging/dbscripts/gluster_volumes_sp.sql
index abb6c5e..be0946d 100644
--- a/packaging/dbscripts/gluster_volumes_sp.sql
+++ b/packaging/dbscripts/gluster_volumes_sp.sql
@@ -206,6 +206,17 @@
 END; $procedure$
 LANGUAGE plpgsql;
 
+Create or replace FUNCTION GetBricksByTaskId(v_task_id UUID)
+RETURNS SETOF gluster_volume_bricks_view STABLE
+AS $procedure$
+BEGIN
+RETURN QUERY SELECT *
+FROM  gluster_volume_bricks_view
+WHERE task_id = v_task_id
+ORDER BY brick_order;
+END; $procedure$
+LANGUAGE plpgsql;
+
 Create or replace FUNCTION GetGlusterOptionById(v_id UUID)
     RETURNS SETOF gluster_volume_options STABLE
     AS $procedure$
diff --git 
a/packaging/dbscripts/upgrade/03_04_0230_add_task_id_idx_gluster_bricks.sql 
b/packaging/dbscripts/upgrade/03_04_0230_add_task_id_idx_gluster_bricks.sql
new file mode 100644
index 0000000..6628217
--- /dev/null
+++ b/packaging/dbscripts/upgrade/03_04_0230_add_task_id_idx_gluster_bricks.sql
@@ -0,0 +1,3 @@
+DROP INDEX if exists IDX_gluster_bricks_task_id;
+CREATE INDEX IDX_gluster_bricks_task_id ON job(task_id);
+


-- 
To view, visit http://gerrit.ovirt.org/22344
To unsubscribe, visit http://gerrit.ovirt.org/settings

Gerrit-MessageType: newchange
Gerrit-Change-Id: I91c5074f29f1913a1b39f00de277c74aacf8bf46
Gerrit-PatchSet: 1
Gerrit-Project: ovirt-engine
Gerrit-Branch: master
Gerrit-Owner: Shubhendu Tripathi <shtri...@redhat.com>
_______________________________________________
Engine-patches mailing list
Engine-patches@ovirt.org
http://lists.ovirt.org/mailman/listinfo/engine-patches

Reply via email to