aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/component/DefaultRubyComponentService.java8
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/component/DefaultRubyComponentServiceTest.java21
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/permission/PermissionTemplateServiceTest.java2
-rw-r--r--sonar-db/src/main/java/org/sonar/db/component/ComponentMapper.java16
-rw-r--r--sonar-db/src/main/java/org/sonar/db/component/ResourceDao.java106
-rw-r--r--sonar-db/src/main/java/org/sonar/db/component/ResourceMapper.java30
-rw-r--r--sonar-db/src/main/resources/org/sonar/db/component/ComponentMapper.xml72
-rw-r--r--sonar-db/src/main/resources/org/sonar/db/component/ResourceMapper.xml87
-rw-r--r--sonar-db/src/test/java/org/sonar/db/component/ResourceDaoTest.java57
9 files changed, 1 insertions, 398 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/component/DefaultRubyComponentService.java b/server/sonar-server/src/main/java/org/sonar/server/component/DefaultRubyComponentService.java
index 99e379d7c0d..5aad761f182 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/component/DefaultRubyComponentService.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/component/DefaultRubyComponentService.java
@@ -67,14 +67,6 @@ public class DefaultRubyComponentService implements RubyComponentService {
}
}
- // Used in rails
- @CheckForNull
- public Component findByUuid(String uuid) {
- try (DbSession dbSession = dbClient.openSession(false)) {
- return dbClient.componentDao().selectByUuid(dbSession, uuid).orNull();
- }
- }
-
// Used in GOV
@CheckForNull
public Long createComponent(String key, String name, String qualifier) {
diff --git a/server/sonar-server/src/test/java/org/sonar/server/component/DefaultRubyComponentServiceTest.java b/server/sonar-server/src/test/java/org/sonar/server/component/DefaultRubyComponentServiceTest.java
index 20368627ad9..46f0c39324f 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/component/DefaultRubyComponentServiceTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/component/DefaultRubyComponentServiceTest.java
@@ -94,27 +94,6 @@ public class DefaultRubyComponentServiceTest {
}
@Test
- public void find_by_key() {
- ComponentDto componentDto = componentDb.insertProject();
-
- assertThat(underTest.findByKey(componentDto.getKey())).isNotNull();
- }
-
- @Test
- public void find_by_uuid() {
- ComponentDto componentDto = componentDb.insertProject();
-
- assertThat(underTest.findByUuid(componentDto.uuid())).isNotNull();
- }
-
- @Test
- public void not_find_by_uuid() {
- componentDb.insertProject();
-
- assertThat(underTest.findByUuid("UNKNOWN")).isNull();
- }
-
- @Test
public void create_component() {
userSession.login("john").setGlobalPermissions(PROVISIONING);
String componentKey = "new-project";
diff --git a/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionTemplateServiceTest.java b/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionTemplateServiceTest.java
index e57afe03f6c..cc54ef95f22 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionTemplateServiceTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/permission/PermissionTemplateServiceTest.java
@@ -154,7 +154,7 @@ public class PermissionTemplateServiceTest {
}
private void checkAuthorizationUpdatedAtIsUpdated() {
- assertThat(dbTester.getDbClient().resourceDao().selectResource(PROJECT.getId(), session).getAuthorizationUpdatedAt()).isEqualTo(NOW);
+ assertThat(dbTester.getDbClient().componentDao().selectOrFailById(session, PROJECT.getId()).getAuthorizationUpdatedAt()).isEqualTo(NOW);
}
private void setDefaultTemplateUuid(String templateUuid) {
diff --git a/sonar-db/src/main/java/org/sonar/db/component/ComponentMapper.java b/sonar-db/src/main/java/org/sonar/db/component/ComponentMapper.java
index 46f0010223b..f57fc3384c1 100644
--- a/sonar-db/src/main/java/org/sonar/db/component/ComponentMapper.java
+++ b/sonar-db/src/main/java/org/sonar/db/component/ComponentMapper.java
@@ -28,9 +28,6 @@ import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.ResultHandler;
import org.apache.ibatis.session.RowBounds;
-/**
- * @since 4.3
- */
public interface ComponentMapper {
@CheckForNull
@@ -63,26 +60,15 @@ public interface ComponentMapper {
int countByQuery(@Param("query") ComponentQuery query);
- List<ComponentDto> selectAncestors(@Param("query") ComponentTreeQuery query, @Param("baseUuidPathLike") String baseUuidPathLike);
-
List<ComponentDto> selectDescendants(@Param("query") ComponentTreeQuery query, @Param("baseUuid") String baseUuid, @Param("baseUuidPath") String baseUuidPath);
/**
- * Return all project (PRJ/TRK) uuids
- */
- List<String> selectProjectUuids();
-
- /**
* Returns all enabled projects (Scope {@link org.sonar.api.resources.Scopes#PROJECT} and qualifier
* {@link org.sonar.api.resources.Qualifiers#PROJECT}) no matter if they are ghost project, provisioned projects or
* regular ones.
*/
List<ComponentDto> selectProjects();
- List<ComponentDto> selectComponents(Map<String, Object> parameters, RowBounds rowBounds);
-
- int countRootComponents(Map<String, Object> parameters);
-
/**
* Return all descendant modules (including itself) from a given component uuid and scope
*/
@@ -120,8 +106,6 @@ public interface ComponentMapper {
*/
List<String> selectProjectsFromView(@Param("viewUuidLikeQuery") String viewUuidLikeQuery, @Param("projectViewUuid") String projectViewUuid);
- long countById(long id);
-
List<ComponentDto> selectProvisionedProjects(Map<String, Object> parameters, RowBounds rowBounds);
int countProvisionedProjects(Map<String, Object> parameters);
diff --git a/sonar-db/src/main/java/org/sonar/db/component/ResourceDao.java b/sonar-db/src/main/java/org/sonar/db/component/ResourceDao.java
index 8c5a2959344..c7852d0e0ba 100644
--- a/sonar-db/src/main/java/org/sonar/db/component/ResourceDao.java
+++ b/sonar-db/src/main/java/org/sonar/db/component/ResourceDao.java
@@ -19,42 +19,22 @@
*/
package org.sonar.db.component;
-import com.google.common.base.Function;
-import com.google.common.collect.Iterables;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import javax.annotation.CheckForNull;
-import javax.annotation.Nonnull;
import org.apache.ibatis.session.SqlSession;
-import org.sonar.api.component.Component;
import org.sonar.api.utils.System2;
import org.sonar.db.AbstractDao;
import org.sonar.db.DbSession;
import org.sonar.db.MyBatis;
-import static com.google.common.collect.Lists.newArrayList;
-
public class ResourceDao extends AbstractDao {
public ResourceDao(MyBatis myBatis, System2 system2) {
super(myBatis, system2);
}
- /**
- * Return a single result or null. If the request returns multiple rows, then
- * the first row is returned.
- */
- @CheckForNull
- public ResourceDto selectResource(ResourceQuery query) {
- DbSession session = myBatis().openSession(false);
- try {
- return selectResource(query, session);
- } finally {
- MyBatis.closeQuietly(session);
- }
- }
-
@CheckForNull
private static ResourceDto selectResource(ResourceQuery query, DbSession session) {
List<ResourceDto> resources = getResources(query, session);
@@ -83,29 +63,10 @@ public class ResourceDao extends AbstractDao {
return session.getMapper(ResourceMapper.class).selectResourceByUuid(componentUuid);
}
- public ResourceDto selectResource(long projectId, SqlSession session) {
- return session.getMapper(ResourceMapper.class).selectResource(projectId);
- }
-
- @CheckForNull
- public SnapshotDto getLastSnapshot(String resourceKey, SqlSession session) {
- return session.getMapper(ResourceMapper.class).selectLastSnapshotByResourceKey(resourceKey);
- }
-
- public List<ResourceDto> selectWholeTreeForRootId(SqlSession session, long rootId, String scope) {
- return session.getMapper(ResourceMapper.class).selectWholeTreeForRootId(rootId, scope);
- }
-
public void updateAuthorizationDate(Long projectId, SqlSession session) {
session.getMapper(ResourceMapper.class).updateAuthorizationDate(projectId, now());
}
- @CheckForNull
- public Component selectByKey(String key) {
- ResourceDto resourceDto = selectResource(ResourceQuery.create().setKey(key));
- return resourceDto != null ? toComponent(resourceDto) : null;
- }
-
/**
* Return the root project of a component.
* Will return the component itself if it's already the root project
@@ -151,51 +112,6 @@ public class ResourceDao extends AbstractDao {
return null;
}
- public List<Component> selectProjectsByQualifiers(Collection<String> qualifiers) {
- if (qualifiers.isEmpty()) {
- return Collections.emptyList();
- }
- SqlSession session = myBatis().openSession(false);
- try {
- return toComponents(session.getMapper(ResourceMapper.class).selectProjectsByQualifiers(qualifiers));
- } finally {
- MyBatis.closeQuietly(session);
- }
- }
-
- /**
- * Return enabled projects including not completed ones, ie without snapshots or without snapshot having islast=true
- */
- public List<Component> selectProjectsIncludingNotCompletedOnesByQualifiers(Collection<String> qualifiers) {
- if (qualifiers.isEmpty()) {
- return Collections.emptyList();
- }
- SqlSession session = myBatis().openSession(false);
- try {
- return toComponents(session.getMapper(ResourceMapper.class).selectProjectsIncludingNotCompletedOnesByQualifiers(qualifiers));
- } finally {
- MyBatis.closeQuietly(session);
- }
- }
-
- /**
- * Return ghosts projects :
- * - not enabled projects
- * - enabled projects without snapshot having islast=true
- * - enabled projects without snapshot
- */
- public List<Component> selectGhostsProjects(Collection<String> qualifiers) {
- if (qualifiers.isEmpty()) {
- return Collections.emptyList();
- }
- SqlSession session = myBatis().openSession(false);
- try {
- return toComponents(session.getMapper(ResourceMapper.class).selectGhostsProjects(qualifiers));
- } finally {
- MyBatis.closeQuietly(session);
- }
- }
-
/**
* Return provisioned projects = enabled projects without snapshot
*/
@@ -218,26 +134,4 @@ public class ResourceDao extends AbstractDao {
return session.getMapper(ResourceMapper.class).selectProvisionedProject(key);
}
- public static ComponentDto toComponent(ResourceDto resourceDto) {
- return new ComponentDto()
- .setId(resourceDto.getId())
- .setKey(resourceDto.getKey())
- .setPath(resourceDto.getPath())
- .setLongName(resourceDto.getLongName())
- .setName(resourceDto.getName())
- .setQualifier(resourceDto.getQualifier());
- }
-
- public static List<Component> toComponents(List<ResourceDto> resourceDto) {
- return newArrayList(Iterables.transform(resourceDto, ToComponent.INSTANCE));
- }
-
- private enum ToComponent implements Function<ResourceDto, Component> {
- INSTANCE;
-
- @Override
- public Component apply(@Nonnull ResourceDto resourceDto) {
- return toComponent(resourceDto);
- }
- }
}
diff --git a/sonar-db/src/main/java/org/sonar/db/component/ResourceMapper.java b/sonar-db/src/main/java/org/sonar/db/component/ResourceMapper.java
index 86e1f747c27..296ba846eaf 100644
--- a/sonar-db/src/main/java/org/sonar/db/component/ResourceMapper.java
+++ b/sonar-db/src/main/java/org/sonar/db/component/ResourceMapper.java
@@ -22,42 +22,12 @@ package org.sonar.db.component;
import java.util.Collection;
import java.util.List;
import org.apache.ibatis.annotations.Param;
-import org.apache.ibatis.session.ResultHandler;
public interface ResourceMapper {
- SnapshotDto selectSnapshot(Long snapshotId);
-
- SnapshotDto selectLastSnapshotByResourceKey(String resourceKey);
-
- SnapshotDto selectLastSnapshotByResourceUuid(String componentUuid);
-
- ResourceDto selectResource(long id);
-
ResourceDto selectResourceByUuid(String uuid);
- List<ResourceDto> selectWholeTreeForRootId(@Param("rootId") long rootId, @Param("scope") String scope);
-
- /**
- * @since 3.0
- */
List<ResourceDto> selectResources(ResourceQuery query);
- /**
- * @since 3.0
- */
- List<Long> selectResourceIds(ResourceQuery query);
-
- /**
- * @since 3.2
- */
- void selectResources(ResourceQuery query, ResultHandler resultHandler);
-
- List<ResourceDto> selectProjectsIncludingNotCompletedOnesByQualifiers(@Param("qualifiers") Collection<String> qualifier);
-
- List<ResourceDto> selectProjectsByQualifiers(@Param("qualifiers") Collection<String> qualifier);
-
- List<ResourceDto> selectGhostsProjects(@Param("qualifiers") Collection<String> qualifier);
-
List<ResourceDto> selectProvisionedProjects(@Param("qualifiers") Collection<String> qualifier);
ResourceDto selectProvisionedProject(@Param("key") String key);
diff --git a/sonar-db/src/main/resources/org/sonar/db/component/ComponentMapper.xml b/sonar-db/src/main/resources/org/sonar/db/component/ComponentMapper.xml
index 6ac9bfbc672..8bbb25cad00 100644
--- a/sonar-db/src/main/resources/org/sonar/db/component/ComponentMapper.xml
+++ b/sonar-db/src/main/resources/org/sonar/db/component/ComponentMapper.xml
@@ -71,14 +71,6 @@
root.uuid=#{projectUuid}
</select>
- <select id="countById" parameterType="long" resultType="long">
- SELECT count(p.id)
- FROM projects p
- <where>
- AND p.id=#{id}
- </where>
- </select>
-
<select id="selectByKeys" parameterType="String" resultType="Component">
select
<include refid="componentColumns"/>
@@ -211,16 +203,6 @@
<include refid="modulesTreeQuery"/>
</select>
- <select id="selectProjectUuids" resultType="String">
- SELECT p.uuid
- FROM projects p
- <where>
- AND p.enabled=${_true}
- AND p.scope='PRJ'
- AND p.qualifier='TRK'
- </where>
- </select>
-
<select id="selectProjects" resultType="Component">
select
<include refid="componentColumns"/>
@@ -243,27 +225,6 @@
</where>
</select>
- <select id="selectComponents" resultType="Component">
- select
- <include refid="componentColumns"/>
- from projects p
- <where>
- AND p.enabled=${_true}
- AND p.copy_component_uuid is null
- AND p.qualifier in
- <foreach collection="qualifiers" open="(" close=")" item="qualifier" separator=",">
- #{qualifier}
- </foreach>
- <if test="query!=null">
- and (
- UPPER(p.name) like #{query}
- or UPPER(p.kee) like #{query}
- )
- </if>
- </where>
- ORDER BY UPPER(p.name), p.name
- </select>
-
<select id="selectByQuery" resultType="Component">
select
<include refid="componentColumns"/>
@@ -315,20 +276,6 @@
</if>
</sql>
- <!-- "p" is ancestors -->
- <select id="selectAncestors" resultType="Component">
- select
- <include refid="componentColumns"/>
- from projects base
- inner join projects p on p.project_uuid = base.project_uuid
- where
- base.uuid = #{query.baseUuid}
- and base.uuid_path like #{baseUuidPathLike}
- and p.uuid != base.uuid
- and p.enabled = ${_true}
- order by ${query.sqlSort}
- </select>
-
<select id="selectDescendants" resultType="Component">
select
<include refid="componentColumns"/>
@@ -378,25 +325,6 @@
</if>
</sql>
- <select id="countRootComponents" resultType="int">
- select count(p.id)
- from projects p
- <where>
- p.enabled=${_true}
- AND p.copy_component_uuid is null
- AND p.qualifier in
- <foreach collection="qualifiers" open="(" close=")" item="qualifier" separator=",">
- #{qualifier}
- </foreach>
- <if test="query!=null">
- and (
- UPPER(p.name) like #{query}
- or UPPER(p.kee) like #{query}
- )
- </if>
- </where>
- </select>
-
<select id="selectUuidsForQualifiers" resultType="UuidWithProjectUuid">
SELECT p.uuid as "uuid", p.project_uuid as "projectUuid" FROM projects p
<where>
diff --git a/sonar-db/src/main/resources/org/sonar/db/component/ResourceMapper.xml b/sonar-db/src/main/resources/org/sonar/db/component/ResourceMapper.xml
index 8316ec08936..9b87197a94d 100644
--- a/sonar-db/src/main/resources/org/sonar/db/component/ResourceMapper.xml
+++ b/sonar-db/src/main/resources/org/sonar/db/component/ResourceMapper.xml
@@ -88,98 +88,11 @@
</where>
</select>
- <select id="selectResource" parameterType="long" resultMap="resourceResultMap">
- select * from projects p
- where p.id=#{id}
- </select>
-
<select id="selectResourceByUuid" parameterType="String" resultMap="resourceResultMap">
select * from projects p
where p.uuid=#{uuid}
</select>
- <select id="selectSnapshot" parameterType="long" resultMap="snapshotResultMap">
- select * from snapshots where id=#{id}
- </select>
-
- <select id="selectLastSnapshotByResourceKey" parameterType="string" resultMap="snapshotResultMap">
- SELECT s.* FROM snapshots s
- INNER JOIN projects p on p.uuid=s.component_uuid AND p.enabled=${_true} AND p.copy_component_uuid is null
- <where>
- AND p.kee=#{id}
- AND s.islast=${_true}
- </where>
- </select>
-
- <select id="selectLastSnapshotByResourceUuid" parameterType="string" resultMap="snapshotResultMap">
- SELECT s.* from snapshots s
- INNER JOIN projects p on p.uuid=s.component_uuid AND p.enabled=${_true} AND p.copy_component_uuid is null
- <where>
- AND p.uuid=#{uuid}
- AND s.islast=${_true}
- </where>
- </select>
-
- <select id="selectWholeTreeForRootId" parameterType="long" resultMap="resourceResultMap">
- select
- pAll.*
- from projects pAll
- inner join projects pRoot on pAll.project_uuid = pRoot.uuid and pRoot.id = #{rootId}
- <where>
- pAll.scope = #{scope}
- </where>
- </select>
-
- <select id="selectProjectsIncludingNotCompletedOnesByQualifiers" parameterType="map" resultMap="resourceResultMap">
- select * from projects p
- <where>
- <if test="qualifiers != null and qualifiers.size() > 0">
- and
- <foreach item="qualifier" index="index" collection="qualifiers" open="(" separator=" or " close=")">
- p.qualifier=#{qualifier}
- </foreach>
- </if>
- and p.enabled=${_true}
- and p.copy_component_uuid is null
- </where>
- </select>
-
- <select id="selectProjectsByQualifiers" parameterType="map" resultMap="resourceResultMap">
- <include refid="selectProjectsByQualifiersQuery"/>
- </select>
-
- <sql id="selectProjectsByQualifiersQuery">
- select p.* from projects p
- inner join snapshots s on s.component_uuid=p.uuid
- <where>
- <if test="qualifiers != null and qualifiers.size() > 0">
- and
- <foreach item="qualifier" index="index" collection="qualifiers" open="(" separator=" or " close=")">
- p.qualifier=#{qualifier}
- </foreach>
- </if>
- and p.enabled=${_true}
- and p.copy_component_uuid is null
- and s.islast=${_true}
- </where>
- </sql>
-
- <select id="selectGhostsProjects" parameterType="map" resultMap="resourceResultMap">
- select distinct p.* from projects p
- inner join snapshots s1 on s1.component_uuid = p.uuid and s1.status='U'
- left join snapshots s2 on s2.component_uuid = p.uuid and s2.status='P'
- <where>
- and s2.id is null
- <if test="qualifiers != null and qualifiers.size() > 0">
- and
- <foreach item="qualifier" index="index" collection="qualifiers" open="(" separator=" or " close=")">
- p.qualifier=#{qualifier}
- </foreach>
- </if>
- and p.copy_component_uuid is null
- </where>
- </select>
-
<select id="selectProvisionedProjects" parameterType="map" resultMap="resourceResultMap">
select p.* from projects p
left join snapshots s on s.component_uuid=p.uuid
diff --git a/sonar-db/src/test/java/org/sonar/db/component/ResourceDaoTest.java b/sonar-db/src/test/java/org/sonar/db/component/ResourceDaoTest.java
index b3dceba464e..c37aa18db02 100644
--- a/sonar-db/src/test/java/org/sonar/db/component/ResourceDaoTest.java
+++ b/sonar-db/src/test/java/org/sonar/db/component/ResourceDaoTest.java
@@ -33,7 +33,6 @@ import static org.assertj.core.api.Assertions.assertThat;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
-
public class ResourceDaoTest {
static System2 system = mock(System2.class);
@@ -63,15 +62,6 @@ public class ResourceDaoTest {
}
@Test
- public void getResource_filter_by_key() {
- dbTester.prepareDbUnit(getClass(), "fixture.xml");
-
- ResourceQuery query = ResourceQuery.create().setKey("org.struts:struts-core");
-
- assertThat(underTest.selectResource(query).getKey()).isEqualTo("org.struts:struts-core");
- }
-
- @Test
public void find_root_project_by_component_key() {
dbTester.prepareDbUnit(getClass(), "fixture.xml");
@@ -84,53 +74,6 @@ public class ResourceDaoTest {
}
@Test
- public void should_find_component_by_key() {
- dbTester.prepareDbUnit(getClass(), "fixture.xml");
-
- assertThat(underTest.selectByKey("org.struts:struts")).isNotNull();
- Component component = underTest.selectByKey("org.struts:struts-core:src/org/struts/RequestContext.java");
- assertThat(component).isNotNull();
- assertThat(component.path()).isEqualTo("src/org/struts/RequestContext.java");
- assertThat(underTest.selectByKey("unknown")).isNull();
- }
-
- @Test
- public void should_select_projects_by_qualifiers() {
- dbTester.prepareDbUnit(getClass(), "fixture-including-ghost-projects-and-technical-project.xml");
-
- List<Component> components = underTest.selectProjectsByQualifiers(newArrayList("TRK"));
- assertThat(components).hasSize(1);
- assertThat(components.get(0).key()).isEqualTo("org.struts:struts");
- assertThat(((ComponentDto) components.get(0)).getId()).isEqualTo(1L);
-
- assertThat(underTest.selectProjectsIncludingNotCompletedOnesByQualifiers(newArrayList("unknown"))).isEmpty();
- assertThat(underTest.selectProjectsIncludingNotCompletedOnesByQualifiers(Collections.<String>emptyList())).isEmpty();
- }
-
- @Test
- public void should_select_projects_including_not_finished_by_qualifiers() {
- dbTester.prepareDbUnit(getClass(), "fixture-including-ghost-projects-and-technical-project.xml");
-
- List<Component> components = underTest.selectProjectsIncludingNotCompletedOnesByQualifiers(newArrayList("TRK"));
- assertThat(getKeys(components)).containsOnly("org.struts:struts", "org.apache.shindig", "org.sample:sample");
-
- assertThat(underTest.selectProjectsIncludingNotCompletedOnesByQualifiers(newArrayList("unknown"))).isEmpty();
- assertThat(underTest.selectProjectsIncludingNotCompletedOnesByQualifiers(Collections.<String>emptyList())).isEmpty();
- }
-
- @Test
- public void should_select_ghosts_projects_by_qualifiers() {
- dbTester.prepareDbUnit(getClass(), "fixture-including-ghost-projects-and-technical-project.xml");
-
- List<Component> components = underTest.selectGhostsProjects(newArrayList("TRK"));
- assertThat(components).hasSize(1);
- assertThat(getKeys(components)).containsOnly("org.apache.shindig");
-
- assertThat(underTest.selectGhostsProjects(newArrayList("unknown"))).isEmpty();
- assertThat(underTest.selectGhostsProjects(Collections.<String>emptyList())).isEmpty();
- }
-
- @Test
public void should_select_provisioned_projects_by_qualifiers() {
dbTester.prepareDbUnit(getClass(), "fixture-including-ghost-projects-and-technical-project.xml");