diff options
author | Trygve Laugstøl <trygvis@inamo.no> | 2013-06-09 23:22:39 +0200 |
---|---|---|
committer | Trygve Laugstøl <trygvis@inamo.no> | 2013-06-09 23:22:39 +0200 |
commit | 1c0fc92c719f3856653d0efcc5fe4a1fa30b7bac (patch) | |
tree | ab1ebbfbd21fe1fcc5be75d31c5262f65a931641 /src/main/java/io/trygvis/queue | |
parent | 33e3be55dc2d815cbd0208bf59d12a7e727f3105 (diff) | |
download | quartz-based-queue-1c0fc92c719f3856653d0efcc5fe4a1fa30b7bac.tar.gz quartz-based-queue-1c0fc92c719f3856653d0efcc5fe4a1fa30b7bac.tar.bz2 quartz-based-queue-1c0fc92c719f3856653d0efcc5fe4a1fa30b7bac.tar.xz quartz-based-queue-1c0fc92c719f3856653d0efcc5fe4a1fa30b7bac.zip |
wip
Diffstat (limited to 'src/main/java/io/trygvis/queue')
-rw-r--r-- | src/main/java/io/trygvis/queue/JdbcQueueService.java | 22 | ||||
-rw-r--r-- | src/main/java/io/trygvis/queue/TaskDao.java | 2 |
2 files changed, 15 insertions, 9 deletions
diff --git a/src/main/java/io/trygvis/queue/JdbcQueueService.java b/src/main/java/io/trygvis/queue/JdbcQueueService.java index d284287..c99bf2e 100644 --- a/src/main/java/io/trygvis/queue/JdbcQueueService.java +++ b/src/main/java/io/trygvis/queue/JdbcQueueService.java @@ -26,7 +26,7 @@ public class JdbcQueueService { this.sqlEffectExecutor = queueSystem.sqlEffectExecutor; } - public void consumeAll(final Queue queue, final TaskEffect effect) { + public void consumeAll(final Queue queue, final TaskEffect effect) throws SQLException { final List<Task> tasks = sqlEffectExecutor.transaction(new SqlEffect<List<Task>>() { @Override public List<Task> doInConnection(Connection c) throws SQLException { @@ -47,7 +47,7 @@ public class JdbcQueueService { }); } - public void executeTask(final TaskEffect taskEffect, final List<Task> tasks) { + public void executeTask(final TaskEffect taskEffect, final List<Task> tasks) throws SQLException { sqlEffectExecutor.transaction(new SqlEffect.Void() { @Override public void doInConnection(Connection connection) throws SQLException { @@ -102,12 +102,6 @@ public class JdbcQueueService { final Date now = new Date(); log.error("Unable to execute task, id=" + task.id(), e); - try { - taskDao.rollback(); - } catch (SQLException e2) { - log.error("Error rolling back transaction after failed apply.", e2); - } - final Task t = task; sqlEffectExecutor.transaction(new SqlEffect.Void() { @Override @@ -117,6 +111,12 @@ public class JdbcQueueService { taskDao.update(task); } }); + + if(e instanceof SQLException) { + throw ((SQLException) e); + } + + throw new RuntimeException("Error while executing task, id=" + task.id(), e); } } @@ -156,4 +156,10 @@ public class JdbcQueueService { return new Task(id, parent, queue, NEW, scheduled, null, 0, null, arguments); } + + public static class TaskExecutionFailed extends Throwable { + public TaskExecutionFailed(Exception e) { + super(e); + } + } } diff --git a/src/main/java/io/trygvis/queue/TaskDao.java b/src/main/java/io/trygvis/queue/TaskDao.java index 025823b..8b58585 100644 --- a/src/main/java/io/trygvis/queue/TaskDao.java +++ b/src/main/java/io/trygvis/queue/TaskDao.java @@ -111,7 +111,7 @@ public class TaskDao { rs.getLong(i++), rs.getLong(i++), rs.getString(i++), - valueOf(rs.getString(i++)), + TaskState.valueOf(rs.getString(i++).trim()), rs.getTimestamp(i++), rs.getTimestamp(i++), rs.getInt(i++), |