aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-core
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-core')
-rw-r--r--sonar-core/src/main/java/org/sonar/core/persistence/SemaphoreDao.java19
-rw-r--r--sonar-core/src/test/java/org/sonar/core/persistence/SemaphoreDaoTest.java54
2 files changed, 31 insertions, 42 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/persistence/SemaphoreDao.java b/sonar-core/src/main/java/org/sonar/core/persistence/SemaphoreDao.java
index 9281c78536c..74dd6a3734c 100644
--- a/sonar-core/src/main/java/org/sonar/core/persistence/SemaphoreDao.java
+++ b/sonar-core/src/main/java/org/sonar/core/persistence/SemaphoreDao.java
@@ -48,7 +48,7 @@ public class SemaphoreDao {
createSemaphore(name, lockedAt, session, mapper);
boolean isAcquired = doAcquire(name, maxDurationInSeconds, session, mapper);
SemaphoreDto semaphore = selectSemaphore(name, session);
- return createLock(semaphore, session, isAcquired);
+ return createLock(semaphore, mapper, isAcquired);
} finally {
MyBatis.closeQuietly(session);
}
@@ -63,10 +63,10 @@ public class SemaphoreDao {
SemaphoreDto semaphore = selectSemaphore(name, session);
Date now = mapper.now();
if (semaphore != null) {
- return createLock(semaphore, session, false);
+ return createLock(semaphore, mapper, false);
} else {
semaphore = createSemaphore(name, now, session, mapper);
- return createLock(semaphore, session, true);
+ return createLock(semaphore, mapper, true);
}
} finally {
MyBatis.closeQuietly(session);
@@ -106,16 +106,16 @@ public class SemaphoreDao {
}
}
- private Lock createLock(SemaphoreDto semaphore, SqlSession session, boolean acquired) {
+ private Lock createLock(SemaphoreDto semaphore, SemaphoreMapper mapper, boolean acquired) {
Lock lock = new Lock(semaphore.getName(), acquired, semaphore.getLockedAt(), semaphore.getCreatedAt(), semaphore.getUpdatedAt());
if (!acquired) {
- lock.setDurationSinceLocked(getDurationSinceLocked(semaphore, session));
+ lock.setDurationSinceLocked(getDurationSinceLocked(semaphore, mapper));
}
return lock;
}
- private long getDurationSinceLocked(SemaphoreDto semaphore, SqlSession session) {
- long now = now(session).getTime();
+ private long getDurationSinceLocked(SemaphoreDto semaphore, SemaphoreMapper mapper) {
+ long now = mapper.now().getTime();
semaphore.getLockedAt();
long locketAt = semaphore.getLockedAt().getTime();
return now - locketAt;
@@ -126,9 +126,4 @@ public class SemaphoreDao {
return mapper.selectSemaphore(name);
}
- protected Date now(SqlSession session){
- SemaphoreMapper mapper = session.getMapper(SemaphoreMapper.class);
- return mapper.now();
- }
-
}
diff --git a/sonar-core/src/test/java/org/sonar/core/persistence/SemaphoreDaoTest.java b/sonar-core/src/test/java/org/sonar/core/persistence/SemaphoreDaoTest.java
index d73f3cacbb9..3ae10efa307 100644
--- a/sonar-core/src/test/java/org/sonar/core/persistence/SemaphoreDaoTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/persistence/SemaphoreDaoTest.java
@@ -74,9 +74,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isTrue();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isTrue();
dao.release("foo");
assertThat(selectSemaphore("foo")).isNull();
@@ -92,9 +92,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isTrue();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isTrue();
dao.release("foo");
assertThat(selectSemaphore("foo")).isNull();
@@ -110,9 +110,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isTrue();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isTrue();
dao.release("foo");
assertThat(selectSemaphore("foo")).isNull();
@@ -129,9 +129,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isFalse();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isFalse();
}
@Test
@@ -145,9 +145,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isTrue();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isTrue();
}
@Test
@@ -161,9 +161,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isTrue();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isTrue();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isTrue();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isTrue();
dao.release("foo");
assertThat(selectSemaphore("foo")).isNull();
@@ -180,9 +180,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
SemaphoreDto semaphore = selectSemaphore("foo");
assertThat(semaphore).isNotNull();
assertThat(semaphore.getName()).isEqualTo("foo");
- assertThat(isRecent(semaphore.getCreatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getUpdatedAt(), 60)).isFalse();
- assertThat(isRecent(semaphore.getLockedAt(), 60)).isFalse();
+ assertThat(isRecent(semaphore.getCreatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getUpdatedAt(), 10)).isFalse();
+ assertThat(isRecent(semaphore.getLockedAt(), 10)).isFalse();
}
@Test
@@ -229,15 +229,9 @@ public class SemaphoreDaoTest extends AbstractDaoTestCase {
}
}
- private boolean isRecent(Date date, int durationInSeconds) {
- SqlSession session = getMyBatis().openSession();
- try {
- SemaphoreDao dao = new SemaphoreDao(getMyBatis());
- Date now = dao.now(session);
- return date.before(now) && DateUtils.addSeconds(date, durationInSeconds).after(now);
- } finally {
- MyBatis.closeQuietly(session);
- }
+ private static boolean isRecent(Date date, int durationInMinutes) {
+ Date now = new Date();
+ return date.before(now) && DateUtils.addSeconds(date, durationInMinutes*60).after(now);
}
private static class Runner extends Thread {