aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--sonar-db/src/main/java/org/sonar/db/organization/OrganizationDao.java10
-rw-r--r--sonar-db/src/main/java/org/sonar/db/organization/OrganizationMapper.java2
-rw-r--r--sonar-db/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml11
-rw-r--r--sonar-db/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java264
4 files changed, 200 insertions, 87 deletions
diff --git a/sonar-db/src/main/java/org/sonar/db/organization/OrganizationDao.java b/sonar-db/src/main/java/org/sonar/db/organization/OrganizationDao.java
index 8dc50dca9a9..e39a27d7157 100644
--- a/sonar-db/src/main/java/org/sonar/db/organization/OrganizationDao.java
+++ b/sonar-db/src/main/java/org/sonar/db/organization/OrganizationDao.java
@@ -19,13 +19,16 @@
*/
package org.sonar.db.organization;
+import java.util.Collections;
import java.util.List;
import java.util.Optional;
+import java.util.Set;
import org.sonar.api.utils.System2;
import org.sonar.db.Dao;
import org.sonar.db.DbSession;
import static java.util.Objects.requireNonNull;
+import static org.sonar.db.DatabaseUtils.executeLargeInputs;
public class OrganizationDao implements Dao {
@@ -78,4 +81,11 @@ public class OrganizationDao implements Dao {
private static OrganizationMapper getMapper(DbSession dbSession) {
return dbSession.getMapper(OrganizationMapper.class);
}
+
+ public List<OrganizationDto> selectByUuids(DbSession dbSession, Set<String> organizationUuids) {
+ if (organizationUuids.size() == 1) {
+ return Collections.singletonList(getMapper(dbSession).selectByUuid(organizationUuids.iterator().next()));
+ }
+ return executeLargeInputs(organizationUuids, getMapper(dbSession)::selectByUuids);
+ }
}
diff --git a/sonar-db/src/main/java/org/sonar/db/organization/OrganizationMapper.java b/sonar-db/src/main/java/org/sonar/db/organization/OrganizationMapper.java
index c9c8b717765..7da4a027413 100644
--- a/sonar-db/src/main/java/org/sonar/db/organization/OrganizationMapper.java
+++ b/sonar-db/src/main/java/org/sonar/db/organization/OrganizationMapper.java
@@ -34,6 +34,8 @@ public interface OrganizationMapper {
@CheckForNull
OrganizationDto selectByUuid(@Param("uuid") String uuid);
+ List<OrganizationDto> selectByUuids(@Param("uuids") List<String> uuids);
+
/**
* Update the organization with UUID specified by {@link OrganizationDto#getUuid()}.
* <p>
diff --git a/sonar-db/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml b/sonar-db/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml
index a436352e476..e120713908c 100644
--- a/sonar-db/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml
+++ b/sonar-db/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml
@@ -29,6 +29,17 @@
org.kee = #{key, jdbcType=VARCHAR}
</select>
+ <select id="selectByUuids" resultType="Organization">
+ select
+ <include refid="selectColumns"/>
+ from organizations org
+ where
+ org.uuid in
+ <foreach collection="uuids" open="(" close=")" item="uuid" separator=",">
+ #{uuid, jdbcType=VARCHAR}
+ </foreach>
+ </select>
+
<select id="selectByQuery" parameterType="map" resultType="Organization">
select
<include refid="selectColumns"/>
diff --git a/sonar-db/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java b/sonar-db/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java
index d348bd4183f..000cb53dac3 100644
--- a/sonar-db/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java
+++ b/sonar-db/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java
@@ -19,6 +19,7 @@
*/
package org.sonar.db.organization;
+import java.util.Collections;
import java.util.List;
import java.util.Locale;
import java.util.Map;
@@ -33,6 +34,8 @@ import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.DbTester;
+import static com.google.common.collect.ImmutableSet.of;
+import static java.util.Collections.singleton;
import static org.assertj.core.api.Assertions.assertThat;
import static org.assertj.core.api.Assertions.tuple;
import static org.mockito.Mockito.mock;
@@ -43,13 +46,20 @@ public class OrganizationDaoTest {
private static final long DATE_1 = 1_999_000L;
private static final long DATE_2 = 8_999_999L;
private static final long DATE_3 = 3_999_000L;
- private static final OrganizationDto ORGANIZATION_DTO = new OrganizationDto()
- .setUuid("a uuid")
- .setKey("the_key")
- .setName("the name")
- .setDescription("the description")
- .setUrl("the url")
- .setAvatarUrl("the avatar url");
+ private static final OrganizationDto ORGANIZATION_DTO_1 = new OrganizationDto()
+ .setUuid("uuid 1")
+ .setKey("the_key 1")
+ .setName("the name 1")
+ .setDescription("the description 1")
+ .setUrl("the url 1")
+ .setAvatarUrl("the avatar url 1");
+ private static final OrganizationDto ORGANIZATION_DTO_2 = new OrganizationDto()
+ .setUuid("uuid 2")
+ .setKey("the_key 2")
+ .setName("the name 2")
+ .setDescription("the description 2")
+ .setUrl("the url 2")
+ .setAvatarUrl("the avatar url 2");
private System2 system2 = mock(System2.class);
@@ -73,7 +83,7 @@ public class OrganizationDaoTest {
@Test
public void insert_populates_createdAt_and_updateAt_with_same_date_from_System2() {
when(system2.now()).thenReturn(DATE_1, DATE_1 + 1_000_000L);
- insertOrganization(copyOf(ORGANIZATION_DTO)
+ insertOrganization(copyOf(ORGANIZATION_DTO_1)
.setCreatedAt(1_000L)
.setUpdatedAt(6_000L));
@@ -84,28 +94,28 @@ public class OrganizationDaoTest {
@Test
public void insert_persists_properties_of_OrganizationDto() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
Map<String, Object> row = selectSingleRow();
- assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO.getUuid());
- assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO.getKey());
- assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO.getName());
- assertThat(row.get("description")).isEqualTo(ORGANIZATION_DTO.getDescription());
- assertThat(row.get("url")).isEqualTo(ORGANIZATION_DTO.getUrl());
- assertThat(row.get("avatarUrl")).isEqualTo(ORGANIZATION_DTO.getAvatarUrl());
- assertThat(row.get("createdAt")).isEqualTo(ORGANIZATION_DTO.getCreatedAt());
- assertThat(row.get("updatedAt")).isEqualTo(ORGANIZATION_DTO.getUpdatedAt());
+ assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO_1.getUuid());
+ assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO_1.getKey());
+ assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO_1.getName());
+ assertThat(row.get("description")).isEqualTo(ORGANIZATION_DTO_1.getDescription());
+ assertThat(row.get("url")).isEqualTo(ORGANIZATION_DTO_1.getUrl());
+ assertThat(row.get("avatarUrl")).isEqualTo(ORGANIZATION_DTO_1.getAvatarUrl());
+ assertThat(row.get("createdAt")).isEqualTo(ORGANIZATION_DTO_1.getCreatedAt());
+ assertThat(row.get("updatedAt")).isEqualTo(ORGANIZATION_DTO_1.getUpdatedAt());
}
@Test
public void description_url_and_avatarUrl_are_optional() {
when(system2.now()).thenReturn(SOME_DATE);
- insertOrganization(copyOf(ORGANIZATION_DTO).setDescription(null).setUrl(null).setAvatarUrl(null));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setDescription(null).setUrl(null).setAvatarUrl(null));
Map<String, Object> row = selectSingleRow();
- assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO.getUuid());
- assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO.getKey());
- assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO.getName());
+ assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO_1.getUuid());
+ assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO_1.getKey());
+ assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO_1.getName());
assertThat(row.get("description")).isNull();
assertThat(row.get("url")).isNull();
assertThat(row.get("avatarUrl")).isNull();
@@ -115,10 +125,10 @@ public class OrganizationDaoTest {
@Test
public void insert_fails_if_row_with_uuid_already_exists() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
OrganizationDto dto = new OrganizationDto()
- .setUuid(ORGANIZATION_DTO.getUuid())
+ .setUuid(ORGANIZATION_DTO_1.getUuid())
.setKey("other key")
.setName("other name")
.setCreatedAt(2_999_000L)
@@ -131,56 +141,117 @@ public class OrganizationDaoTest {
@Test
public void selectByKey_returns_empty_when_table_is_empty() {
- assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO.getKey())).isEmpty();
+ assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO_1.getKey())).isEmpty();
}
@Test
public void selectByKey_returns_row_data_when_key_exists() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
- Optional<OrganizationDto> optional = underTest.selectByKey(dbSession, ORGANIZATION_DTO.getKey());
- verify(optional);
+ Optional<OrganizationDto> optional = underTest.selectByKey(dbSession, ORGANIZATION_DTO_1.getKey());
+ verifyOrganization1(optional);
}
@Test
public void selectByKey_returns_row_data_of_specified_key() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.selectByKey(dbSession, "foo key")).isEmpty();
}
@Test
public void selectByKey_is_case_sensitive() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
- assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO.getKey().toUpperCase(Locale.ENGLISH))).isEmpty();
+ assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO_1.getKey().toUpperCase(Locale.ENGLISH))).isEmpty();
}
@Test
public void selectByUuid_returns_empty_when_table_is_empty() {
- assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO.getUuid())).isEmpty();
+ assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO_1.getUuid())).isEmpty();
}
@Test
public void selectByUuid_returns_row_data_when_uuid_exists() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
- Optional<OrganizationDto> optional = underTest.selectByUuid(dbSession, ORGANIZATION_DTO.getUuid());
- verify(optional);
+ Optional<OrganizationDto> optional = underTest.selectByUuid(dbSession, ORGANIZATION_DTO_1.getUuid());
+ verifyOrganization1(optional);
}
@Test
public void selectByUuid_returns_row_data_of_specified_uuid() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.selectByUuid(dbSession, "foo uuid")).isEmpty();
}
@Test
public void selectByUuid_is_case_sensitive() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
- assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO.getUuid().toUpperCase(Locale.ENGLISH))).isEmpty();
+ assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO_1.getUuid().toUpperCase(Locale.ENGLISH))).isEmpty();
+ }
+
+ @Test
+ public void selectByUuids_returns_empty_when_table_is_empty() {
+ assertThat(underTest.selectByUuids(dbSession, of(ORGANIZATION_DTO_1.getUuid(), ORGANIZATION_DTO_2.getUuid())))
+ .isEmpty();
+ }
+
+ @Test
+ public void selectByUuids_returns_empty_when_argument_is_empty() {
+ assertThat(underTest.selectByUuids(dbSession, Collections.emptySet()))
+ .isEmpty();
+ }
+
+ @Test
+ public void selectByUuids_returns_row_data_of_single_uuid_when_uuid_exists() {
+ insertOrganization(ORGANIZATION_DTO_1);
+
+ List<OrganizationDto> dtos = underTest.selectByUuids(dbSession, singleton(ORGANIZATION_DTO_1.getUuid()));
+ assertThat(dtos).hasSize(1);
+ verifyOrganization1(dtos.iterator().next());
+ }
+
+ @Test
+ public void selectByUuids_returns_row_data_of_multiple_uuid_when_uuid_exists() {
+ insertOrganization(ORGANIZATION_DTO_1);
+ insertOrganization(ORGANIZATION_DTO_2);
+
+ List<OrganizationDto> dtos = underTest.selectByUuids(dbSession, of(ORGANIZATION_DTO_1.getUuid(), ORGANIZATION_DTO_2.getUuid()));
+ assertThat(dtos).hasSize(2);
+ verifyOrganization1(dtos.stream().filter((t) -> t.getUuid().equals(ORGANIZATION_DTO_1.getUuid())).findFirst().get());
+ verifyOrganization(dtos.stream().filter((t) -> t.getUuid().equals(ORGANIZATION_DTO_2.getUuid())).findFirst().get(), ORGANIZATION_DTO_2);
+ }
+
+ @Test
+ public void selectByUuids_returns_empty_when_no_uuid_exist() {
+ insertOrganization(ORGANIZATION_DTO_1);
+ insertOrganization(ORGANIZATION_DTO_2);
+
+ assertThat(underTest.selectByUuids(dbSession, of("foo uuid", "bar uuid")))
+ .isEmpty();
+ }
+
+ @Test
+ public void selectByUuids_ignores_non_existing_uuids() {
+ insertOrganization(ORGANIZATION_DTO_1);
+ insertOrganization(ORGANIZATION_DTO_2);
+
+ List<OrganizationDto> dtos = underTest.selectByUuids(dbSession, of(ORGANIZATION_DTO_1.getUuid(), "foo uuid", ORGANIZATION_DTO_2.getUuid(), "bar uuid"));
+ assertThat(dtos).extracting(OrganizationDto::getUuid).containsOnly(ORGANIZATION_DTO_1.getUuid(), ORGANIZATION_DTO_2.getUuid());
+ }
+
+ @Test
+ public void selectByUuids_is_case_sensitive() {
+ insertOrganization(ORGANIZATION_DTO_1);
+ insertOrganization(ORGANIZATION_DTO_2);
+
+ assertThat(underTest.selectByUuids(
+ dbSession,
+ of(ORGANIZATION_DTO_1.getUuid().toUpperCase(Locale.ENGLISH), ORGANIZATION_DTO_2.getUuid().toUpperCase(Locale.ENGLISH))))
+ .isEmpty();
}
@Test
@@ -190,22 +261,22 @@ public class OrganizationDaoTest {
@Test
public void selectByQuery_returns_single_row_of_table_when_requesting_first_page_of_size_1_or_more() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.selectByQuery(dbSession, 0, 1))
.hasSize(1)
.extracting("uuid")
- .containsOnly(ORGANIZATION_DTO.getUuid());
+ .containsOnly(ORGANIZATION_DTO_1.getUuid());
assertThat(underTest.selectByQuery(dbSession, 0, 10))
.hasSize(1)
.extracting("uuid")
- .containsOnly(ORGANIZATION_DTO.getUuid());
+ .containsOnly(ORGANIZATION_DTO_1.getUuid());
}
@Test
public void selectByQuery_returns_empty_on_table_with_single_row_when_not_requesting_the_first_page() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.selectByQuery(dbSession, 1, 1)).isEmpty();
assertThat(underTest.selectByQuery(dbSession, Math.abs(new Random().nextInt(10)) + 1, 1)).isEmpty();
@@ -216,11 +287,11 @@ public class OrganizationDaoTest {
public void selectByQuery_returns_rows_ordered_by_createdAt_descending_applying_requested_paging() {
long time = 1_999_999L;
when(system2.now()).thenReturn(time, time + 1_000, time + 2_000, time + 3_000, time + 5_000);
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid3").setKey("key-3"));
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid1").setKey("key-1"));
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid2").setKey("key-2"));
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid5").setKey("key-5"));
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid4").setKey("key-4"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid3").setKey("key-3"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid1").setKey("key-1"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid2").setKey("key-2"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid5").setKey("key-5"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid4").setKey("key-4"));
assertThat(underTest.selectByQuery(dbSession, 0, 1))
.extracting("uuid", "key")
@@ -262,34 +333,34 @@ public class OrganizationDaoTest {
@Test
public void update_does_not_fail_if_specified_row_does_not_exist() {
- underTest.update(dbSession, ORGANIZATION_DTO);
+ underTest.update(dbSession, ORGANIZATION_DTO_1);
}
@Test
public void update_with_same_information_succeeds_but_has_no_effect() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
- underTest.update(dbSession, ORGANIZATION_DTO);
+ underTest.update(dbSession, ORGANIZATION_DTO_1);
dbSession.commit();
Map<String, Object> row = selectSingleRow();
- assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO.getUuid());
- assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO.getKey());
- assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO.getName());
- assertThat(row.get("description")).isEqualTo(ORGANIZATION_DTO.getDescription());
- assertThat(row.get("url")).isEqualTo(ORGANIZATION_DTO.getUrl());
- assertThat(row.get("avatarUrl")).isEqualTo(ORGANIZATION_DTO.getAvatarUrl());
- assertThat(row.get("createdAt")).isEqualTo(ORGANIZATION_DTO.getCreatedAt());
- assertThat(row.get("updatedAt")).isEqualTo(ORGANIZATION_DTO.getUpdatedAt());
+ assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO_1.getUuid());
+ assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO_1.getKey());
+ assertThat(row.get("name")).isEqualTo(ORGANIZATION_DTO_1.getName());
+ assertThat(row.get("description")).isEqualTo(ORGANIZATION_DTO_1.getDescription());
+ assertThat(row.get("url")).isEqualTo(ORGANIZATION_DTO_1.getUrl());
+ assertThat(row.get("avatarUrl")).isEqualTo(ORGANIZATION_DTO_1.getAvatarUrl());
+ assertThat(row.get("createdAt")).isEqualTo(ORGANIZATION_DTO_1.getCreatedAt());
+ assertThat(row.get("updatedAt")).isEqualTo(ORGANIZATION_DTO_1.getUpdatedAt());
}
@Test
public void update_populates_updatedAt_with_date_from_System2() {
when(system2.now()).thenReturn(DATE_1);
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
when(system2.now()).thenReturn(DATE_2);
- underTest.update(dbSession, copyOf(ORGANIZATION_DTO)
+ underTest.update(dbSession, copyOf(ORGANIZATION_DTO_1)
.setUpdatedAt(2_000L));
dbSession.commit();
@@ -301,11 +372,11 @@ public class OrganizationDaoTest {
@Test
public void update_does_not_update_key_nor_createdAt() {
when(system2.now()).thenReturn(DATE_1);
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
when(system2.now()).thenReturn(DATE_3);
underTest.update(dbSession, new OrganizationDto()
- .setUuid(ORGANIZATION_DTO.getUuid())
+ .setUuid(ORGANIZATION_DTO_1.getUuid())
.setKey("new key")
.setName("new name")
.setDescription("new description")
@@ -316,8 +387,8 @@ public class OrganizationDaoTest {
dbSession.commit();
Map<String, Object> row = selectSingleRow();
- assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO.getUuid());
- assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO.getKey());
+ assertThat(row.get("uuid")).isEqualTo(ORGANIZATION_DTO_1.getUuid());
+ assertThat(row.get("key")).isEqualTo(ORGANIZATION_DTO_1.getKey());
assertThat(row.get("name")).isEqualTo("new name");
assertThat(row.get("description")).isEqualTo("new description");
assertThat(row.get("url")).isEqualTo("new url");
@@ -328,11 +399,11 @@ public class OrganizationDaoTest {
@Test
public void update_fails_if_name_is_null() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
expectedException.expect(PersistenceException.class);
- underTest.update(dbSession, copyOf(ORGANIZATION_DTO).setName(null));
+ underTest.update(dbSession, copyOf(ORGANIZATION_DTO_1).setName(null));
}
@Test
@@ -343,7 +414,7 @@ public class OrganizationDaoTest {
@Test
public void deleteByUuid_does_not_fail_on_non_existing_row() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.deleteByUuid(dbSession, "uuid")).isEqualTo(0);
dbSession.commit();
@@ -351,23 +422,23 @@ public class OrganizationDaoTest {
@Test
public void deleteByUuid_deletes_row_with_specified_uuid() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
String anotherUuid = "uuid";
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid(anotherUuid).setKey("key"));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid(anotherUuid).setKey("key"));
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(2);
assertThat(underTest.deleteByUuid(dbSession, anotherUuid)).isEqualTo(1);
dbSession.commit();
assertThat(underTest.selectByUuid(dbSession, anotherUuid)).isEmpty();
- assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO.getUuid())).isNotEmpty();
+ assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO_1.getUuid())).isNotEmpty();
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(1);
assertThat(underTest.deleteByUuid(dbSession, anotherUuid)).isEqualTo(0);
- assertThat(underTest.deleteByUuid(dbSession, ORGANIZATION_DTO.getUuid())).isEqualTo(1);
+ assertThat(underTest.deleteByUuid(dbSession, ORGANIZATION_DTO_1.getUuid())).isEqualTo(1);
dbSession.commit();
- assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO.getUuid())).isEmpty();
+ assertThat(underTest.selectByUuid(dbSession, ORGANIZATION_DTO_1.getUuid())).isEmpty();
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(0);
}
@@ -379,7 +450,7 @@ public class OrganizationDaoTest {
@Test
public void deleteByKey_does_not_fail_on_non_existing_row() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
assertThat(underTest.deleteByKey(dbSession, "key")).isEqualTo(0);
dbSession.commit();
@@ -387,23 +458,23 @@ public class OrganizationDaoTest {
@Test
public void deleteByUuid_deletes_row_with_specified_key() {
- insertOrganization(ORGANIZATION_DTO);
+ insertOrganization(ORGANIZATION_DTO_1);
String anotherKey = "key";
- insertOrganization(copyOf(ORGANIZATION_DTO).setUuid("uuid").setKey(anotherKey));
+ insertOrganization(copyOf(ORGANIZATION_DTO_1).setUuid("uuid").setKey(anotherKey));
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(2);
assertThat(underTest.deleteByKey(dbSession, anotherKey)).isEqualTo(1);
dbSession.commit();
assertThat(underTest.selectByKey(dbSession, anotherKey)).isEmpty();
- assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO.getKey())).isNotEmpty();
+ assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO_1.getKey())).isNotEmpty();
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(1);
assertThat(underTest.deleteByKey(dbSession, anotherKey)).isEqualTo(0);
- assertThat(underTest.deleteByKey(dbSession, ORGANIZATION_DTO.getKey())).isEqualTo(1);
+ assertThat(underTest.deleteByKey(dbSession, ORGANIZATION_DTO_1.getKey())).isEqualTo(1);
dbSession.commit();
- assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO.getKey())).isEmpty();
+ assertThat(underTest.selectByKey(dbSession, ORGANIZATION_DTO_1.getKey())).isEmpty();
assertThat(dbTester.countRowsOfTable("organizations")).isEqualTo(0);
}
@@ -417,17 +488,36 @@ public class OrganizationDaoTest {
dbSession.commit();
}
- private void verify(Optional<OrganizationDto> optional) {
+ private void verifyOrganization1(Optional<OrganizationDto> optional) {
+ assertThat(optional).isNotEmpty();
+ verifyOrganization1(optional.get());
+ }
+
+ private void verifyOrganization1(OrganizationDto dto) {
+ assertThat(dto.getUuid()).isEqualTo(ORGANIZATION_DTO_1.getUuid());
+ assertThat(dto.getKey()).isEqualTo(ORGANIZATION_DTO_1.getKey());
+ assertThat(dto.getName()).isEqualTo(ORGANIZATION_DTO_1.getName());
+ assertThat(dto.getDescription()).isEqualTo(ORGANIZATION_DTO_1.getDescription());
+ assertThat(dto.getUrl()).isEqualTo(ORGANIZATION_DTO_1.getUrl());
+ assertThat(dto.getAvatarUrl()).isEqualTo(ORGANIZATION_DTO_1.getAvatarUrl());
+ assertThat(dto.getCreatedAt()).isEqualTo(ORGANIZATION_DTO_1.getCreatedAt());
+ assertThat(dto.getUpdatedAt()).isEqualTo(ORGANIZATION_DTO_1.getUpdatedAt());
+ }
+
+ private void verifyOrganization(Optional<OrganizationDto> optional, OrganizationDto expected) {
assertThat(optional).isNotEmpty();
- OrganizationDto dto = optional.get();
- assertThat(dto.getUuid()).isEqualTo(ORGANIZATION_DTO.getUuid());
- assertThat(dto.getKey()).isEqualTo(ORGANIZATION_DTO.getKey());
- assertThat(dto.getName()).isEqualTo(ORGANIZATION_DTO.getName());
- assertThat(dto.getDescription()).isEqualTo(ORGANIZATION_DTO.getDescription());
- assertThat(dto.getUrl()).isEqualTo(ORGANIZATION_DTO.getUrl());
- assertThat(dto.getAvatarUrl()).isEqualTo(ORGANIZATION_DTO.getAvatarUrl());
- assertThat(dto.getCreatedAt()).isEqualTo(ORGANIZATION_DTO.getCreatedAt());
- assertThat(dto.getUpdatedAt()).isEqualTo(ORGANIZATION_DTO.getUpdatedAt());
+ verifyOrganization(optional.get(), expected);
+ }
+
+ private void verifyOrganization(OrganizationDto dto, OrganizationDto expected) {
+ assertThat(dto.getUuid()).isEqualTo(expected.getUuid());
+ assertThat(dto.getKey()).isEqualTo(expected.getKey());
+ assertThat(dto.getName()).isEqualTo(expected.getName());
+ assertThat(dto.getDescription()).isEqualTo(expected.getDescription());
+ assertThat(dto.getUrl()).isEqualTo(expected.getUrl());
+ assertThat(dto.getAvatarUrl()).isEqualTo(expected.getAvatarUrl());
+ assertThat(dto.getCreatedAt()).isEqualTo(expected.getCreatedAt());
+ assertThat(dto.getUpdatedAt()).isEqualTo(expected.getUpdatedAt());
}
private Map<String, Object> selectSingleRow() {