diff options
author | Simon Brandhof <simon.brandhof@sonarsource.com> | 2017-05-31 10:59:33 +0200 |
---|---|---|
committer | Eric Hartmann <hartmann.eric@gmail.com> | 2017-06-14 15:43:12 +0200 |
commit | 3e26c9b9b44ebabbc2c81e134c26799ce3f4bc3b (patch) | |
tree | 548b40695d3fb85cdcd42c889bb1ae470cbbbb14 | |
parent | d4133c63eb8e7b6acc54195da3206f1b3a5f7689 (diff) | |
download | sonarqube-3e26c9b9b44ebabbc2c81e134c26799ce3f4bc3b.tar.gz sonarqube-3e26c9b9b44ebabbc2c81e134c26799ce3f4bc3b.zip |
SONAR-9304 rename table qprofiles to org_qprofiles
139 files changed, 1746 insertions, 1728 deletions
diff --git a/server/sonar-db-core/src/main/java/org/sonar/db/version/SqTables.java b/server/sonar-db-core/src/main/java/org/sonar/db/version/SqTables.java index 7e23cf9dd70..c86a1b6a92c 100644 --- a/server/sonar-db-core/src/main/java/org/sonar/db/version/SqTables.java +++ b/server/sonar-db-core/src/main/java/org/sonar/db/version/SqTables.java @@ -68,19 +68,19 @@ public final class SqTables { "notifications", "organizations", "organization_members", + "org_qprofiles", "permission_templates", "perm_templates_users", "perm_templates_groups", "perm_tpl_characteristics", - "quality_gates", - "quality_gate_conditions", "projects", "project_links", "project_measures", "project_qprofiles", "properties", "qprofile_changes", - "qprofiles", + "quality_gates", + "quality_gate_conditions", "rules", "rules_metadata", "rules_parameters", diff --git a/server/sonar-db-core/src/main/resources/org/sonar/db/version/schema-h2.ddl b/server/sonar-db-core/src/main/resources/org/sonar/db/version/schema-h2.ddl index 21791997147..eda17e61f32 100644 --- a/server/sonar-db-core/src/main/resources/org/sonar/db/version/schema-h2.ddl +++ b/server/sonar-db-core/src/main/resources/org/sonar/db/version/schema-h2.ddl @@ -47,9 +47,7 @@ CREATE TABLE "RULES_PROFILES" ( "ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1), "NAME" VARCHAR(100) NOT NULL, "LANGUAGE" VARCHAR(20), - "ORGANIZATION_UUID" VARCHAR(40) NOT NULL, "KEE" VARCHAR(255) NOT NULL, - "PARENT_KEE" VARCHAR(255), "RULES_UPDATED_AT" VARCHAR(100), "CREATED_AT" TIMESTAMP, "UPDATED_AT" TIMESTAMP, @@ -60,7 +58,7 @@ CREATE TABLE "RULES_PROFILES" ( CREATE UNIQUE INDEX "UNIQ_QPROF_KEY" ON "RULES_PROFILES" ("KEE"); -CREATE TABLE "QPROFILES" ( +CREATE TABLE "ORG_QPROFILES" ( "UUID" VARCHAR(40) NOT NULL PRIMARY KEY, "ORGANIZATION_UUID" VARCHAR(40) NOT NULL, "RULES_PROFILE_UUID" VARCHAR(40) NOT NULL, @@ -68,7 +66,8 @@ CREATE TABLE "QPROFILES" ( "CREATED_AT" BIGINT NOT NULL, "UPDATED_AT" BIGINT NOT NULL ); -CREATE INDEX "QPROFILES_ORG_UUID" ON "QPROFILES" ("ORGANIZATION_UUID"); +CREATE INDEX "ORG_QPROFILES_ORG_UUID" ON "ORG_QPROFILES" ("ORGANIZATION_UUID"); +CREATE INDEX "ORG_QPROFILES_RP_UUID" ON "ORG_QPROFILES" ("RULES_PROFILE_UUID"); CREATE TABLE "DEFAULT_QPROFILES" ( diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java b/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java index d55857343c3..e99aec847ea 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java @@ -97,7 +97,6 @@ import org.sonar.db.qualityprofile.ActiveRuleMapper; import org.sonar.db.qualityprofile.ActiveRuleParamDto; import org.sonar.db.qualityprofile.DefaultQProfileMapper; import org.sonar.db.qualityprofile.QProfileChangeMapper; -import org.sonar.db.qualityprofile.RulesProfileDto; import org.sonar.db.qualityprofile.QualityProfileMapper; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleMapper; @@ -166,7 +165,6 @@ public class MyBatis implements Startable { confBuilder.loadAlias("PurgeableAnalysis", PurgeableAnalysisDto.class); confBuilder.loadAlias("QualityGateCondition", QualityGateConditionDto.class); confBuilder.loadAlias("QualityGate", QualityGateDto.class); - confBuilder.loadAlias("RulesProfile", RulesProfileDto.class); confBuilder.loadAlias("RequirementMigration", RequirementMigrationDto.class); confBuilder.loadAlias("Resource", ResourceDto.class); confBuilder.loadAlias("RuleParam", RuleParamDto.class); diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/ActiveRuleDto.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/ActiveRuleDto.java index ff3719a8810..415c17564ec 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/ActiveRuleDto.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/ActiveRuleDto.java @@ -142,7 +142,7 @@ public class ActiveRuleDto { return this; } - public static ActiveRuleDto createFor(RulesProfileDto profileDto, RuleDefinitionDto ruleDto) { + public static ActiveRuleDto createFor(QProfileDto profileDto, RuleDefinitionDto ruleDto) { requireNonNull(profileDto.getId(), "Profile is not persisted"); requireNonNull(ruleDto.getId(), "Rule is not persisted"); ActiveRuleDto dto = new ActiveRuleDto(); diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/DefaultQProfileDto.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/DefaultQProfileDto.java index e97e7803665..4474af22cf9 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/DefaultQProfileDto.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/DefaultQProfileDto.java @@ -52,7 +52,7 @@ public class DefaultQProfileDto { return this; } - public static DefaultQProfileDto from(RulesProfileDto profile) { + public static DefaultQProfileDto from(QProfileDto profile) { return new DefaultQProfileDto() .setOrganizationUuid(profile.getOrganizationUuid()) .setLanguage(profile.getLanguage()) diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeDao.java index b98e7b24d29..783f1580563 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeDao.java @@ -40,9 +40,7 @@ public class QProfileChangeDao implements Dao { } public void insert(DbSession dbSession, QProfileChangeDto dto) { - checkState(dto.getKey() == null, "Key of QProfileChangeDto must be set by DAO only. Got %s.", dto.getKey()); checkState(dto.getCreatedAt() == 0L, "Date of QProfileChangeDto must be set by DAO only. Got %s.", dto.getCreatedAt()); - dto.setKey(uuidFactory.create()); dto.setCreatedAt(system2.now()); mapper(dbSession).insert(dto); @@ -52,13 +50,13 @@ public class QProfileChangeDao implements Dao { return mapper(dbSession).selectByQuery(query); } - public int countForProfileKey(DbSession dbSession, String profileKey) { - return mapper(dbSession).countForProfileKey(profileKey); + public int countForProfileUuid(DbSession dbSession, String profileUuid) { + return mapper(dbSession).countForProfileUuid(profileUuid); } - public void deleteByProfileKeys(DbSession dbSession, Collection<String> profileKeys) { + public void deleteByProfileKeys(DbSession dbSession, Collection<String> profileUuids) { QProfileChangeMapper mapper = mapper(dbSession); - DatabaseUtils.executeLargeUpdates(profileKeys, mapper::deleteByProfileKeys); + DatabaseUtils.executeLargeUpdates(profileUuids, mapper::deleteByProfileUuids); } private static QProfileChangeMapper mapper(DbSession dbSession) { diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeMapper.java index 24d46605d9e..6d14638fcd2 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeMapper.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeMapper.java @@ -29,7 +29,7 @@ public interface QProfileChangeMapper { List<QProfileChangeDto> selectByQuery(@Param("query") QProfileChangeQuery query); - int countForProfileKey(@Param("profileKey") String profileKey); + int countForProfileUuid(@Param("profileUuid") String profileUuid); - void deleteByProfileKeys(@Param("profileKeys") Collection<String> profileKeys); + void deleteByProfileUuids(@Param("profileUuids") Collection<String> profileUuids); } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeQuery.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeQuery.java index 8bbcbd88584..8de9d798c0f 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeQuery.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileChangeQuery.java @@ -28,18 +28,18 @@ import static java.util.Objects.requireNonNull; public class QProfileChangeQuery { - private final String profileKey; + private final String profileUuid; private Long fromIncluded; private Long toExcluded; private int offset = 0; private int limit = 100; - public QProfileChangeQuery(String profileKey) { - this.profileKey = requireNonNull(profileKey); + public QProfileChangeQuery(String profileUuid) { + this.profileUuid = requireNonNull(profileUuid); } - public String getProfileKey() { - return profileKey; + public String getProfileUuid() { + return profileUuid; } @CheckForNull diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/RulesProfileDto.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileDto.java index 0afffd0f7aa..92f47a6d3c0 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/RulesProfileDto.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QProfileDto.java @@ -26,9 +26,9 @@ import org.sonar.core.util.UtcDateUtils; import org.sonar.db.organization.OrganizationDto; /** - * Represents the table "rules_profiles" + * Represents the join of "org_qprofiles" and "rules_profiles" */ -public class RulesProfileDto { +public class QProfileDto { private Integer id; /** @@ -50,12 +50,12 @@ public class RulesProfileDto { return organizationUuid; } - public RulesProfileDto setOrganizationUuid(String organizationUuid) { + public QProfileDto setOrganizationUuid(String organizationUuid) { this.organizationUuid = organizationUuid; return this; } - public RulesProfileDto setKey(String s) { + public QProfileDto setKey(String s) { return setKee(s); } @@ -63,7 +63,7 @@ public class RulesProfileDto { return kee; } - public RulesProfileDto setKee(String s) { + public QProfileDto setKee(String s) { this.kee = s; return this; } @@ -72,7 +72,7 @@ public class RulesProfileDto { return id; } - public RulesProfileDto setId(Integer id) { + public QProfileDto setId(Integer id) { this.id = id; return this; } @@ -81,7 +81,7 @@ public class RulesProfileDto { return name; } - public RulesProfileDto setName(String name) { + public QProfileDto setName(String name) { this.name = name; return this; } @@ -90,7 +90,7 @@ public class RulesProfileDto { return language; } - public RulesProfileDto setLanguage(String language) { + public QProfileDto setLanguage(String language) { this.language = language; return this; } @@ -100,7 +100,7 @@ public class RulesProfileDto { return parentKee; } - public RulesProfileDto setParentKee(@Nullable String s) { + public QProfileDto setParentKee(@Nullable String s) { this.parentKee = s; return this; } @@ -109,12 +109,12 @@ public class RulesProfileDto { return rulesUpdatedAt; } - public RulesProfileDto setRulesUpdatedAt(String s) { + public QProfileDto setRulesUpdatedAt(String s) { this.rulesUpdatedAt = s; return this; } - public RulesProfileDto setRulesUpdatedAtAsDate(Date d) { + public QProfileDto setRulesUpdatedAtAsDate(Date d) { this.rulesUpdatedAt = UtcDateUtils.formatDateTime(d); return this; } @@ -124,7 +124,7 @@ public class RulesProfileDto { return lastUsed; } - public RulesProfileDto setLastUsed(@Nullable Long lastUsed) { + public QProfileDto setLastUsed(@Nullable Long lastUsed) { this.lastUsed = lastUsed; return this; } @@ -134,7 +134,7 @@ public class RulesProfileDto { return userUpdatedAt; } - public RulesProfileDto setUserUpdatedAt(@Nullable Long userUpdatedAt) { + public QProfileDto setUserUpdatedAt(@Nullable Long userUpdatedAt) { this.userUpdatedAt = userUpdatedAt; return this; } @@ -143,12 +143,12 @@ public class RulesProfileDto { return isBuiltIn; } - public RulesProfileDto setIsBuiltIn(boolean b) { + public QProfileDto setIsBuiltIn(boolean b) { this.isBuiltIn = b; return this; } - public static RulesProfileDto createFor(String key) { - return new RulesProfileDto().setKee(key); + public static QProfileDto createFor(String key) { + return new QProfileDto().setKee(key); } } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileDao.java index 7dd416bd086..e23cc4d980a 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileDao.java @@ -20,7 +20,7 @@ package org.sonar.db.qualityprofile; import com.google.common.base.Preconditions; -import com.google.common.collect.Lists; +import java.util.ArrayList; import java.util.Collection; import java.util.Date; import java.util.List; @@ -49,84 +49,87 @@ public class QualityProfileDao implements Dao { } @CheckForNull - public RulesProfileDto selectByKey(DbSession session, String key) { - return mapper(session).selectByKey(key); + public QProfileDto selectByUuid(DbSession session, String uuid) { + return mapper(session).selectByUuid(uuid); } - public RulesProfileDto selectOrFailByKey(DbSession session, String key) { - RulesProfileDto dto = selectByKey(session, key); + public QProfileDto selectOrFailByUuid(DbSession session, String uuid) { + QProfileDto dto = selectByUuid(session, uuid); if (dto == null) { - throw new RowNotFoundException("Quality profile not found: " + key); + throw new RowNotFoundException("Quality profile not found: " + uuid); } return dto; } - public List<RulesProfileDto> selectByKeys(DbSession session, List<String> keys) { - return executeLargeInputs(keys, mapper(session)::selectByKeys); + public List<QProfileDto> selectByUuids(DbSession session, List<String> uuids) { + return executeLargeInputs(uuids, mapper(session)::selectByUuids); } - public List<RulesProfileDto> selectAll(DbSession session, OrganizationDto organization) { + public List<QProfileDto> selectAll(DbSession session, OrganizationDto organization) { return mapper(session).selectAll(organization.getUuid()); } - public void insert(DbSession session, RulesProfileDto profile, RulesProfileDto... otherProfiles) { + public void insert(DbSession session, QProfileDto profile, QProfileDto... otherProfiles) { QualityProfileMapper mapper = mapper(session); doInsert(mapper, profile); - for (RulesProfileDto other : otherProfiles) { + for (QProfileDto other : otherProfiles) { doInsert(mapper, other); } } - private void doInsert(QualityProfileMapper mapper, RulesProfileDto profile) { + private void doInsert(QualityProfileMapper mapper, QProfileDto profile) { Preconditions.checkArgument(profile.getId() == null, "Quality profile is already persisted (got id %d)", profile.getId()); - mapper.insert(profile, new Date(system.now())); + long now = system.now(); + mapper.insertRulesProfile(profile, new Date(now)); + mapper.insertOrgQProfile(profile, now); } - public void update(DbSession session, RulesProfileDto profile, RulesProfileDto... otherProfiles) { + public void update(DbSession session, QProfileDto profile, QProfileDto... otherProfiles) { QualityProfileMapper mapper = mapper(session); - doUpdate(mapper, profile); - for (RulesProfileDto otherProfile : otherProfiles) { - doUpdate(mapper, otherProfile); + long now = system.now(); + doUpdate(mapper, profile, now); + for (QProfileDto otherProfile : otherProfiles) { + doUpdate(mapper, otherProfile, now); } } - private void doUpdate(QualityProfileMapper mapper, RulesProfileDto profile) { - Preconditions.checkArgument(profile.getId() != null, "Quality profile is not persisted"); - mapper.update(profile, new Date(system.now())); + private void doUpdate(QualityProfileMapper mapper, QProfileDto profile, long now) { + mapper.updateRulesProfile(profile, new Date(now)); + mapper.updateOrgQProfile(profile, now); } - public List<RulesProfileDto> selectDefaultProfiles(DbSession session, OrganizationDto organization, Collection<String> languageKeys) { - return mapper(session).selectDefaultProfiles(organization.getUuid(), languageKeys); + public List<QProfileDto> selectDefaultProfiles(DbSession session, OrganizationDto organization, Collection<String> languages) { + return mapper(session).selectDefaultProfiles(organization.getUuid(), languages); } @CheckForNull - public RulesProfileDto selectDefaultProfile(DbSession session, OrganizationDto organization, String language) { + public QProfileDto selectDefaultProfile(DbSession session, OrganizationDto organization, String language) { return mapper(session).selectDefaultProfile(organization.getUuid(), language); } @CheckForNull - public RulesProfileDto selectAssociatedToProjectAndLanguage(DbSession session, ComponentDto project, String language) { + public QProfileDto selectAssociatedToProjectAndLanguage(DbSession session, ComponentDto project, String language) { return mapper(session).selectAssociatedToProjectUuidAndLanguage(project.getOrganizationUuid(), project.projectUuid(), language); } - public List<RulesProfileDto> selectAssociatedToProjectUuidAndLanguages(DbSession session, ComponentDto project, Collection<String> languages) { + public List<QProfileDto> selectAssociatedToProjectUuidAndLanguages(DbSession session, ComponentDto project, Collection<String> languages) { return mapper(session).selectAssociatedToProjectUuidAndLanguages(project.getOrganizationUuid(), project.uuid(), languages); } - public List<RulesProfileDto> selectByLanguage(DbSession dbSession, OrganizationDto organization, String language) { + public List<QProfileDto> selectByLanguage(DbSession dbSession, OrganizationDto organization, String language) { return mapper(dbSession).selectByLanguage(organization.getUuid(), language); } - public List<RulesProfileDto> selectChildren(DbSession session, String key) { - return mapper(session).selectChildren(key); + public List<QProfileDto> selectChildren(DbSession session, String uuid) { + return mapper(session).selectChildren(uuid); } /** * All descendants, in the top-down order. */ - public List<RulesProfileDto> selectDescendants(DbSession session, String key) { - List<RulesProfileDto> descendants = Lists.newArrayList(); - for (RulesProfileDto child : selectChildren(session, key)) { + public List<QProfileDto> selectDescendants(DbSession session, String uuid) { + List<QProfileDto> descendants = new ArrayList<>(); + for (QProfileDto child : selectChildren(session, uuid)) { descendants.add(child); descendants.addAll(selectDescendants(session, child.getKee())); } @@ -134,63 +137,69 @@ public class QualityProfileDao implements Dao { } @CheckForNull - public RulesProfileDto selectByNameAndLanguage(OrganizationDto organization, String name, String language, DbSession session) { + public QProfileDto selectByNameAndLanguage(DbSession session, OrganizationDto organization, String name, String language) { return mapper(session).selectByNameAndLanguage(organization.getUuid(), name, language); } - public List<RulesProfileDto> selectByNameAndLanguages(OrganizationDto organization, String name, Collection<String> languageKeys, DbSession session) { - return mapper(session).selectByNameAndLanguages(organization.getUuid(), name, languageKeys); + public List<QProfileDto> selectByNameAndLanguages(DbSession session, OrganizationDto organization, String name, Collection<String> languages) { + return mapper(session).selectByNameAndLanguages(organization.getUuid(), name, languages); } - public Map<String, Long> countProjectsByProfileKey(DbSession dbSession, OrganizationDto organization) { - return KeyLongValue.toMap(mapper(dbSession).countProjectsByProfileKey(organization.getUuid())); + public Map<String, Long> countProjectsByProfileUuid(DbSession dbSession, OrganizationDto organization) { + return KeyLongValue.toMap(mapper(dbSession).countProjectsByProfileUuid(organization.getUuid())); } - public void insertProjectProfileAssociation(DbSession dbSession, ComponentDto project, RulesProfileDto profile) { + public void insertProjectProfileAssociation(DbSession dbSession, ComponentDto project, QProfileDto profile) { mapper(dbSession).insertProjectProfileAssociation(project.uuid(), profile.getKee()); } - public void deleteProjectProfileAssociation(DbSession dbSession, ComponentDto project, RulesProfileDto profile) { + public void deleteProjectProfileAssociation(DbSession dbSession, ComponentDto project, QProfileDto profile) { mapper(dbSession).deleteProjectProfileAssociation(project.uuid(), profile.getKee()); } - public void updateProjectProfileAssociation(DbSession dbSession, ComponentDto project, String newProfileKey, String oldProfileKey) { - mapper(dbSession).updateProjectProfileAssociation(project.uuid(), newProfileKey, oldProfileKey); + public void updateProjectProfileAssociation(DbSession dbSession, ComponentDto project, String newProfileUuid, String oldProfileUuid) { + mapper(dbSession).updateProjectProfileAssociation(project.uuid(), newProfileUuid, oldProfileUuid); } - public void deleteProjectAssociationsByProfileKeys(DbSession dbSession, Collection<String> profileKeys) { + public void deleteProjectAssociationsByProfileUuids(DbSession dbSession, Collection<String> profileUuids) { QualityProfileMapper mapper = mapper(dbSession); - DatabaseUtils.executeLargeUpdates(profileKeys, mapper::deleteProjectAssociationByProfileKeys); + DatabaseUtils.executeLargeUpdates(profileUuids, mapper::deleteProjectAssociationByProfileUuids); } - public List<ProjectQprofileAssociationDto> selectSelectedProjects(OrganizationDto organization, String profileKey, @Nullable String query, DbSession session) { + public List<ProjectQprofileAssociationDto> selectSelectedProjects(DbSession session, OrganizationDto organization, QProfileDto profile, @Nullable String query) { String nameQuery = sqlQueryString(query); - return mapper(session).selectSelectedProjects(organization.getUuid(), profileKey, nameQuery); + return mapper(session).selectSelectedProjects(organization.getUuid(), profile.getKee(), nameQuery); } - public List<ProjectQprofileAssociationDto> selectDeselectedProjects(OrganizationDto organization, String profileKey, @Nullable String query, DbSession session) { + public List<ProjectQprofileAssociationDto> selectDeselectedProjects(DbSession session, OrganizationDto organization, QProfileDto profile, @Nullable String query) { String nameQuery = sqlQueryString(query); - return mapper(session).selectDeselectedProjects(organization.getUuid(), profileKey, nameQuery); + return mapper(session).selectDeselectedProjects(organization.getUuid(), profile.getKee(), nameQuery); } - public List<ProjectQprofileAssociationDto> selectProjectAssociations(OrganizationDto organization, String profileKey, @Nullable String query, DbSession session) { + public List<ProjectQprofileAssociationDto> selectProjectAssociations(DbSession session, OrganizationDto organization, QProfileDto profile, @Nullable String query) { String nameQuery = sqlQueryString(query); - return mapper(session).selectProjectAssociations(organization.getUuid(), profileKey, nameQuery); + return mapper(session).selectProjectAssociations(organization.getUuid(), profile.getKee(), nameQuery); } - public Collection<String> selectOutdatedProfiles(DbSession dbSession, String language, String name) { - return mapper(dbSession).selectOutdatedProfiles(language, name); + public Collection<String> selectUuidsOfCustomRulesProfiles(DbSession dbSession, String language, String name) { + return mapper(dbSession).selectUuidsOfCustomQProfiles(language, name); } - public void renameAndCommit(DbSession dbSession, Collection<String> keys, String newName) { + public void renameRulesProfilesAndCommit(DbSession dbSession, Collection<String> rulesProfileUuids, String newName) { QualityProfileMapper mapper = mapper(dbSession); Date now = new Date(system.now()); - executeLargeUpdates(keys, partition -> { - mapper.rename(newName, now, partition); + executeLargeUpdates(rulesProfileUuids, partition -> { + mapper.renameRulesProfiles(newName, now, partition); dbSession.commit(); }); } + public void deleteByUuids(DbSession dbSession, Collection<String> profileUuids) { + QualityProfileMapper mapper = mapper(dbSession); + DatabaseUtils.executeLargeUpdates(profileUuids, mapper::deleteOrgQProfilesByUuids); + DatabaseUtils.executeLargeUpdates(profileUuids, mapper::deleteRulesProfilesByUuids); + } + private static String sqlQueryString(@Nullable String query) { if (query == null) { return "%"; @@ -201,9 +210,4 @@ public class QualityProfileDao implements Dao { private static QualityProfileMapper mapper(DbSession session) { return session.getMapper(QualityProfileMapper.class); } - - public void deleteByKeys(DbSession dbSession, Collection<String> profileKeys) { - QualityProfileMapper mapper = mapper(dbSession); - DatabaseUtils.executeLargeUpdates(profileKeys, mapper::deleteByKeys); - } } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileMapper.java index 9a514215385..cf289bc2ce9 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileMapper.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/qualityprofile/QualityProfileMapper.java @@ -28,51 +28,62 @@ import org.sonar.db.KeyLongValue; public interface QualityProfileMapper { - void insert(@Param("dto") RulesProfileDto dto, @Param("now") Date now); + void insertOrgQProfile(@Param("dto") QProfileDto dto, @Param("now") long now); - void update(@Param("dto") RulesProfileDto dto, @Param("now") Date now); + void insertRulesProfile(@Param("dto") QProfileDto dto, @Param("now") Date now); - void deleteByKeys(@Param("profileKeys") Collection<String> profileKeys); + void updateRulesProfile(@Param("dto") QProfileDto dto, @Param("now") Date now); - List<RulesProfileDto> selectAll(@Param("organizationUuid") String organizationUuid); + void updateOrgQProfile(@Param("dto") QProfileDto dto, @Param("now") long now); + + void deleteRulesProfilesByUuids(@Param("uuids") Collection<String> uuids); + + void deleteOrgQProfilesByUuids(@Param("uuids") Collection<String> uuids); + + List<QProfileDto> selectAll(@Param("organizationUuid") String organizationUuid); @CheckForNull - RulesProfileDto selectDefaultProfile(@Param("organizationUuid") String organizationUuid, @Param("language") String language); + QProfileDto selectDefaultProfile(@Param("organizationUuid") String organizationUuid, @Param("language") String language); - List<RulesProfileDto> selectDefaultProfiles( + List<QProfileDto> selectDefaultProfiles( @Param("organizationUuid") String organizationUuid, @Param("languages") Collection<String> languages); @CheckForNull - RulesProfileDto selectByNameAndLanguage(@Param("organizationUuid") String organizationUuid, @Param("name") String name, @Param("language") String language); + QProfileDto selectByNameAndLanguage( + @Param("organizationUuid") String organizationUuid, + @Param("name") String name, + @Param("language") String language); - List<RulesProfileDto> selectByNameAndLanguages( + List<QProfileDto> selectByNameAndLanguages( @Param("organizationUuid") String organizationUuid, @Param("name") String name, @Param("languages") Collection<String> languages); @CheckForNull - RulesProfileDto selectByKey(String key); + QProfileDto selectByUuid(String uuid); - List<RulesProfileDto> selectByLanguage(@Param("organizationUuid") String organizationUuid, @Param("language") String language); + List<QProfileDto> selectByUuids(@Param("uuids") Collection<String> uuids); - List<RulesProfileDto> selectByKeys(@Param("keys") List<String> keys); + List<QProfileDto> selectByLanguage( + @Param("organizationUuid") String organizationUuid, + @Param("language") String language); // INHERITANCE - List<RulesProfileDto> selectChildren(String key); + List<QProfileDto> selectChildren(String uuid); // PROJECTS - List<KeyLongValue> countProjectsByProfileKey(@Param("organizationUuid") String organizationUuid); + List<KeyLongValue> countProjectsByProfileUuid(@Param("organizationUuid") String organizationUuid); @CheckForNull - RulesProfileDto selectAssociatedToProjectUuidAndLanguage( + QProfileDto selectAssociatedToProjectUuidAndLanguage( @Param("organizationUuid") String organizationUuid, @Param("projectUuid") String projectUuid, @Param("language") String language); - List<RulesProfileDto> selectAssociatedToProjectUuidAndLanguages( + List<QProfileDto> selectAssociatedToProjectUuidAndLanguages( @Param("organizationUuid") String organizationUuid, @Param("projectUuid") String projectUuid, @Param("languages") Collection<String> languages); @@ -86,26 +97,26 @@ public interface QualityProfileMapper { @Param("profileUuid") String profileUuid, @Param("oldProfileUuid") String oldProfileUuid); - void deleteProjectProfileAssociation(@Param("projectUuid") String projectUuid, @Param("profileKey") String profileKey); + void deleteProjectProfileAssociation(@Param("projectUuid") String projectUuid, @Param("profileUuid") String profileUuid); - void deleteProjectAssociationByProfileKeys(@Param("profileKeys") Collection<String> profileKeys); + void deleteProjectAssociationByProfileUuids(@Param("profileUuids") Collection<String> profileUuids); List<ProjectQprofileAssociationDto> selectSelectedProjects( @Param("organizationUuid") String organizationUuid, - @Param("profileKey") String profileKey, + @Param("profileUuid") String profileUuid, @Param("nameQuery") String nameQuery); List<ProjectQprofileAssociationDto> selectDeselectedProjects( @Param("organizationUuid") String organizationUuid, - @Param("profileKey") String profileKey, + @Param("profileUuid") String profileUuid, @Param("nameQuery") String nameQuery); List<ProjectQprofileAssociationDto> selectProjectAssociations( @Param("organizationUuid") String organizationUuid, - @Param("profileKey") String profileKey, + @Param("profileUuid") String profileUuid, @Param("nameQuery") String nameQuery); - List<String> selectOutdatedProfiles(@Param("language") String language, @Param("name") String name); + List<String> selectUuidsOfCustomQProfiles(@Param("language") String language, @Param("name") String name); - void rename(@Param("newName") String newName, @Param("updatedAt") Date updatedAt, @Param("profileKeys") Collection<String> profileKeys); + void renameRulesProfiles(@Param("newName") String newName, @Param("updatedAt") Date updatedAt, @Param("uuids") Collection<String> uuids); } diff --git a/server/sonar-db-dao/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml b/server/sonar-db-dao/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml index feacf5db7a3..5d80727e51e 100644 --- a/server/sonar-db-dao/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml +++ b/server/sonar-db-dao/src/main/resources/org/sonar/db/organization/OrganizationMapper.xml @@ -135,7 +135,8 @@ from organizations org where not exists ( select 1 from rules_profiles p - where p.organization_uuid = org.uuid + inner join org_qprofiles oqp on oqp.rules_profile_uuid = p.kee + where oqp.organization_uuid = org.uuid and p.language = #{profileLanguage, jdbcType=VARCHAR} and p.name = #{profileName, jdbcType=VARCHAR} ) diff --git a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/ActiveRuleMapper.xml b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/ActiveRuleMapper.xml index 463c29de8ac..51d24aaf0f5 100644 --- a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/ActiveRuleMapper.xml +++ b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/ActiveRuleMapper.xml @@ -17,8 +17,9 @@ </sql> <sql id="activeRuleKeyJoin"> - INNER JOIN rules_profiles qp ON qp.id=a.profile_id - INNER JOIN rules r ON r.id = a.rule_id + inner join rules_profiles qp on qp.id=a.profile_id + inner join org_qprofiles oqp on oqp.rules_profile_uuid = qp.kee + inner join rules r on r.id = a.rule_id </sql> <insert id="insert" parameterType="ActiveRule" keyColumn="id" useGeneratedKeys="true" keyProperty="id"> @@ -88,7 +89,7 @@ FROM active_rules a <include refid="activeRuleKeyJoin"/> WHERE a.rule_id=#{ruleId, jdbcType=BIGINT} - AND qp.organization_uuid=#{organizationUuid, jdbcType=VARCHAR} + AND oqp.organization_uuid=#{organizationUuid, jdbcType=VARCHAR} </select> <select id="selectByRuleIdOfAllOrganizations" parameterType="Integer" resultType="ActiveRule"> @@ -109,7 +110,7 @@ <foreach collection="ruleIds" item="ruleId" separator="," open="(" close=")"> #{ruleId} </foreach> - AND qp.organization_uuid=#{organizationUuid, jdbcType=VARCHAR} + AND oqp.organization_uuid=#{organizationUuid, jdbcType=VARCHAR} </select> <!-- Parameters --> @@ -191,34 +192,37 @@ </select> <select id="countActiveRulesByProfileKey" resultType="KeyLongValue" parameterType="map"> - select p.kee as "key", count(ar.id) as "value" + select rp.kee as "key", count(ar.id) as "value" from active_rules ar - inner join rules_profiles p on p.id = ar.profile_id + inner join rules_profiles rp on rp.id = ar.profile_id + inner join org_qprofiles oqp on oqp.rules_profile_uuid = rp.kee inner join rules r on r.id = ar.rule_id - where p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + where oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} and r.status != 'REMOVED' - group by p.kee + group by rp.kee </select> <select id="countActiveRulesForRuleStatusByProfileKey" resultType="KeyLongValue" parameterType="map"> - select p.kee as "key", count(ar.id) as "value" + select rp.kee as "key", count(ar.id) as "value" from active_rules ar - inner join rules_profiles p on p.id = ar.profile_id + inner join rules_profiles rp on rp.id = ar.profile_id + inner join org_qprofiles oqp on oqp.rules_profile_uuid = rp.kee inner join rules r on r.id = ar.rule_id - where p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + where oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} and r.status = #{ruleStatus, jdbcType=VARCHAR} - group by p.kee + group by rp.kee </select> <select id="countActiveRulesForInheritanceByProfileKey" resultType="KeyLongValue" parameterType="map"> - select p.kee as "key", count(ar.id) as "value" + select rp.kee as "key", count(ar.id) as "value" from active_rules ar - inner join rules_profiles p on p.id = ar.profile_id + inner join rules_profiles rp on rp.id = ar.profile_id + inner join org_qprofiles oqp on oqp.rules_profile_uuid = rp.kee inner join rules r on r.id = ar.rule_id - where p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + where oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} and ar.inheritance = #{inheritance, jdbcType=VARCHAR} and r.status != 'REMOVED' - group by p.kee + group by rp.kee </select> </mapper> diff --git a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QProfileChangeMapper.xml b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QProfileChangeMapper.xml index 728614064df..ddd345a3f32 100644 --- a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QProfileChangeMapper.xml +++ b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QProfileChangeMapper.xml @@ -22,9 +22,9 @@ ) </insert> - <select id="countForProfileKey" resultType="int"> + <select id="countForProfileUuid" resultType="int"> select count(kee) from qprofile_changes - where qprofile_key = #{profileKey} + where qprofile_key = #{profileUuid, jdbcType=VARCHAR} </select> <select id="selectByQuery" resultType="org.sonar.db.qualityprofile.QProfileChangeDto"> @@ -61,7 +61,7 @@ <sql id="sqlSelectByQuery"> select <include refid="sqlColumns" /> from qprofile_changes - where qprofile_key = #{query.profileKey} + where qprofile_key = #{query.profileUuid, jdbcType=VARCHAR} <if test="query.fromIncluded != null"> and created_at >= #{query.fromIncluded} </if> @@ -71,11 +71,11 @@ order by created_at desc </sql> - <delete id="deleteByProfileKeys" parameterType="String"> + <delete id="deleteByProfileUuids" parameterType="String"> delete from qprofile_changes where qprofile_key in - <foreach collection="profileKeys" open="(" close=")" item="profileKey" separator=","> - #{profileKey, jdbcType=VARCHAR} + <foreach collection="profileUuids" open="(" close=")" item="profileUuid" separator=","> + #{profileUuid, jdbcType=VARCHAR} </foreach> </delete> </mapper> diff --git a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QualityProfileMapper.xml b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QualityProfileMapper.xml index 3eeb5f676ff..fdd6f3224b1 100644 --- a/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QualityProfileMapper.xml +++ b/server/sonar-db-dao/src/main/resources/org/sonar/db/qualityprofile/QualityProfileMapper.xml @@ -3,201 +3,226 @@ <mapper namespace="org.sonar.db.qualityprofile.QualityProfileMapper"> - <sql id="profilesColumns"> - p.id as id, - p.organization_uuid as organizationUuid, - p.kee as kee, - p.name as name, - p.language as language, - p.parent_kee as parentKee, - p.rules_updated_at as rulesUpdatedAt, - p.last_used as lastUsed, - p.user_updated_at as userUpdatedAt, - p.is_built_in as isBuiltIn + <sql id="qProfileColumns"> + oqp.uuid as kee, + oqp.organization_uuid as organizationUuid, + oqp.parent_uuid as parentKee, + rp.id as id, + rp.name as name, + rp.language as language, + rp.rules_updated_at as rulesUpdatedAt, + rp.last_used as lastUsed, + rp.user_updated_at as userUpdatedAt, + rp.is_built_in as isBuiltIn </sql> - <insert id="insert" parameterType="map" keyColumn="id" useGeneratedKeys="true" keyProperty="dto.id"> - INSERT INTO rules_profiles (organization_uuid, kee, parent_kee, name, language, created_at, updated_at, rules_updated_at, last_used, user_updated_at, is_built_in) - VALUES ( - #{dto.organizationUuid, jdbcType=VARCHAR}, - #{dto.kee, jdbcType=VARCHAR}, - #{dto.parentKee, jdbcType=VARCHAR}, - #{dto.name, jdbcType=VARCHAR}, - #{dto.language, jdbcType=VARCHAR}, - #{now, jdbcType=TIMESTAMP}, - #{now, jdbcType=TIMESTAMP}, - #{dto.rulesUpdatedAt, jdbcType=VARCHAR}, - #{dto.lastUsed, jdbcType=BIGINT}, - #{dto.userUpdatedAt, jdbcType=BIGINT}, - #{dto.isBuiltIn, jdbcType=BOOLEAN} + <insert id="insertRulesProfile" parameterType="map" keyColumn="id" useGeneratedKeys="true" keyProperty="dto.id"> + insert into rules_profiles ( + kee, + name, + language, + created_at, + updated_at, + rules_updated_at, + last_used, + user_updated_at, + is_built_in + ) values ( + #{dto.kee, jdbcType=VARCHAR}, + #{dto.name, jdbcType=VARCHAR}, + #{dto.language, jdbcType=VARCHAR}, + #{now, jdbcType=TIMESTAMP}, + #{now, jdbcType=TIMESTAMP}, + #{dto.rulesUpdatedAt, jdbcType=VARCHAR}, + #{dto.lastUsed, jdbcType=BIGINT}, + #{dto.userUpdatedAt, jdbcType=BIGINT}, + #{dto.isBuiltIn, jdbcType=BOOLEAN} + ) + </insert> + + <insert id="insertOrgQProfile" parameterType="map" useGeneratedKeys="false"> + insert into org_qprofiles ( + uuid, + organization_uuid, + rules_profile_uuid, + parent_uuid, + created_at, + updated_at + ) values ( + #{dto.kee, jdbcType=VARCHAR}, + #{dto.organizationUuid, jdbcType=VARCHAR}, + #{dto.kee, jdbcType=VARCHAR}, + #{dto.parentKee, jdbcType=VARCHAR}, + #{now, jdbcType=BIGINT}, + #{now, jdbcType=BIGINT} ) </insert> - <update id="update" parameterType="map"> - UPDATE rules_profiles SET - name=#{dto.name, jdbcType=VARCHAR}, - language=#{dto.language, jdbcType=VARCHAR}, - parent_kee=#{dto.parentKee, jdbcType=VARCHAR}, - updated_at=#{now, jdbcType=TIMESTAMP}, - rules_updated_at=#{dto.rulesUpdatedAt, jdbcType=VARCHAR}, - last_used=#{dto.lastUsed, jdbcType=BIGINT}, - user_updated_at=#{dto.userUpdatedAt, jdbcType=BIGINT}, - is_built_in=#{dto.isBuiltIn, jdbcType=BOOLEAN} - WHERE id=#{dto.id} + <update id="updateRulesProfile" parameterType="map"> + update rules_profiles + set + name = #{dto.name, jdbcType=VARCHAR}, + language = #{dto.language, jdbcType=VARCHAR}, + updated_at = #{now, jdbcType=TIMESTAMP}, + rules_updated_at = #{dto.rulesUpdatedAt, jdbcType=VARCHAR}, + last_used = #{dto.lastUsed, jdbcType=BIGINT}, + user_updated_at = #{dto.userUpdatedAt, jdbcType=BIGINT}, + is_built_in = #{dto.isBuiltIn, jdbcType=BOOLEAN} + where + kee = #{dto.kee, jdbcType=VARCHAR} + </update> + + <update id="updateOrgQProfile" parameterType="map"> + update org_qprofiles + set + parent_uuid = #{dto.parentKee, jdbcType=VARCHAR}, + updated_at = #{now, jdbcType=BIGINT} + where + uuid = #{dto.kee, jdbcType=VARCHAR} </update> - <update id="deleteByKeys" parameterType="String"> + <delete id="deleteRulesProfilesByUuids" parameterType="String"> delete from rules_profiles where kee in - <foreach collection="profileKeys" open="(" close=")" item="profileKey" separator=",">#{profileKey, jdbcType=VARCHAR}</foreach> - </update> + <foreach collection="uuids" open="(" close=")" item="uuid" separator=",">#{uuid, jdbcType=VARCHAR}</foreach> + </delete> - <select id="selectAll" parameterType="map" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.organization_uuid = #{organizationUuid,jdbcType=VARCHAR} - ORDER BY p.name, p.language - </select> - - <select id="selectByNameAndLanguage" parameterType="map" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.name=#{name, jdbcType=VARCHAR} - AND p.language=#{language, jdbcType=VARCHAR} - <if test="organizationUuid != null"> - AND p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - </if> - </select> - - <select id="selectByNameAndLanguages" parameterType="map" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.name=#{name, jdbcType=VARCHAR} - AND p.language IN <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> - AND p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - </select> - - <select id="selectByKey" parameterType="string" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.kee=#{id} - </select> - - <select id="selectByKeys" parameterType="string" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.kee in - <foreach collection="keys" open="(" close=")" item="key" separator=","> - #{key} - </foreach> + <delete id="deleteOrgQProfilesByUuids" parameterType="String"> + delete from org_qprofiles + where uuid in + <foreach collection="uuids" open="(" close=")" item="uuid" separator=",">#{uuid, jdbcType=VARCHAR}</foreach> + </delete> + + <select id="selectAll" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + oqp.organization_uuid = #{organizationUuid,jdbcType=VARCHAR} + order by rp.name, rp.language </select> - <select id="selectByLanguage" parameterType="String" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.language=#{language} - AND p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - ORDER BY p.name + <select id="selectDefaultProfile" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + inner join default_qprofiles dp on dp.qprofile_uuid = oqp.uuid + where + dp.language = #{language, jdbcType=VARCHAR} + and dp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + and rp.language = dp.language + and oqp.organization_uuid = dp.organization_uuid </select> - <select id="selectChildren" parameterType="string" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - WHERE p.parent_kee=#{id} - ORDER BY p.name + <select id="selectDefaultProfiles" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + inner join default_qprofiles dp on dp.qprofile_uuid = oqp.uuid + where + dp.language in <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> + and dp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + and rp.language = dp.language + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} </select> - <select id="selectDefaultProfile" parameterType="map" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - INNER JOIN default_qprofiles dp on p.kee=dp.qprofile_uuid - WHERE - dp.language=#{language, jdbcType=VARCHAR} - AND dp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + <select id="selectByNameAndLanguage" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + rp.name = #{name, jdbcType=VARCHAR} + and rp.language = #{language, jdbcType=VARCHAR} + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + </select> + + <select id="selectByNameAndLanguages" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + rp.name = #{name, jdbcType=VARCHAR} + and rp.language in <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} </select> - <select id="selectDefaultProfiles" parameterType="map" resultType="RulesProfile"> - SELECT - <include refid="profilesColumns"/> - FROM rules_profiles p - INNER JOIN default_qprofiles dp on p.kee=dp.qprofile_uuid - WHERE - dp.language in <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> - AND dp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + <select id="selectByUuid" parameterType="string" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + oqp.uuid = #{uuid, jdbcType=VARCHAR} </select> - <select id="selectSelectedProjects" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> - SELECT pp.id as id, pj.id as projectId, pj.uuid as projectUuid, pj.kee as projectKey, pj.name as projectName, pp.profile_key as profileKey - FROM projects pj - JOIN project_qprofiles pp ON pp.project_uuid = pj.uuid - AND pp.profile_key = #{profileKey, jdbcType=VARCHAR} - WHERE pj.scope='PRJ' AND pj.qualifier='TRK' - AND UPPER(pj.name) LIKE #{nameQuery, jdbcType=VARCHAR} - AND pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - ORDER BY pj.name ASC + <select id="selectByUuids" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + oqp.uuid in <foreach collection="uuids" open="(" close=")" item="uuid" separator=",">#{uuid}</foreach> </select> - <select id="selectDeselectedProjects" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> - SELECT pp.id as id, pj.id as projectId, pj.uuid as projectUuid, pj.kee as projectKey, pj.name as projectName, pp.profile_key as profileKey - FROM projects pj - LEFT JOIN project_qprofiles pp ON pp.project_uuid = pj.uuid - AND pp.profile_key = #{profileKey, jdbcType=VARCHAR} - WHERE pj.scope='PRJ' AND pj.qualifier='TRK' - AND UPPER(pj.name) LIKE #{nameQuery, jdbcType=VARCHAR} - AND pp.profile_key IS NULL - AND pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - ORDER BY pj.name ASC + <select id="selectByLanguage" parameterType="String" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + rp.language = #{language, jdbcType=VARCHAR} + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} </select> - <select id="selectProjectAssociations" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> - SELECT pp.id as id, pj.id as projectId, pj.uuid as projectUuid, pj.kee as projectKey, pj.name as projectName, pp.profile_key as profileKey - FROM projects pj - LEFT JOIN project_qprofiles pp ON pp.project_uuid = pj.uuid - AND pp.profile_key = #{profileKey, jdbcType=VARCHAR} - WHERE pj.scope='PRJ' AND pj.qualifier='TRK' - AND UPPER(pj.name) LIKE #{nameQuery, jdbcType=VARCHAR} - AND pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - ORDER BY pj.name ASC + <select id="selectChildren" parameterType="string" resultType="org.sonar.db.qualityprofile.QProfileDto"> + select + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + where + oqp.parent_uuid = #{uuid, jdbcType=VARCHAR} + ORDER BY rp.name </select> - <select id="countProjectsByProfileKey" resultType="KeyLongValue" parameterType="map"> - select pp.profile_key as "key", count(projects.id) as "value" - from projects projects - inner join project_qprofiles pp ON pp.project_uuid = projects.uuid - inner join rules_profiles prof ON pp.profile_key = prof.kee - where projects.enabled = ${_true} - and prof.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} - group by pp.profile_key + <select id="countProjectsByProfileUuid" resultType="KeyLongValue" parameterType="map"> + select pqp.profile_key as "key", count(pj.uuid) as "value" + from projects pj + inner join project_qprofiles pqp on pqp.project_uuid = pj.uuid + inner join org_qprofiles oqp on oqp.uuid = pqp.profile_key + where + pj.enabled = ${_true} + and pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + and oqp.organization_uuid = pj.organization_uuid + group by pqp.profile_key </select> - <select id="selectAssociatedToProjectUuidAndLanguage" parameterType="map" resultType="RulesProfile"> + <select id="selectAssociatedToProjectUuidAndLanguage" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> select - <include refid="profilesColumns"/> - from rules_profiles p - inner join project_qprofiles pp ON pp.profile_key = p.kee + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + inner join project_qprofiles pqp ON pqp.profile_key = oqp.uuid where - p.language = #{language, jdbcType=VARCHAR} - and pp.project_uuid = #{projectUuid, jdbcType=VARCHAR} - and p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + rp.language = #{language, jdbcType=VARCHAR} + and pqp.project_uuid = #{projectUuid, jdbcType=VARCHAR} + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} </select> - <select id="selectAssociatedToProjectUuidAndLanguages" parameterType="map" resultType="RulesProfile"> + <select id="selectAssociatedToProjectUuidAndLanguages" parameterType="map" resultType="org.sonar.db.qualityprofile.QProfileDto"> select - <include refid="profilesColumns"/> - from rules_profiles p - inner join project_qprofiles pq ON pq.profile_key = p.kee + <include refid="qProfileColumns"/> + from org_qprofiles oqp + inner join rules_profiles rp on oqp.rules_profile_uuid = rp.kee + inner join project_qprofiles pqp ON pqp.profile_key = oqp.uuid where - p.language in <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> - and pq.project_uuid = #{projectUuid, jdbcType=VARCHAR} - and p.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + rp.language in <foreach collection="languages" open="(" close=")" item="language" separator=",">#{language, jdbcType=VARCHAR}</foreach> + and pqp.project_uuid = #{projectUuid, jdbcType=VARCHAR} + and oqp.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} </select> <insert id="insertProjectProfileAssociation" useGeneratedKeys="false"> @@ -213,40 +238,86 @@ <update id="updateProjectProfileAssociation"> update project_qprofiles set - profile_key = #{profileUuid, jdbcType=VARCHAR} + profile_key = #{profileUuid, jdbcType=VARCHAR} where - project_uuid = #{projectUuid, jdbcType=VARCHAR} - and profile_key = #{oldProfileUuid, jdbcType=VARCHAR} + project_uuid = #{projectUuid, jdbcType=VARCHAR} + and profile_key = #{oldProfileUuid, jdbcType=VARCHAR} </update> - <update id="deleteProjectProfileAssociation"> - DELETE FROM project_qprofiles - WHERE project_uuid=#{projectUuid, jdbcType=VARCHAR} AND profile_key=#{profileKey, jdbcType=VARCHAR} - </update> + <delete id="deleteProjectProfileAssociation"> + delete from project_qprofiles + where + project_uuid = #{projectUuid, jdbcType=VARCHAR} + and profile_key=#{profileUuid, jdbcType=VARCHAR} + </delete> - <update id="deleteProjectAssociationByProfileKeys" parameterType="String"> + <delete id="deleteProjectAssociationByProfileUuids" parameterType="String"> delete from project_qprofiles where profile_key in - <foreach collection="profileKeys" open="(" close=")" item="profileKey" separator=","> - #{profileKey, jdbcType=VARCHAR} + <foreach collection="profileUuids" open="(" close=")" item="profileUuid" separator=","> + #{profileUuid, jdbcType=VARCHAR} </foreach> - </update> + </delete> + + <select id="selectSelectedProjects" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> + select + pp.id as id, + pj.id as projectId, + pj.uuid as projectUuid, + pj.kee as projectKey, + pj.name as projectName, + pp.profile_key as profileKey + from projects pj + inner join project_qprofiles pp ON pp.project_uuid = pj.uuid and pp.profile_key = #{profileUuid, jdbcType=VARCHAR} + where + pj.scope = 'PRJ' + and pj.qualifier = 'TRK' + and upper(pj.name) like #{nameQuery, jdbcType=VARCHAR} + and pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + order by pj.name ASC + </select> - <select id="selectOutdatedProfiles" parameterType="map" resultType="string"> - select rp.kee - from rules_profiles rp - inner join organizations o on o.uuid = rp.organization_uuid - where rp.language = #{language, jdbcType=VARCHAR} + <select id="selectDeselectedProjects" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> + SELECT pp.id as id, pj.id as projectId, pj.uuid as projectUuid, pj.kee as projectKey, pj.name as projectName, pp.profile_key as profileKey + FROM projects pj + LEFT JOIN project_qprofiles pp ON pp.project_uuid = pj.uuid + AND pp.profile_key = #{profileUuid, jdbcType=VARCHAR} + WHERE pj.scope='PRJ' AND pj.qualifier='TRK' + AND UPPER(pj.name) LIKE #{nameQuery, jdbcType=VARCHAR} + AND pp.profile_key IS NULL + AND pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + ORDER BY pj.name ASC + </select> + + <select id="selectProjectAssociations" resultType="org.sonar.db.qualityprofile.ProjectQprofileAssociationDto"> + SELECT pp.id as id, pj.id as projectId, pj.uuid as projectUuid, pj.kee as projectKey, pj.name as projectName, pp.profile_key as profileKey + FROM projects pj + LEFT JOIN project_qprofiles pp ON pp.project_uuid = pj.uuid + AND pp.profile_key = #{profileUuid, jdbcType=VARCHAR} + WHERE pj.scope='PRJ' AND pj.qualifier='TRK' + AND UPPER(pj.name) LIKE #{nameQuery, jdbcType=VARCHAR} + AND pj.organization_uuid = #{organizationUuid, jdbcType=VARCHAR} + ORDER BY pj.name ASC + </select> + + <select id="selectUuidsOfCustomQProfiles" parameterType="map" resultType="string"> + select oqp.uuid + from org_qprofiles oqp + inner join organizations o on o.uuid = oqp.organization_uuid + inner join rules_profiles rp on rp.kee = oqp.rules_profile_uuid + where + rp.language = #{language, jdbcType=VARCHAR} and rp.name = #{name, jdbcType=VARCHAR} and rp.is_built_in = ${_false} </select> - <update id="rename" parameterType="map"> + <update id="renameRulesProfiles" parameterType="map"> update rules_profiles set name = #{newName, jdbcType=VARCHAR}, updated_at = #{updatedAt, jdbcType=TIMESTAMP} - where kee in <foreach collection="profileKeys" open="(" close=")" item="profileKey" separator=",">#{profileKey, jdbcType=VARCHAR}</foreach> + where + kee in <foreach collection="uuids" open="(" close=")" item="uuid" separator=",">#{uuid, jdbcType=VARCHAR}</foreach> </update> </mapper> diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java b/server/sonar-db-dao/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java index 30d00d121e2..242975bd404 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/organization/OrganizationDaoTest.java @@ -41,7 +41,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.dialect.Dialect; import org.sonar.db.dialect.Oracle; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.user.GroupDto; import org.sonar.db.user.GroupTesting; import org.sonar.db.user.UserDto; @@ -877,7 +877,7 @@ public class OrganizationDaoTest { public void selectWithoutQualityProfile_returns_() { OrganizationDto orgWithoutAnyProfiles = dbTester.organizations().insert(); OrganizationDto orgWithProfiles = dbTester.organizations().insert(); - RulesProfileDto profile = dbTester.qualityProfiles().insert(orgWithProfiles); + QProfileDto profile = dbTester.qualityProfiles().insert(orgWithProfiles); assertThat(underTest.selectWithoutQualityProfile(dbSession, "js", "foo")) .extracting(OrganizationDto::getUuid).containsExactlyInAnyOrder(orgWithoutAnyProfiles.getUuid(), orgWithProfiles.getUuid()); diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/ActiveRuleDaoTest.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/ActiveRuleDaoTest.java index 35530c4abd4..bf03320b40a 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/ActiveRuleDaoTest.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/ActiveRuleDaoTest.java @@ -63,8 +63,8 @@ public class ActiveRuleDaoTest { private OrganizationDto organization = OrganizationTesting.newOrganizationDto(); - private RulesProfileDto profile1 = RulesProfileDto.createFor("qp1").setOrganizationUuid(organization.getUuid()).setName("QProfile1"); - private RulesProfileDto profile2 = RulesProfileDto.createFor("qp2").setOrganizationUuid(organization.getUuid()).setName("QProfile2"); + private QProfileDto profile1 = QProfileDto.createFor("qp1").setOrganizationUuid(organization.getUuid()).setName("QProfile1"); + private QProfileDto profile2 = QProfileDto.createFor("qp2").setOrganizationUuid(organization.getUuid()).setName("QProfile2"); private RuleDefinitionDto rule1 = RuleTesting.newRule(RuleTesting.XOO_X1); private RuleDefinitionDto rule2 = RuleTesting.newRule(RuleTesting.XOO_X2); @@ -334,7 +334,7 @@ public class ActiveRuleDaoTest { assertThat(dbTester.countRowsOfTable(dbSession, "active_rules")).isEqualTo(1); } - private static ActiveRuleDto newRow(RulesProfileDto profile, RuleDefinitionDto rule) { + private static ActiveRuleDto newRow(QProfileDto profile, RuleDefinitionDto rule) { return createFor(profile, rule).setSeverity(BLOCKER); } diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/DefaultQProfileDaoTest.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/DefaultQProfileDaoTest.java index f5800f52589..f317d828e08 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/DefaultQProfileDaoTest.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/DefaultQProfileDaoTest.java @@ -20,6 +20,7 @@ package org.sonar.db.qualityprofile; import java.util.List; +import java.util.Optional; import org.junit.Rule; import org.junit.Test; import org.sonar.api.utils.System2; @@ -42,7 +43,7 @@ public class DefaultQProfileDaoTest { @Test public void insertOrUpdate_inserts_row_when_does_not_exist() { OrganizationDto org = dbTester.organizations().insert(); - RulesProfileDto profile = dbTester.qualityProfiles().insert(org); + QProfileDto profile = dbTester.qualityProfiles().insert(org); DefaultQProfileDto dto = DefaultQProfileDto.from(profile); underTest.insertOrUpdate(dbSession, dto); @@ -69,7 +70,7 @@ public class DefaultQProfileDaoTest { dbSession.commit(); assertThat(countRows()).isEqualTo(1); - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org, dto.getLanguage())).hasValue(newQProfileUuid); + assertThat(selectUuidOfDefaultProfile(org, dto.getLanguage())).hasValue(newQProfileUuid); } @Test @@ -85,18 +86,18 @@ public class DefaultQProfileDaoTest { dbSession.commit(); assertThat(countRows()).isEqualTo(2); - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org1, "java")).isEmpty(); - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org1, "js")).hasValue("u2"); - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org2, "java")).isEmpty(); - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org2, "js")).hasValue("u4"); + assertThat(selectUuidOfDefaultProfile(org1, "java")).isEmpty(); + assertThat(selectUuidOfDefaultProfile(org1, "js")).hasValue("u2"); + assertThat(selectUuidOfDefaultProfile(org2, "java")).isEmpty(); + assertThat(selectUuidOfDefaultProfile(org2, "js")).hasValue("u4"); } @Test public void selectExistingQProfileUuids_filters_defaults() { OrganizationDto org = dbTester.organizations().insert(); - RulesProfileDto profile1 = dbTester.qualityProfiles().insert(org); - RulesProfileDto profile2 = dbTester.qualityProfiles().insert(org); - dbTester.qualityProfiles().markAsDefault(profile1); + QProfileDto profile1 = dbTester.qualityProfiles().insert(org); + QProfileDto profile2 = dbTester.qualityProfiles().insert(org); + dbTester.qualityProfiles().setAsDefault(profile1); List<String> profileUuids = asList(profile1.getKee(), profile2.getKee(), "other"); assertThat(underTest.selectExistingQProfileUuids(dbSession, org.getUuid(), profileUuids)) @@ -106,21 +107,30 @@ public class DefaultQProfileDaoTest { @Test public void isDefault_returns_true_if_profile_is_marked_as_default() { OrganizationDto org = dbTester.organizations().insert(); - RulesProfileDto profile1 = dbTester.qualityProfiles().insert(org); - RulesProfileDto profile2 = dbTester.qualityProfiles().insert(org); - dbTester.qualityProfiles().markAsDefault(profile1); + QProfileDto profile1 = dbTester.qualityProfiles().insert(org); + QProfileDto profile2 = dbTester.qualityProfiles().insert(org); + dbTester.qualityProfiles().setAsDefault(profile1); assertThat(underTest.isDefault(dbSession, org.getUuid(), profile1.getKee())).isTrue(); assertThat(underTest.isDefault(dbSession, org.getUuid(), profile2.getKee())).isFalse(); assertThat(underTest.isDefault(dbSession, org.getUuid(), "does_not_exist")).isFalse(); } - private void assertThatIsDefault(OrganizationDto org, RulesProfileDto profile) { - assertThat(dbTester.qualityProfiles().selectUuidOfDefaultProfile(org, profile.getLanguage())).hasValue(profile.getKee()); + private void assertThatIsDefault(OrganizationDto org, QProfileDto profile) { + assertThat(selectUuidOfDefaultProfile(org, profile.getLanguage())).hasValue(profile.getKee()); assertThat(underTest.isDefault(dbSession, org.getUuid(), profile.getKee())).isTrue(); } private int countRows() { return dbTester.countRowsOfTable("default_qprofiles"); } + + private Optional<String> selectUuidOfDefaultProfile(OrganizationDto org, String language) { + return dbTester.select("select qprofile_uuid as \"profileUuid\" " + + " from default_qprofiles " + + " where organization_uuid='" + org.getUuid() + "' and language='" + language + "'") + .stream() + .findFirst() + .map(m -> (String) m.get("profileUuid")); + } } diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QProfileChangeDaoTest.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QProfileChangeDaoTest.java index 6ecb82cebc4..be9bf0496de 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QProfileChangeDaoTest.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QProfileChangeDaoTest.java @@ -89,14 +89,6 @@ public class QProfileChangeDaoTest { } @Test - public void insert_throws_ISE_if_key_is_already_set() { - expectedException.expect(IllegalStateException.class); - expectedException.expectMessage("Key of QProfileChangeDto must be set by DAO only. Got C1."); - - underTest.insert(dbSession, new QProfileChangeDto().setKey("C1")); - } - - @Test public void insert_throws_ISE_if_date_is_already_set() { expectedException.expect(IllegalStateException.class); expectedException.expectMessage("Date of QProfileChangeDto must be set by DAO only. Got 123."); @@ -211,8 +203,8 @@ public class QProfileChangeDaoTest { insertChange("P1", "ACTIVATED", null, null);// key: C1 insertChange("P1", "ACTIVATED", null, null);// key: C2 - assertThat(underTest.countForProfileKey(dbSession, "P1")).isEqualTo(2); - assertThat(underTest.countForProfileKey(dbSession, "P2")).isEqualTo(0); + assertThat(underTest.countForProfileUuid(dbSession, "P1")).isEqualTo(2); + assertThat(underTest.countForProfileUuid(dbSession, "P2")).isEqualTo(0); } @Test @@ -224,8 +216,8 @@ public class QProfileChangeDaoTest { underTest.deleteByProfileKeys(dbSession, asList("P1")); - assertThat(underTest.countForProfileKey(dbSession, "P1")).isEqualTo(0); - assertThat(underTest.countForProfileKey(dbSession, "P2")).isEqualTo(1); + assertThat(underTest.countForProfileUuid(dbSession, "P1")).isEqualTo(0); + assertThat(underTest.countForProfileUuid(dbSession, "P2")).isEqualTo(1); } @Test @@ -235,7 +227,7 @@ public class QProfileChangeDaoTest { underTest.deleteByProfileKeys(dbSession, asList("does_not_exist")); - assertThat(underTest.countForProfileKey(dbSession, "P1")).isEqualTo(1); + assertThat(underTest.countForProfileUuid(dbSession, "P1")).isEqualTo(1); } private void insertChange(String profileKey, String type, @Nullable String login, @Nullable String data) { diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDaoTest.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDaoTest.java index c6332f53d86..f2f2e8f9d56 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDaoTest.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDaoTest.java @@ -19,10 +19,12 @@ */ package org.sonar.db.qualityprofile; +import java.util.Arrays; import java.util.Collection; import java.util.Collections; import java.util.List; import java.util.Map; +import java.util.stream.IntStream; import org.assertj.core.data.MapEntry; import org.junit.After; import org.junit.Before; @@ -55,7 +57,6 @@ public class QualityProfileDaoTest { public DbTester dbTester = DbTester.create(system); private DbSession dbSession = dbTester.getSession(); - private QualityProfileDbTester qualityProfileDb = new QualityProfileDbTester(dbTester); private QualityProfileDao underTest = dbTester.getDbClient().qualityProfileDao(); private OrganizationDto organization; @@ -66,90 +67,109 @@ public class QualityProfileDaoTest { } @After - public void tearDown() { - // minor optimization, no need to commit pending operations + public void deleteData() { dbSession.rollback(); } @Test - public void insert() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); - - RulesProfileDto dto = RulesProfileDto.createFor("abcde") + public void test_insert() { + QProfileDto dto = QProfileDto.createFor("theUuid") .setOrganizationUuid(organization.getUuid()) - .setName("ABCDE") - .setLanguage("xoo") + .setName("theName") + .setLanguage("theLang") + .setLastUsed(1_000L) + .setParentKee("theParentUuid") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") .setIsBuiltIn(true); - underTest.insert(dbTester.getSession(), dto); - dbTester.commit(); + underTest.insert(dbSession, dto); - dbTester.assertDbUnit(getClass(), "insert-result.xml", new String[] {"created_at", "updated_at", "rules_updated_at"}, "rules_profiles"); + QProfileDto reloaded = underTest.selectByUuid(dbSession, dto.getKee()); + assertThat(reloaded.getKee()).isEqualTo(dto.getKee()); + assertThat(reloaded.getId()).isNotNull().isNotZero(); + assertThat(reloaded.getLanguage()).isEqualTo(dto.getLanguage()); + assertThat(reloaded.getName()).isEqualTo(dto.getName()); + assertThat(reloaded.getLastUsed()).isEqualTo(dto.getLastUsed()); + assertThat(reloaded.getRulesUpdatedAt()).isEqualTo(dto.getRulesUpdatedAt()); + assertThat(reloaded.getParentKee()).isEqualTo(dto.getParentKee()); + assertThat(reloaded.getOrganizationUuid()).isEqualTo(dto.getOrganizationUuid()); + assertThat(reloaded.isBuiltIn()).isEqualTo(dto.isBuiltIn()); } @Test - public void update() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); - - RulesProfileDto dto = RulesProfileDto.createFor("key") - .setId(1) + public void test_update() { + QProfileDto initial = QProfileDto.createFor("theUuid") .setOrganizationUuid(organization.getUuid()) - .setName("New Name") - .setLanguage("js") - .setParentKee("fghij") - .setIsBuiltIn(false); - - underTest.update(dbSession, dto); - dbSession.commit(); - - dbTester.assertDbUnit(getClass(), "update-result.xml", new String[] {"created_at", "updated_at", "rules_updated_at"}, "rules_profiles"); + .setName("theName") + .setLanguage("theLang") + .setLastUsed(1_000L) + .setParentKee("theParentUuid") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(true); + underTest.insert(dbSession, initial); + + QProfileDto update = QProfileDto.createFor(initial.getKee()) + .setName("theNewName") + .setLanguage("theNewLang") + .setLastUsed(11_000L) + .setParentKee("theNewParentUuid") + .setUserUpdatedAt(12_000L) + .setRulesUpdatedAt("2017-06-01") + .setIsBuiltIn(false) + + // field that cannot be changed + .setOrganizationUuid("theNewOrg"); + underTest.update(dbSession, update); + + QProfileDto reloaded = underTest.selectByUuid(dbSession, initial.getKee()); + assertThat(reloaded.getKee()).isEqualTo(initial.getKee()); + assertThat(reloaded.getOrganizationUuid()).isEqualTo(initial.getOrganizationUuid()); + + // updated fields + assertThat(reloaded.getLanguage()).isEqualTo(update.getLanguage()); + assertThat(reloaded.getName()).isEqualTo(update.getName()); + assertThat(reloaded.getLastUsed()).isEqualTo(update.getLastUsed()); + assertThat(reloaded.getRulesUpdatedAt()).isEqualTo(update.getRulesUpdatedAt()); + assertThat(reloaded.getParentKee()).isEqualTo(update.getParentKee()); + assertThat(reloaded.isBuiltIn()).isEqualTo(update.isBuiltIn()); } @Test - public void test_deleteByKeys() { - RulesProfileDto p1 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); - RulesProfileDto p2 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); - RulesProfileDto p3 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); + public void test_deleteByUuids() { + QProfileDto p1 = dbTester.qualityProfiles().insert(organization); + QProfileDto p2 = dbTester.qualityProfiles().insert(organization); + QProfileDto p3 = dbTester.qualityProfiles().insert(organization); - underTest.deleteByKeys(dbSession, asList(p1.getKee(), p3.getKee(), "does_not_exist")); + underTest.deleteByUuids(dbSession, asList(p1.getKee(), p3.getKee(), "does_not_exist")); - List<Map<String, Object>> keysInDb = dbTester.select(dbSession, "select kee as \"key\" from rules_profiles"); - assertThat(keysInDb).hasSize(1); - assertThat(keysInDb.get(0).get("key")).isEqualTo(p2.getKee()); + List<QProfileDto> profiles = underTest.selectAll(dbSession, organization); + assertThat(profiles).extracting(QProfileDto::getKee).containsExactly(p2.getKee()); } @Test - public void deleteByKeys_does_nothing_if_empty_keys() { - RulesProfileDto p1 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); + public void deleteByUuids_does_nothing_if_empty_uuids() { + dbTester.qualityProfiles().insert(organization); - underTest.deleteByKeys(dbSession, Collections.emptyList()); + underTest.deleteByUuids(dbSession, Collections.emptyList()); assertThat(dbTester.countRowsOfTable(dbSession, "rules_profiles")).isEqualTo(1); + assertThat(dbTester.countRowsOfTable(dbSession, "org_qprofiles")).isEqualTo(1); } @Test - public void deleteProjectAssociationsByProfileKeys_does_nothing_if_empty_keys() { - RulesProfileDto profile1 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); - ComponentDto project1 = dbTester.components().insertPrivateProject(); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project1, profile1); - - underTest.deleteProjectAssociationsByProfileKeys(dbSession, Collections.emptyList()); - - assertThat(dbTester.countRowsOfTable(dbSession, "project_qprofiles")).isEqualTo(1); - } + public void test_deleteProjectAssociationsByProfileUuids() { + QProfileDto profile1 = dbTester.qualityProfiles().insert(organization); + QProfileDto profile2 = dbTester.qualityProfiles().insert(organization); + ComponentDto project1 = dbTester.components().insertPrivateProject(organization); + ComponentDto project2 = dbTester.components().insertPrivateProject(organization); + ComponentDto project3 = dbTester.components().insertPrivateProject(organization); + dbTester.qualityProfiles().associateWithProject(project1, profile1); + dbTester.qualityProfiles().associateWithProject(project2, profile1); + dbTester.qualityProfiles().associateWithProject(project3, profile2); - @Test - public void deleteProjectAssociationsByProfileKeys_deletes_rows_from_table_project_profiles() { - RulesProfileDto profile1 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); - RulesProfileDto profile2 = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); - ComponentDto project1 = dbTester.components().insertPrivateProject(); - ComponentDto project2 = dbTester.components().insertPrivateProject(); - ComponentDto project3 = dbTester.components().insertPrivateProject(); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project1, profile1); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project2, profile1); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project3, profile2); - - underTest.deleteProjectAssociationsByProfileKeys(dbSession, asList(profile1.getKee(), "does_not_exist")); + underTest.deleteProjectAssociationsByProfileUuids(dbSession, asList(profile1.getKee(), "does_not_exist")); List<Map<String, Object>> rows = dbTester.select(dbSession, "select project_uuid as \"projectUuid\", profile_key as \"profileKey\" from project_qprofiles"); assertThat(rows).hasSize(1); @@ -158,103 +178,148 @@ public class QualityProfileDaoTest { } @Test - public void find_all() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); + public void deleteProjectAssociationsByProfileUuids_does_nothing_if_empty_uuids() { + QProfileDto profile = dbTester.qualityProfiles().insert(organization); + ComponentDto project = dbTester.components().insertPrivateProject(); + dbTester.qualityProfiles().associateWithProject(project, profile); - List<RulesProfileDto> dtos = underTest.selectAll(dbTester.getSession(), organization); + underTest.deleteProjectAssociationsByProfileUuids(dbSession, Collections.emptyList()); - assertThat(dtos).hasSize(2); + assertThat(dbTester.countRowsOfTable(dbSession, "project_qprofiles")).isEqualTo(1); + } - RulesProfileDto dto1 = dtos.get(0); - assertThat(dto1.getId()).isEqualTo(1); - assertThat(dto1.getName()).isEqualTo("Sonar Way"); - assertThat(dto1.getLanguage()).isEqualTo("java"); - assertThat(dto1.getParentKee()).isNull(); - assertThat(dto1.isBuiltIn()).isTrue(); - - RulesProfileDto dto2 = dtos.get(1); - assertThat(dto2.getId()).isEqualTo(2); - assertThat(dto2.getName()).isEqualTo("Sonar Way"); - assertThat(dto2.getLanguage()).isEqualTo("js"); - assertThat(dto2.getParentKee()).isNull(); - assertThat(dto2.isBuiltIn()).isFalse(); + @Test + public void test_selectAll() { + List<QProfileDto> sharedData = createSharedData(); + + List<QProfileDto> reloadeds = underTest.selectAll(dbSession, organization); + + assertThat(reloadeds).hasSize(sharedData.size()); + + IntStream.range(1, reloadeds.size()) + .forEach( + i -> { + QProfileDto reloaded = reloadeds.get(i - 1); + QProfileDto original = sharedData.get(i - 1); + + assertThat(reloaded.getId()).isEqualTo(original.getId()); + assertThat(reloaded.getName()).isEqualTo(original.getName()); + assertThat(reloaded.getKee()).isEqualTo(original.getKee()); + assertThat(reloaded.getOrganizationUuid()).isEqualTo(original.getOrganizationUuid()); + assertThat(reloaded.getLanguage()).isEqualTo(original.getLanguage()); + assertThat(reloaded.getParentKee()).isEqualTo(original.getParentKee()); + assertThat(reloaded.getRulesUpdatedAt()).isEqualTo(original.getRulesUpdatedAt()); + assertThat(reloaded.getLastUsed()).isEqualTo(original.getLastUsed()); + assertThat(reloaded.getUserUpdatedAt()).isEqualTo(original.getUserUpdatedAt()); + assertThat(reloaded.isBuiltIn()).isEqualTo(original.isBuiltIn()); + } + ); } @Test public void find_all_is_sorted_by_profile_name() { - dbTester.prepareDbUnit(getClass(), "select_all_is_sorted_by_profile_name.xml"); + QProfileDto dto1 = QProfileDto.createFor("js_first") + .setOrganizationUuid(organization.getUuid()) + .setName("First") + .setLanguage("js") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, dto1); + + QProfileDto dto2 = QProfileDto.createFor("js_second") + .setOrganizationUuid(organization.getUuid()) + .setName("Second") + .setLanguage("js") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, dto2); + + QProfileDto dto3 = QProfileDto.createFor("js_third") + .setOrganizationUuid(organization.getUuid()) + .setName("Third") + .setLanguage("js") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, dto3); - List<RulesProfileDto> dtos = underTest.selectAll(dbTester.getSession(), organization); + List<QProfileDto> dtos = underTest.selectAll(dbSession, organization); assertThat(dtos).hasSize(3); assertThat(dtos.get(0).getName()).isEqualTo("First"); assertThat(dtos.get(1).getName()).isEqualTo("Second"); assertThat(dtos.get(2).getName()).isEqualTo("Third"); + + underTest.deleteByUuids(dbSession, Arrays.asList("js_first", "js_second", "js_third")); } @Test public void get_default_profile() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); + List<QProfileDto> sharedData = createSharedData(); - RulesProfileDto java = underTest.selectDefaultProfile(dbTester.getSession(), organization, "java"); + QProfileDto java = underTest.selectDefaultProfile(dbSession, organization, "java"); assertThat(java).isNotNull(); assertThat(java.getKee()).isEqualTo("java_sonar_way"); - assertThat(underTest.selectDefaultProfile(dbTester.getSession(), dbTester.organizations().insert(), "java")).isNull(); - assertThat(underTest.selectDefaultProfile(dbTester.getSession(), organization, "js")).isNull(); + assertThat(underTest.selectDefaultProfile(dbSession, dbTester.organizations().insert(), "java")).isNull(); + assertThat(underTest.selectDefaultProfile(dbSession, organization, "js")).isNull(); } @Test public void get_default_profiles() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); + List<QProfileDto> sharedData = createSharedData(); - List<RulesProfileDto> java = underTest.selectDefaultProfiles(dbTester.getSession(), organization, singletonList("java")); - assertThat(java).extracting(RulesProfileDto::getKee).containsOnly("java_sonar_way"); + List<QProfileDto> java = underTest.selectDefaultProfiles(dbSession, organization, singletonList("java")); + assertThat(java).extracting(QProfileDto::getKee).containsOnly("java_sonar_way"); - assertThat(underTest.selectDefaultProfiles(dbTester.getSession(), organization, singletonList("js"))).isEmpty(); - assertThat(underTest.selectDefaultProfiles(dbTester.getSession(), organization, of("java", "js"))).extracting(RulesProfileDto::getKee).containsOnly("java_sonar_way"); - assertThat(underTest.selectDefaultProfiles(dbTester.getSession(), organization, of("js", "java"))).extracting(RulesProfileDto::getKee).containsOnly("java_sonar_way"); + assertThat(underTest.selectDefaultProfiles(dbSession, organization, singletonList("js"))).isEmpty(); + assertThat(underTest.selectDefaultProfiles(dbSession, organization, of("java", "js"))).extracting(QProfileDto::getKee).containsOnly("java_sonar_way"); + assertThat(underTest.selectDefaultProfiles(dbSession, organization, of("js", "java"))).extracting(QProfileDto::getKee).containsOnly("java_sonar_way"); } @Test public void get_by_name_and_language() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); + List<QProfileDto> sharedData = createSharedData(); - RulesProfileDto dto = underTest.selectByNameAndLanguage(organization, "Sonar Way", "java", dbTester.getSession()); - assertThat(dto.getId()).isEqualTo(1); + QProfileDto dto = underTest.selectByNameAndLanguage(dbSession, organization, "Sonar Way", "java"); assertThat(dto.getName()).isEqualTo("Sonar Way"); assertThat(dto.getLanguage()).isEqualTo("java"); assertThat(dto.getParentKee()).isNull(); - assertThat(underTest.selectByNameAndLanguage(organization, "Sonar Way", "java", dbTester.getSession())).isNotNull(); - assertThat(underTest.selectByNameAndLanguage(organization, "Sonar Way", "unknown", dbTester.getSession())).isNull(); + assertThat(underTest.selectByNameAndLanguage(dbSession, organization, "Sonar Way", "java")).isNotNull(); + assertThat(underTest.selectByNameAndLanguage(dbSession, organization, "Sonar Way", "unknown")).isNull(); } @Test public void get_by_name_and_languages() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); + createSharedData(); - List<RulesProfileDto> dtos = underTest.selectByNameAndLanguages(organization, "Sonar Way", singletonList("java"), dbTester.getSession()); + List<QProfileDto> dtos = underTest.selectByNameAndLanguages(dbSession, organization, "Sonar Way", singletonList("java")); assertThat(dtos).hasSize(1); - RulesProfileDto dto = dtos.iterator().next(); - assertThat(dto.getId()).isEqualTo(1); + QProfileDto dto = dtos.iterator().next(); assertThat(dto.getName()).isEqualTo("Sonar Way"); assertThat(dto.getLanguage()).isEqualTo("java"); assertThat(dto.getParentKee()).isNull(); - assertThat(underTest.selectByNameAndLanguages(organization, "Sonar Way", singletonList("unknown"), dbTester.getSession())).isEmpty(); - assertThat(underTest.selectByNameAndLanguages(organization, "Sonar Way", of("java", "unknown"), dbTester.getSession())).extracting("id").containsOnly(1); + assertThat(underTest.selectByNameAndLanguages(dbSession, organization, "Sonar Way", singletonList("unknown"))).isEmpty(); + assertThat(underTest.selectByNameAndLanguages(dbSession, organization, "Sonar Way", of("java", "unknown"))) + .extracting(QProfileDto::getKee).containsOnly(dto.getKee()); } @Test public void should_find_by_language() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto() + QProfileDto profile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()); underTest.insert(dbSession, profile); - List<RulesProfileDto> results = underTest.selectByLanguage(dbSession, organization, profile.getLanguage()); + List<QProfileDto> results = underTest.selectByLanguage(dbSession, organization, profile.getLanguage()); assertThat(results).hasSize(1); - RulesProfileDto result = results.get(0); + QProfileDto result = results.get(0); assertThat(result.getId()).isEqualTo(profile.getId()); assertThat(result.getName()).isEqualTo(profile.getName()); @@ -265,60 +330,123 @@ public class QualityProfileDaoTest { @Test public void should_not_find_by_language_in_wrong_organization() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto() + QProfileDto profile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()); underTest.insert(dbSession, profile); - List<RulesProfileDto> results = underTest.selectByLanguage(dbSession, OrganizationTesting.newOrganizationDto(), profile.getLanguage()); + List<QProfileDto> results = underTest.selectByLanguage(dbSession, OrganizationTesting.newOrganizationDto(), profile.getLanguage()); assertThat(results).isEmpty(); } @Test public void should_not_find_by_language_with_wrong_language() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto() + QProfileDto profile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()); underTest.insert(dbSession, profile); - List<RulesProfileDto> results = underTest.selectByLanguage(dbSession, organization, "another language"); + List<QProfileDto> results = underTest.selectByLanguage(dbSession, organization, "another language"); assertThat(results).isEmpty(); } + @Test public void find_children() { - dbTester.prepareDbUnit(getClass(), "inheritance.xml"); + QProfileDto original1 = QProfileDto.createFor("java_child1") + .setOrganizationUuid(organization.getUuid()) + .setName("Child1") + .setLanguage("java") + .setLastUsed(1_000L) + .setParentKee("java_parent") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original1); + + QProfileDto original2 = QProfileDto.createFor("java_child2") + .setOrganizationUuid(organization.getUuid()) + .setName("Child2") + .setLanguage("java") + .setLastUsed(1_000L) + .setParentKee("java_parent") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original2); + + QProfileDto original3 = QProfileDto.createFor("java_parent") + .setOrganizationUuid(organization.getUuid()) + .setName("Parent") + .setLanguage("java") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original3); + + QProfileDto original4 = QProfileDto.createFor("js_child1") + .setOrganizationUuid(organization.getUuid()) + .setName("Child1") + .setLanguage("js") + .setLastUsed(1_000L) + .setParentKee("js_parent") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original4); - List<RulesProfileDto> dtos = underTest.selectChildren(dbTester.getSession(), "java_parent"); + QProfileDto original5 = QProfileDto.createFor("js_child2") + .setOrganizationUuid(organization.getUuid()) + .setName("Child2") + .setLanguage("js") + .setLastUsed(1_000L) + .setParentKee("js_parent") + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original5); + + QProfileDto original6 = QProfileDto.createFor("js_parent") + .setOrganizationUuid(organization.getUuid()) + .setName("Parent") + .setLanguage("js") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(false); + underTest.insert(dbSession, original6); + + List<QProfileDto> dtos = underTest.selectChildren(dbSession, "java_parent"); assertThat(dtos).hasSize(2); - RulesProfileDto dto1 = dtos.get(0); - assertThat(dto1.getId()).isEqualTo(1); + QProfileDto dto1 = dtos.get(0); assertThat(dto1.getName()).isEqualTo("Child1"); assertThat(dto1.getLanguage()).isEqualTo("java"); assertThat(dto1.getParentKee()).isEqualTo("java_parent"); - RulesProfileDto dto2 = dtos.get(1); - assertThat(dto2.getId()).isEqualTo(2); + QProfileDto dto2 = dtos.get(1); assertThat(dto2.getName()).isEqualTo("Child2"); assertThat(dto2.getLanguage()).isEqualTo("java"); assertThat(dto2.getParentKee()).isEqualTo("java_parent"); + + underTest.deleteByUuids(dbSession, Arrays.asList("java_parent", "java_child1", "java_child2", "js_parent", "js_child1", "js_child2")); } @Test public void countProjectsByProfileKey() { - RulesProfileDto profileWithoutProjects = dbTester.qualityProfiles().insert(organization); - RulesProfileDto profileWithProjects = dbTester.qualityProfiles().insert(organization); + QProfileDto profileWithoutProjects = dbTester.qualityProfiles().insert(organization); + QProfileDto profileWithProjects = dbTester.qualityProfiles().insert(organization); ComponentDto project1 = dbTester.components().insertPrivateProject(organization); ComponentDto project2 = dbTester.components().insertPrivateProject(organization); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project1, profileWithProjects); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project2, profileWithProjects); + dbTester.qualityProfiles().associateWithProject(project1, profileWithProjects); + dbTester.qualityProfiles().associateWithProject(project2, profileWithProjects); OrganizationDto otherOrg = dbTester.organizations().insert(); - RulesProfileDto profileInOtherOrg = dbTester.qualityProfiles().insert(otherOrg); + QProfileDto profileInOtherOrg = dbTester.qualityProfiles().insert(otherOrg); ComponentDto projectInOtherOrg = dbTester.components().insertPrivateProject(otherOrg); - dbTester.qualityProfiles().associateProjectWithQualityProfile(projectInOtherOrg, profileInOtherOrg); + dbTester.qualityProfiles().associateWithProject(projectInOtherOrg, profileInOtherOrg); - assertThat(underTest.countProjectsByProfileKey(dbTester.getSession(), organization)).containsOnly( + assertThat(underTest.countProjectsByProfileUuid(dbSession, organization)).containsOnly( MapEntry.entry(profileWithProjects.getKee(), 2L)); } @@ -327,17 +455,17 @@ public class QualityProfileDaoTest { OrganizationDto org = dbTester.organizations().insert(); ComponentDto project1 = dbTester.components().insertPublicProject(org); ComponentDto project2 = dbTester.components().insertPublicProject(org); - RulesProfileDto javaProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); - RulesProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project1, javaProfile, jsProfile); + QProfileDto javaProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); + QProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); + dbTester.qualityProfiles().associateWithProject(project1, javaProfile, jsProfile); - assertThat(underTest.selectAssociatedToProjectAndLanguage(dbTester.getSession(), project1, "java").getKee()) + assertThat(underTest.selectAssociatedToProjectAndLanguage(dbSession, project1, "java").getKee()) .isEqualTo(javaProfile.getKee()); - assertThat(underTest.selectAssociatedToProjectAndLanguage(dbTester.getSession(), project1, "js").getKee()) + assertThat(underTest.selectAssociatedToProjectAndLanguage(dbSession, project1, "js").getKee()) .isEqualTo(jsProfile.getKee()); - assertThat(underTest.selectAssociatedToProjectAndLanguage(dbTester.getSession(), project1, "cobol")) + assertThat(underTest.selectAssociatedToProjectAndLanguage(dbSession, project1, "cobol")) .isNull(); - assertThat(underTest.selectAssociatedToProjectAndLanguage(dbTester.getSession(), project2, "java")) + assertThat(underTest.selectAssociatedToProjectAndLanguage(dbSession, project2, "java")) .isNull(); } @@ -346,19 +474,19 @@ public class QualityProfileDaoTest { OrganizationDto org = dbTester.organizations().insert(); ComponentDto project1 = dbTester.components().insertPublicProject(org); ComponentDto project2 = dbTester.components().insertPublicProject(org); - RulesProfileDto javaProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); - RulesProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project1, javaProfile, jsProfile); + QProfileDto javaProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); + QProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); + dbTester.qualityProfiles().associateWithProject(project1, javaProfile, jsProfile); - assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbTester.getSession(), project1, singletonList("java"))) - .extracting(RulesProfileDto::getKee).containsOnly(javaProfile.getKee()); - assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbTester.getSession(), project1, singletonList("unknown"))) + assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbSession, project1, singletonList("java"))) + .extracting(QProfileDto::getKee).containsOnly(javaProfile.getKee()); + assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbSession, project1, singletonList("unknown"))) .isEmpty(); - assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbTester.getSession(), project1, of("java", "unknown"))) - .extracting(RulesProfileDto::getKee).containsExactly(javaProfile.getKee()); - assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbTester.getSession(), project1, of("java", "js"))) - .extracting(RulesProfileDto::getKee).containsExactlyInAnyOrder(javaProfile.getKee(), jsProfile.getKee()); - assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbTester.getSession(), project2, singletonList("java"))) + assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbSession, project1, of("java", "unknown"))) + .extracting(QProfileDto::getKee).containsExactly(javaProfile.getKee()); + assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbSession, project1, of("java", "js"))) + .extracting(QProfileDto::getKee).containsExactlyInAnyOrder(javaProfile.getKee(), jsProfile.getKee()); + assertThat(underTest.selectAssociatedToProjectUuidAndLanguages(dbSession, project2, singletonList("java"))) .isEmpty(); } @@ -366,10 +494,10 @@ public class QualityProfileDaoTest { public void test_updateProjectProfileAssociation() { OrganizationDto org = dbTester.organizations().insert(); ComponentDto project = dbTester.components().insertPrivateProject(org); - RulesProfileDto javaProfile1 = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); - RulesProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); - RulesProfileDto javaProfile2 = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); - qualityProfileDb.associateProjectWithQualityProfile(project, javaProfile1, jsProfile); + QProfileDto javaProfile1 = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); + QProfileDto jsProfile = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("js")); + QProfileDto javaProfile2 = dbTester.qualityProfiles().insert(org, p -> p.setLanguage("java")); + dbTester.qualityProfiles().associateWithProject(project, javaProfile1, jsProfile); underTest.updateProjectProfileAssociation(dbSession, project, javaProfile2.getKee(), javaProfile1.getKee()); @@ -379,15 +507,15 @@ public class QualityProfileDaoTest { @Test public void selectByKeys() { - qualityProfileDb.insertQualityProfiles(newQualityProfileDto().setKey("qp-key-1"), newQualityProfileDto().setKee("qp-key-2"), newQualityProfileDto().setKee("qp-key-3")); + dbTester.qualityProfiles().insert(newQualityProfileDto().setKey("qp-key-1"), newQualityProfileDto().setKee("qp-key-2"), newQualityProfileDto().setKee("qp-key-3")); - assertThat(underTest.selectOrFailByKey(dbSession, "qp-key-1")).isNotNull(); - assertThat(underTest.selectByKey(dbSession, "qp-key-1")).isNotNull(); - assertThat(underTest.selectByKey(dbSession, "qp-key-42")).isNull(); - assertThat(underTest.selectByKeys(dbSession, newArrayList("qp-key-1", "qp-key-3", "qp-key-42"))) + assertThat(underTest.selectOrFailByUuid(dbSession, "qp-key-1")).isNotNull(); + assertThat(underTest.selectByUuid(dbSession, "qp-key-1")).isNotNull(); + assertThat(underTest.selectByUuid(dbSession, "qp-key-42")).isNull(); + assertThat(underTest.selectByUuids(dbSession, newArrayList("qp-key-1", "qp-key-3", "qp-key-42"))) .hasSize(2) - .extracting(RulesProfileDto::getKee).containsOnlyOnce("qp-key-1", "qp-key-3"); - assertThat(underTest.selectByKeys(dbSession, emptyList())).isEmpty(); + .extracting(QProfileDto::getKee).containsOnlyOnce("qp-key-1", "qp-key-3"); + assertThat(underTest.selectByUuids(dbSession, emptyList())).isEmpty(); } @Test @@ -398,23 +526,24 @@ public class QualityProfileDaoTest { OrganizationDto organization2 = dbTester.organizations().insert(); ComponentDto project4 = dbTester.components().insertPrivateProject(t -> t.setName("Project4 name"), t -> t.setOrganizationUuid(organization2.getUuid())); - RulesProfileDto profile1 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile1); - qualityProfileDb.associateProjectWithQualityProfile(project1, profile1); - qualityProfileDb.associateProjectWithQualityProfile(project2, profile1); + QProfileDto profile1 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile1); + dbTester.qualityProfiles().associateWithProject(project1, profile1); + dbTester.qualityProfiles().associateWithProject(project2, profile1); - RulesProfileDto profile2 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile2); - qualityProfileDb.associateProjectWithQualityProfile(project3, profile2); + QProfileDto profile2 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile2); + dbTester.qualityProfiles().associateWithProject(project3, profile2); + QProfileDto profile3 = newQualityProfileDto(); - assertThat(underTest.selectSelectedProjects(organization, profile1.getKee(), null, dbSession)) + assertThat(underTest.selectSelectedProjects(dbSession, organization, profile1, null)) .extracting("projectId", "projectUuid", "projectKey", "projectName", "profileKey") .containsOnly( tuple(project1.getId(), project1.uuid(), project1.key(), project1.name(), profile1.getKee()), tuple(project2.getId(), project2.uuid(), project2.key(), project2.name(), profile1.getKee())); - assertThat(underTest.selectSelectedProjects(organization, profile1.getKee(), "ect1", dbSession)).hasSize(1); - assertThat(underTest.selectSelectedProjects(organization, "unknown", null, dbSession)).isEmpty(); + assertThat(underTest.selectSelectedProjects(dbSession, organization, profile1, "ect1")).hasSize(1); + assertThat(underTest.selectSelectedProjects(dbSession, organization, profile3, null)).isEmpty(); } @Test @@ -425,22 +554,23 @@ public class QualityProfileDaoTest { OrganizationDto organization2 = dbTester.organizations().insert(); ComponentDto project4 = dbTester.components().insertPrivateProject(t -> t.setName("Project4 name"), t -> t.setOrganizationUuid(organization2.getUuid())); - RulesProfileDto profile1 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile1); - qualityProfileDb.associateProjectWithQualityProfile(project1, profile1); + QProfileDto profile1 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile1); + dbTester.qualityProfiles().associateWithProject(project1, profile1); - RulesProfileDto profile2 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile2); - qualityProfileDb.associateProjectWithQualityProfile(project2, profile2); + QProfileDto profile2 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile2); + dbTester.qualityProfiles().associateWithProject(project2, profile2); + QProfileDto profile3 = newQualityProfileDto(); - assertThat(underTest.selectDeselectedProjects(organization, profile1.getKee(), null, dbSession)) + assertThat(underTest.selectDeselectedProjects(dbSession, organization, profile1, null)) .extracting("projectId", "projectUuid", "projectKey", "projectName", "profileKey") .containsExactly( tuple(project2.getId(), project2.uuid(), project2.key(), project2.name(), null), tuple(project3.getId(), project3.uuid(), project3.key(), project3.name(), null)); - assertThat(underTest.selectDeselectedProjects(organization, profile1.getKee(), "ect2", dbSession)).hasSize(1); - assertThat(underTest.selectDeselectedProjects(organization, "unknown", null, dbSession)).hasSize(3); + assertThat(underTest.selectDeselectedProjects(dbSession, organization, profile1, "ect2")).hasSize(1); + assertThat(underTest.selectDeselectedProjects(dbSession, organization, profile3, null)).hasSize(3); } @Test @@ -451,23 +581,24 @@ public class QualityProfileDaoTest { OrganizationDto organization2 = dbTester.organizations().insert(); ComponentDto project4 = dbTester.components().insertPrivateProject(t -> t.setName("Project4 name"), t -> t.setOrganizationUuid(organization2.getUuid())); - RulesProfileDto profile1 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile1); - qualityProfileDb.associateProjectWithQualityProfile(project1, profile1); + QProfileDto profile1 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile1); + dbTester.qualityProfiles().associateWithProject(project1, profile1); - RulesProfileDto profile2 = newQualityProfileDto(); - qualityProfileDb.insertQualityProfiles(profile2); - qualityProfileDb.associateProjectWithQualityProfile(project2, profile2); + QProfileDto profile2 = newQualityProfileDto(); + dbTester.qualityProfiles().insert(profile2); + dbTester.qualityProfiles().associateWithProject(project2, profile2); + QProfileDto profile3 = newQualityProfileDto(); - assertThat(underTest.selectProjectAssociations(organization, profile1.getKee(), null, dbSession)) + assertThat(underTest.selectProjectAssociations(dbSession, organization, profile1, null)) .extracting("projectId", "projectUuid", "projectKey", "projectName", "profileKey") .containsOnly( tuple(project1.getId(), project1.uuid(), project1.key(), project1.name(), profile1.getKee()), tuple(project2.getId(), project2.uuid(), project2.key(), project2.name(), null), tuple(project3.getId(), project3.uuid(), project3.key(), project3.name(), null)); - assertThat(underTest.selectProjectAssociations(organization, profile1.getKee(), "ect2", dbSession)).hasSize(1); - assertThat(underTest.selectProjectAssociations(organization, "unknown", null, dbSession)).hasSize(3); + assertThat(underTest.selectProjectAssociations(dbSession, organization, profile1, "ect2")).hasSize(1); + assertThat(underTest.selectProjectAssociations(dbSession, organization, profile3, null)).hasSize(3); } @Test @@ -475,54 +606,75 @@ public class QualityProfileDaoTest { OrganizationDto org1 = dbTester.organizations().insert(); OrganizationDto org2 = dbTester.organizations().insert(); OrganizationDto org3 = dbTester.organizations().insert(); - RulesProfileDto outdatedProfile1 = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("java").setName("foo")); - RulesProfileDto outdatedProfile2 = dbTester.qualityProfiles().insert(org2, p -> p.setIsBuiltIn(false).setLanguage("java").setName("foo")); - RulesProfileDto builtInProfile = dbTester.qualityProfiles().insert(org3, p -> p.setIsBuiltIn(true).setLanguage("java").setName("foo")); - RulesProfileDto differentLanguage = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("cobol").setName("foo")); - RulesProfileDto differentName = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("java").setName("bar")); + QProfileDto outdatedProfile1 = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("java").setName("foo")); + QProfileDto outdatedProfile2 = dbTester.qualityProfiles().insert(org2, p -> p.setIsBuiltIn(false).setLanguage("java").setName("foo")); + QProfileDto builtInProfile = dbTester.qualityProfiles().insert(org3, p -> p.setIsBuiltIn(true).setLanguage("java").setName("foo")); + QProfileDto differentLanguage = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("cobol").setName("foo")); + QProfileDto differentName = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage("java").setName("bar")); - Collection<String> keys = underTest.selectOutdatedProfiles(dbSession, "java", "foo"); + Collection<String> keys = underTest.selectUuidsOfCustomRulesProfiles(dbSession, "java", "foo"); assertThat(keys).containsExactlyInAnyOrder(outdatedProfile1.getKee(), outdatedProfile2.getKee()); } @Test public void selectOutdatedProfiles_returns_empty_list_if_no_match() { - assertThat(underTest.selectOutdatedProfiles(dbSession, "java", "foo")).isEmpty(); + assertThat(underTest.selectUuidsOfCustomRulesProfiles(dbSession, "java", "foo")).isEmpty(); } @Test public void renameAndCommit_updates_name_of_specified_profiles() { OrganizationDto org1 = dbTester.organizations().insert(); OrganizationDto org2 = dbTester.organizations().insert(); - RulesProfileDto fooInOrg1 = dbTester.qualityProfiles().insert(org1, p -> p.setName("foo")); - RulesProfileDto fooInOrg2 = dbTester.qualityProfiles().insert(org2, p -> p.setName("foo")); - RulesProfileDto bar = dbTester.qualityProfiles().insert(org1, p -> p.setName("bar")); + QProfileDto fooInOrg1 = dbTester.qualityProfiles().insert(org1, p -> p.setName("foo")); + QProfileDto fooInOrg2 = dbTester.qualityProfiles().insert(org2, p -> p.setName("foo")); + QProfileDto bar = dbTester.qualityProfiles().insert(org1, p -> p.setName("bar")); - underTest.renameAndCommit(dbSession, asList(fooInOrg1.getKee(), fooInOrg2.getKee()), "foo (copy)"); + underTest.renameRulesProfilesAndCommit(dbSession, asList(fooInOrg1.getKee(), fooInOrg2.getKee()), "foo (copy)"); - assertThat(underTest.selectOrFailByKey(dbSession, fooInOrg1.getKee()).getName()).isEqualTo("foo (copy)"); - assertThat(underTest.selectOrFailByKey(dbSession, fooInOrg2.getKee()).getName()).isEqualTo("foo (copy)"); - assertThat(underTest.selectOrFailByKey(dbSession, bar.getKee()).getName()).isEqualTo("bar"); + assertThat(underTest.selectOrFailByUuid(dbSession, fooInOrg1.getKee()).getName()).isEqualTo("foo (copy)"); + assertThat(underTest.selectOrFailByUuid(dbSession, fooInOrg2.getKee()).getName()).isEqualTo("foo (copy)"); + assertThat(underTest.selectOrFailByUuid(dbSession, bar.getKee()).getName()).isEqualTo("bar"); } @Test public void renameAndCommit_does_nothing_if_empty_keys() { OrganizationDto org = dbTester.organizations().insert(); - RulesProfileDto profile = dbTester.qualityProfiles().insert(org, p -> p.setName("foo")); + QProfileDto profile = dbTester.qualityProfiles().insert(org, p -> p.setName("foo")); - underTest.renameAndCommit(dbSession, Collections.emptyList(), "foo (copy)"); + underTest.renameRulesProfilesAndCommit(dbSession, Collections.emptyList(), "foo (copy)"); - assertThat(underTest.selectOrFailByKey(dbSession, profile.getKee()).getName()).isEqualTo("foo"); + assertThat(underTest.selectOrFailByUuid(dbSession, profile.getKee()).getName()).isEqualTo("foo"); } - private RulesProfileDto insertQualityProfileDto(String key, String name, String language) { - RulesProfileDto dto = RulesProfileDto.createFor(key) + private List<QProfileDto> createSharedData() { + QProfileDto dto1 = QProfileDto.createFor("java_sonar_way") .setOrganizationUuid(organization.getUuid()) - .setName(name) - .setLanguage(language); - underTest.insert(dbSession, dto); - return dto; + .setName("Sonar Way") + .setLanguage("java") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(true); + underTest.insert(dbSession, dto1); + + QProfileDto dto2 = QProfileDto.createFor("js_sonar_way") + .setOrganizationUuid(organization.getUuid()) + .setName("Sonar Way") + .setLanguage("js") + .setLastUsed(1_000L) + .setUserUpdatedAt(2_000L) + .setRulesUpdatedAt("2017-05-31") + .setIsBuiltIn(true); + underTest.insert(dbSession, dto2); + + DefaultQProfileDto defaultQProfileDto = new DefaultQProfileDto() + .setQProfileUuid(dto1.getKee()) + .setLanguage(dto1.getLanguage()) + .setOrganizationUuid(organization.getUuid()); + dbTester.getDbClient().defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(dto1)); + + return Arrays.asList(dto1, dto2); } } diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDbTester.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDbTester.java index 562f925b2ca..02c53fad43d 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDbTester.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileDbTester.java @@ -22,6 +22,7 @@ package org.sonar.db.qualityprofile; import java.util.Arrays; import java.util.Optional; import java.util.function.Consumer; +import org.sonar.api.rule.Severity; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; @@ -29,93 +30,82 @@ import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.rule.RuleDefinitionDto; -import static org.sonar.api.rule.Severity.MAJOR; +import static org.apache.commons.lang.math.RandomUtils.nextInt; +import static org.apache.commons.lang.math.RandomUtils.nextLong; import static org.sonar.db.qualityprofile.ActiveRuleDto.createFor; public class QualityProfileDbTester { - private final DbTester dbTester; private final DbClient dbClient; private final DbSession dbSession; public QualityProfileDbTester(DbTester dbTester) { - this.dbTester = dbTester; this.dbClient = dbTester.getDbClient(); this.dbSession = dbTester.getSession(); } - public Optional<RulesProfileDto> selectByKey(String key) { - return Optional.ofNullable(dbClient.qualityProfileDao().selectByKey(dbSession, key)); + public Optional<QProfileDto> selectByUuid(String uuid) { + return Optional.ofNullable(dbClient.qualityProfileDao().selectByUuid(dbSession, uuid)); } /** * Create a profile with random field values on the specified organization. */ - @SafeVarargs - public final RulesProfileDto insert(OrganizationDto organization, Consumer<RulesProfileDto>... consumers) { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto() + public QProfileDto insert(OrganizationDto organization) { + return insert(organization, c -> { + }); + } + + /** + * Create a profile with random field values on the specified organization. + */ + public QProfileDto insert(OrganizationDto organization, Consumer<QProfileDto> consumer) { + QProfileDto profile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()); - Arrays.stream(consumers).forEach(c -> c.accept(profile)); + consumer.accept(profile); dbClient.qualityProfileDao().insert(dbSession, profile); dbSession.commit(); return profile; } - public void insertQualityProfiles(RulesProfileDto qualityProfile, RulesProfileDto... qualityProfiles) { - dbClient.qualityProfileDao().insert(dbSession, qualityProfile, qualityProfiles); - dbSession.commit(); - } - - public RulesProfileDto insertQualityProfile(RulesProfileDto qualityProfile) { - dbClient.qualityProfileDao().insert(dbSession, qualityProfile); + public QualityProfileDbTester insert(QProfileDto profile, QProfileDto... others) { + dbClient.qualityProfileDao().insert(dbSession, profile); + Arrays.stream(others).forEach(p -> dbClient.qualityProfileDao().insert(dbSession, p)); dbSession.commit(); - return qualityProfile; + return this; } - public void insertProjectWithQualityProfileAssociations(ComponentDto project, RulesProfileDto... qualityProfiles) { - dbClient.componentDao().insert(dbSession, project); - for (RulesProfileDto qualityProfile : qualityProfiles) { - dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, qualityProfile); + public QualityProfileDbTester associateWithProject(ComponentDto project, QProfileDto profile, QProfileDto... otherProfiles) { + dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, profile); + for (QProfileDto p : otherProfiles) { + dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, p); } dbSession.commit(); + return this; } - public void associateProjectWithQualityProfile(ComponentDto project, RulesProfileDto... qualityProfiles) { - for (RulesProfileDto qualityProfile : qualityProfiles) { - dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, qualityProfile); - } - dbSession.commit(); + public ActiveRuleDto activateRule(QProfileDto profile, RuleDefinitionDto rule) { + return activateRule(profile, rule, ar -> { + }); } - @SafeVarargs - public final ActiveRuleDto activateRule(RulesProfileDto profile, RuleDefinitionDto rule, Consumer<ActiveRuleDto>... consumers) { - ActiveRuleDto activeRule = createFor(profile, rule).setSeverity(MAJOR); - for (Consumer<ActiveRuleDto> consumer : consumers) { - consumer.accept(activeRule); - } + public ActiveRuleDto activateRule(QProfileDto profile, RuleDefinitionDto rule, Consumer<ActiveRuleDto> consumer) { + ActiveRuleDto activeRule = createFor(profile, rule) + .setSeverity(Severity.ALL.get(nextInt(Severity.ALL.size()))) + .setCreatedAt(nextLong()) + .setUpdatedAt(nextLong()); + consumer.accept(activeRule); dbClient.activeRuleDao().insert(dbSession, activeRule); dbSession.commit(); return activeRule; } - public void markAsDefault(RulesProfileDto... profiles) { - for (RulesProfileDto profile : profiles) { - DefaultQProfileDto dto = new DefaultQProfileDto() - .setOrganizationUuid(profile.getOrganizationUuid()) - .setLanguage(profile.getLanguage()) - .setQProfileUuid(profile.getKee()); - dbClient.defaultQProfileDao().insertOrUpdate(dbSession, dto); + public QualityProfileDbTester setAsDefault(QProfileDto profile, QProfileDto... others) { + dbClient.defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(profile)); + for (QProfileDto other : others) { + dbClient.defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(other)); } - dbSession.commit(); - } - - public Optional<String> selectUuidOfDefaultProfile(OrganizationDto org, String language) { - return dbTester.select("select qprofile_uuid as \"profileUuid\" " + - " from default_qprofiles " + - " where organization_uuid='" + org.getUuid() + "' and language='" + language + "'") - .stream() - .findFirst() - .map(m -> (String)m.get("profileUuid")); + return this; } } diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileTesting.java b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileTesting.java index 3c1c9c1dec5..31625394af9 100644 --- a/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileTesting.java +++ b/server/sonar-db-dao/src/test/java/org/sonar/db/qualityprofile/QualityProfileTesting.java @@ -20,25 +20,32 @@ package org.sonar.db.qualityprofile; import org.sonar.core.util.Uuids; -import org.sonar.db.DbSession; -import org.sonar.db.DbTester; -import static java.util.Arrays.stream; import static org.apache.commons.lang.RandomStringUtils.randomAlphanumeric; import static org.apache.commons.lang.math.RandomUtils.nextLong; public class QualityProfileTesting { - public static RulesProfileDto newQualityProfileDto() { + private QualityProfileTesting() { + // prevent instantiation + } + + /** + * Create an instance of {@link QProfileDto} with random field values. + */ + public static QProfileDto newQualityProfileDto() { String uuid = Uuids.createFast(); - RulesProfileDto dto = RulesProfileDto.createFor(uuid) + return QProfileDto.createFor(uuid) .setOrganizationUuid(randomAlphanumeric(40)) .setName(uuid) .setLanguage(randomAlphanumeric(20)) .setLastUsed(nextLong()); - return dto; } + /** + * Create an instance of {@link QProfileChangeDto} with random field values, + * except changeType which is always {@code "ACTIVATED"}. + */ public static QProfileChangeDto newQProfileChangeDto() { return new QProfileChangeDto() .setKey(randomAlphanumeric(40)) @@ -47,13 +54,4 @@ public class QualityProfileTesting { .setChangeType("ACTIVATED") .setLogin(randomAlphanumeric(10)); } - - public static void insert(DbTester dbTester, QProfileChangeDto... dtos) { - // do not use QProfileChangeDao so that generated fields key and creation date - // can be defined by tests - DbSession dbSession = dbTester.getSession(); - QProfileChangeMapper mapper = dbSession.getMapper(QProfileChangeMapper.class); - stream(dtos).forEach(mapper::insert); - dbSession.commit(); - } } diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/delete-result.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/delete-result.xml deleted file mode 100644 index 691735eb14d..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/delete-result.xml +++ /dev/null @@ -1,16 +0,0 @@ -<dataset> - - <rules_profiles id="2" - name="Sonar Way" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="123456789" - user_updated_at="987654321"/> - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/inheritance.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/inheritance.xml deleted file mode 100644 index 8f063f02d18..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/inheritance.xml +++ /dev/null @@ -1,71 +0,0 @@ -<dataset> - - <rules_profiles id="1" - name="Child1" - language="java" - organization_uuid="org-123" - parent_kee="java_parent" - kee="java_child1" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="2" - name="Child2" - language="java" - organization_uuid="org-123" - parent_kee="java_parent" - kee="java_child2" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="3" - name="Parent" - language="java" - organization_uuid="org-123" - parent_kee="[null]" - kee="java_parent" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <!-- Same profile for another language --> - - <rules_profiles id="4" - name="Child1" - language="js" - organization_uuid="org-123" - parent_kee="js_parent" - kee="js_child1" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="5" - name="Child2" - language="js" - organization_uuid="org-123" - parent_kee="js_parent" - kee="js_child2" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="6" - name="Parent" - language="js" - organization_uuid="org-123" - parent_kee="[null]" - kee="js_parent" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/insert-result.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/insert-result.xml deleted file mode 100644 index 1e4b2849681..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/insert-result.xml +++ /dev/null @@ -1,43 +0,0 @@ -<dataset> - - <rules_profiles id="1" - name="Sonar Way" - language="java" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="java_sonar_way" - is_built_in="[true]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="[null]" - user_updated_at="[null]"/> - - <rules_profiles id="2" - name="Sonar Way" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="123456789" - user_updated_at="987654321"/> - - <rules_profiles id="3" - name="ABCDE" - language="xoo" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="abcde" - is_built_in="[true]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="[null]" - user_updated_at="[null]"/> - - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_all_is_sorted_by_profile_name.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_all_is_sorted_by_profile_name.xml deleted file mode 100644 index 42c8a4f64ab..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_all_is_sorted_by_profile_name.xml +++ /dev/null @@ -1,37 +0,0 @@ -<dataset> - - <rules_profiles id="3" - name="Third" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_third" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="1" - name="First" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_first" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="2" - name="Second" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_second" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_by_language.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_by_language.xml deleted file mode 100644 index 3d5814908ca..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/select_by_language.xml +++ /dev/null @@ -1,36 +0,0 @@ -<dataset> - - <rules_profiles id="1" - name="Sonar Way 1" - language="java" - organization_uuid="org-123" - parent_kee="[null]" - kee="java_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="2" - name="Sonar Way" - language="js" - organization_uuid="org-123" - parent_kee="[null]" - kee="js_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - - <rules_profiles id="3" - name="Sonar Way 2" - language="java" - organization_uuid="org-123" - parent_kee="[null]" - kee="java_sonar_way2" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]"/> - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/shared.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/shared.xml deleted file mode 100644 index 7872802c029..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/shared.xml +++ /dev/null @@ -1,37 +0,0 @@ -<dataset> - - <rules_profiles id="1" - name="Sonar Way" - language="java" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="java_sonar_way" - is_built_in="[true]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="[null]" - user_updated_at="[null]"/> - - <rules_profiles id="2" - name="Sonar Way" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="123456789" - user_updated_at="987654321"/> - - <default_qprofiles - organization_uuid="QualityProfileDaoTest-ORG" - language="java" - qprofile_uuid="java_sonar_way" - created_at="1000" - updated_at="2000" - /> - -</dataset> diff --git a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/update-result.xml b/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/update-result.xml deleted file mode 100644 index d37e24c2e62..00000000000 --- a/server/sonar-db-dao/src/test/resources/org/sonar/db/qualityprofile/QualityProfileDaoTest/update-result.xml +++ /dev/null @@ -1,28 +0,0 @@ -<dataset> - - <rules_profiles id="1" - name="New Name" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="fghij" - kee="java_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="[null]" - user_updated_at="[null]"/> - - <rules_profiles id="2" - name="Sonar Way" - language="js" - organization_uuid="QualityProfileDaoTest-ORG" - parent_kee="[null]" - kee="js_sonar_way" - is_built_in="[false]" - rules_updated_at="[null]" - created_at="[null]" - updated_at="[null]" - last_used="123456789" - user_updated_at="987654321"/> -</dataset> diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfiles.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfiles.java index 23d137c1142..787fa699238 100644 --- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfiles.java +++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfiles.java @@ -30,11 +30,11 @@ import static org.sonar.server.platform.db.migration.def.BigIntegerColumnDef.new import static org.sonar.server.platform.db.migration.def.VarcharColumnDef.UUID_SIZE; import static org.sonar.server.platform.db.migration.def.VarcharColumnDef.newVarcharColumnDefBuilder; -public class CreateTableQProfiles extends DdlChange { +public class CreateTableOrgQProfiles extends DdlChange { - private static final String TABLE_NAME = "qprofiles"; + private static final String TABLE_NAME = "org_qprofiles"; - public CreateTableQProfiles(Database db) { + public CreateTableOrgQProfiles(Database db) { super(db); } @@ -46,21 +46,21 @@ public class CreateTableQProfiles extends DdlChange { .setIsNullable(false) .setIgnoreOracleUnit(true) .build(); + VarcharColumnDef rulesProfileUuid = newVarcharColumnDefBuilder() + .setColumnName("rules_profile_uuid") + .setLimit(UUID_SIZE) + .setIsNullable(false) + .setIgnoreOracleUnit(true) + .build(); context.execute( new CreateTableBuilder(getDialect(), TABLE_NAME) .addPkColumn(newVarcharColumnDefBuilder() .setColumnName("uuid") .setLimit(UUID_SIZE) .setIsNullable(false) - .setIgnoreOracleUnit(true) .build()) .addColumn(organizationColumn) - .addColumn(newVarcharColumnDefBuilder() - .setColumnName("rules_profile_uuid") - .setLimit(UUID_SIZE) - .setIsNullable(false) - .setIgnoreOracleUnit(true) - .build()) + .addColumn(rulesProfileUuid) .addColumn(newVarcharColumnDefBuilder() .setColumnName("parent_uuid") .setLimit(UUID_SIZE) @@ -83,5 +83,12 @@ public class CreateTableQProfiles extends DdlChange { .setName("qprofiles_org_uuid") .addColumn(organizationColumn) .build()); + + context.execute( + new CreateIndexBuilder(getDialect()) + .setTable(TABLE_NAME) + .setName("qprofiles_rp_uuid") + .addColumn(rulesProfileUuid) + .build()); } } diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65.java index a9956f20c78..abf295015e0 100644 --- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65.java +++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65.java @@ -49,6 +49,7 @@ public class DbVersion65 implements DbVersion { .add(1720, "Populate table default_qprofiles", PopulateTableDefaultQProfiles.class) .add(1721, "Drop rules_profiles.is_default", DropIsDefaultColumnFromRulesProfiles.class) .add(1722, "Create table qprofiles", CreateTableQProfiles.class) - .add(1723, "Populate table qprofiles", PopulateQProfiles.class); + .add(1723, "Populate table qprofiles", PopulateQProfiles.class) + .add(1724, "Drop columns organization_uuid and parent_kee from rules_profiles", DropOrgUuidAndParentKeeFromRulesProfiles.class); } } diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfiles.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfiles.java new file mode 100644 index 00000000000..105c8fde6ab --- /dev/null +++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfiles.java @@ -0,0 +1,41 @@ +/* + * SonarQube + * Copyright (C) 2009-2017 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ + +package org.sonar.server.platform.db.migration.version.v65; + +import java.sql.SQLException; +import org.sonar.db.Database; +import org.sonar.server.platform.db.migration.sql.DropColumnsBuilder; +import org.sonar.server.platform.db.migration.step.DdlChange; + +public class DropOrgUuidAndParentKeeFromRulesProfiles extends DdlChange { + + private static final String TABLE_NAME = "rules_profiles"; + + public DropOrgUuidAndParentKeeFromRulesProfiles(Database db) { + super(db); + } + + @Override + public void execute(Context context) throws SQLException { + context.execute(new DropColumnsBuilder(getDialect(), TABLE_NAME, "organization_uuid").build()); + context.execute(new DropColumnsBuilder(getDialect(), TABLE_NAME, "parent_kee").build()); + } +} diff --git a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/PopulateQProfiles.java b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfiles.java index a7505cd9d55..b8f35b3057a 100644 --- a/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/PopulateQProfiles.java +++ b/server/sonar-db-migration/src/main/java/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfiles.java @@ -26,11 +26,11 @@ import org.sonar.db.Database; import org.sonar.server.platform.db.migration.step.DataChange; import org.sonar.server.platform.db.migration.step.MassUpdate; -public class PopulateQProfiles extends DataChange { +public class PopulateOrgQProfiles extends DataChange { private final System2 system2; - public PopulateQProfiles(Database db, System2 system2) { + public PopulateOrgQProfiles(Database db, System2 system2) { super(db); this.system2 = system2; } @@ -41,15 +41,19 @@ public class PopulateQProfiles extends DataChange { MassUpdate massUpdate = context.prepareMassUpdate(); massUpdate.select("select p.kee, p.organization_uuid, p.parent_kee from rules_profiles p " + - "where not exists ( select qp.uuid from qprofiles qp where qp.uuid = p.kee and qp.organization_uuid = p.organization_uuid )"); - massUpdate.update("insert into qprofiles" + + "where not exists ( select qp.uuid from org_qprofiles qp where qp.uuid = p.kee and qp.organization_uuid = p.organization_uuid )"); + massUpdate.update("insert into org_qprofiles" + " (uuid, organization_uuid, rules_profile_uuid, parent_uuid, created_at, updated_at) values (?, ?, ?, ?, ?, ?)"); - massUpdate.rowPluralName("qprofiles"); + massUpdate.rowPluralName("org_qprofiles"); massUpdate.execute((row, update) -> { - update.setString(1, row.getString(1)); - update.setString(2, row.getString(2)); - update.setString(3, row.getString(1)); - update.setString(4, row.getString(3)); + String uuid = row.getString(1); + String organizationUuid = row.getString(2); + String parentUuid = row.getString(3); + + update.setString(1, uuid); + update.setString(2, organizationUuid); + update.setString(3, uuid); + update.setString(4, parentUuid); update.setLong(5, now); update.setLong(6, now); return true; diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfilesTest.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfilesTest.java index 6ad59c3fdc5..d44d46715df 100644 --- a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfilesTest.java +++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfilesTest.java @@ -29,16 +29,16 @@ import org.sonar.db.CoreDbTester; import static org.assertj.core.api.Assertions.assertThat; -public class CreateTableQProfilesTest { +public class CreateTableOrgQProfilesTest { - private static final String TABLE = "qprofiles"; + private static final String TABLE = "org_qprofiles"; @Rule - public final CoreDbTester db = CoreDbTester.createForSchema(CreateTableQProfilesTest.class, "empty.sql"); + public final CoreDbTester db = CoreDbTester.createForSchema(CreateTableOrgQProfilesTest.class, "empty.sql"); @Rule public ExpectedException expectedException = ExpectedException.none(); - private CreateTableQProfiles underTest = new CreateTableQProfiles(db.database()); + private CreateTableOrgQProfiles underTest = new CreateTableOrgQProfiles(db.database()); @Test public void creates_table_on_empty_db() throws SQLException { @@ -47,12 +47,13 @@ public class CreateTableQProfilesTest { assertThat(db.countRowsOfTable(TABLE)).isEqualTo(0); db.assertColumnDefinition(TABLE, "uuid", Types.VARCHAR, 40, false); - db.assertPrimaryKey(TABLE, "pk_qprofiles", "uuid"); + db.assertPrimaryKey(TABLE, "pk_org_qprofiles", "uuid"); db.assertColumnDefinition(TABLE, "organization_uuid", Types.VARCHAR, 40, false); db.assertColumnDefinition(TABLE, "rules_profile_uuid", Types.VARCHAR, 40, false); db.assertColumnDefinition(TABLE, "created_at", Types.BIGINT, null, false); db.assertColumnDefinition(TABLE, "updated_at", Types.BIGINT, null, false); db.assertIndex(TABLE, "qprofiles_org_uuid", "organization_uuid"); + db.assertIndex(TABLE, "qprofiles_rp_uuid", "rules_profile_uuid"); } @Test diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65Test.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65Test.java index a1f026d0fff..e9474738566 100644 --- a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65Test.java +++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DbVersion65Test.java @@ -35,6 +35,6 @@ public class DbVersion65Test { @Test public void verify_migration_count() { - verifyMigrationCount(underTest, 24); + verifyMigrationCount(underTest, 25); } } diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest.java new file mode 100644 index 00000000000..f879628475b --- /dev/null +++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest.java @@ -0,0 +1,43 @@ +/* + * SonarQube + * Copyright (C) 2009-2017 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.server.platform.db.migration.version.v65; + +import java.sql.SQLException; +import org.junit.Rule; +import org.junit.Test; +import org.sonar.db.CoreDbTester; + +public class DropOrgUuidAndParentKeeFromRulesProfilesTest { + + private static final String TABLE_NAME = "rules_profiles"; + + @Rule + public CoreDbTester db = CoreDbTester.createForSchema(DropOrgUuidAndParentKeeFromRulesProfilesTest.class, "initial.sql"); + + private DropOrgUuidAndParentKeeFromRulesProfiles underTest = new DropOrgUuidAndParentKeeFromRulesProfiles(db.database()); + + @Test + public void columns_are_dropped() throws SQLException { + underTest.execute(); + + db.assertColumnDoesNotExist(TABLE_NAME, "organization_uuid"); + db.assertColumnDoesNotExist(TABLE_NAME, "parent_kee"); + } +} diff --git a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/PopulateQProfilesTest.java b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfilesTest.java index b4fb5dc578c..301fefc0e21 100644 --- a/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/PopulateQProfilesTest.java +++ b/server/sonar-db-migration/src/test/java/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfilesTest.java @@ -35,16 +35,16 @@ import static java.lang.String.format; import static org.assertj.core.api.Assertions.assertThat; -public class PopulateQProfilesTest { +public class PopulateOrgQProfilesTest { @Rule public ExpectedException expectedException = ExpectedException.none(); @Rule - public CoreDbTester db = CoreDbTester.createForSchema(PopulateQProfilesTest.class, "initial.sql"); + public CoreDbTester db = CoreDbTester.createForSchema(PopulateOrgQProfilesTest.class, "initial.sql"); private System2 system2 = new AlwaysIncreasingSystem2(); - private PopulateQProfiles underTest = new PopulateQProfiles(db.database(), system2); + private PopulateOrgQProfiles underTest = new PopulateOrgQProfiles(db.database(), system2); @Test public void migration_is_reentrant() throws SQLException { @@ -52,13 +52,13 @@ public class PopulateQProfilesTest { insertRulesProfile("ORG_2", "js", "u2", "u1", true); // org1 is already processed - insertQProfile("u1", "ORG_1", "RPU1"); + insertOrgQProfile("u1", "ORG_1", "RPU1"); underTest.execute(); assertThat(countRows()).isEqualTo(2); - Map<String, Object> qprofile1 = selectQProfile("u1", "ORG_1"); - Map<String, Object> qprofile2 = selectQProfile("u2", "ORG_2"); + Map<String, Object> qprofile1 = selectOrgQProfile("u1", "ORG_1"); + Map<String, Object> qprofile2 = selectOrgQProfile("u2", "ORG_2"); assertThat(qprofile1.get("UUID")).isEqualTo("u1"); assertThat(qprofile1.get("ORGANIZATION_UUID")).isEqualTo("ORG_1"); @@ -86,7 +86,7 @@ public class PopulateQProfilesTest { private int countRows() { - return db.countRowsOfTable("qprofiles"); + return db.countRowsOfTable("org_qprofiles"); } private void insertRulesProfile(String orgUuid, String language, String uuid, String parentKee, boolean isDefault) { @@ -100,8 +100,8 @@ public class PopulateQProfilesTest { "IS_BUILT_IN", true); } - private void insertQProfile(String uuid, String orgUuid, String rulesProfileUuid) { - db.executeInsert("QPROFILES", + private void insertOrgQProfile(String uuid, String orgUuid, String rulesProfileUuid) { + db.executeInsert("ORG_QPROFILES", "ORGANIZATION_UUID", orgUuid, "RULES_PROFILE_UUID", rulesProfileUuid, "UUID", uuid, @@ -110,7 +110,7 @@ public class PopulateQProfilesTest { ); } - private Map<String, Object> selectQProfile(String uuid, String orgUuid) { - return db.selectFirst(format("select * from qprofiles where uuid='%s' and organization_uuid='%s'", uuid, orgUuid)); + private Map<String, Object> selectOrgQProfile(String uuid, String orgUuid) { + return db.selectFirst(format("select * from org_qprofiles where uuid='%s' and organization_uuid='%s'", uuid, orgUuid)); } } diff --git a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfilesTest/empty.sql b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfilesTest/empty.sql index e69de29bb2d..e69de29bb2d 100644 --- a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/CreateTableQProfilesTest/empty.sql +++ b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/CreateTableOrgQProfilesTest/empty.sql diff --git a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest/initial.sql b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest/initial.sql new file mode 100644 index 00000000000..7c1c1fedab0 --- /dev/null +++ b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/DropOrgUuidAndParentKeeFromRulesProfilesTest/initial.sql @@ -0,0 +1,15 @@ +CREATE TABLE "RULES_PROFILES" ( + "ID" INTEGER NOT NULL GENERATED BY DEFAULT AS IDENTITY (START WITH 1, INCREMENT BY 1), + "NAME" VARCHAR(100) NOT NULL, + "LANGUAGE" VARCHAR(20), + "ORGANIZATION_UUID" VARCHAR(40) NOT NULL, + "KEE" VARCHAR(255) NOT NULL, + "PARENT_KEE" VARCHAR(255), + "RULES_UPDATED_AT" VARCHAR(100), + "CREATED_AT" TIMESTAMP, + "UPDATED_AT" TIMESTAMP, + "LAST_USED" BIGINT, + "USER_UPDATED_AT" BIGINT, + "IS_BUILT_IN" BOOLEAN NOT NULL +); +CREATE UNIQUE INDEX "UNIQ_QPROF_KEY" ON "RULES_PROFILES" ("KEE"); diff --git a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/PopulateQProfilesTest/initial.sql b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfilesTest/initial.sql index df8bf1316ff..3d84b4a125f 100644 --- a/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/PopulateQProfilesTest/initial.sql +++ b/server/sonar-db-migration/src/test/resources/org/sonar/server/platform/db/migration/version/v65/PopulateOrgQProfilesTest/initial.sql @@ -15,7 +15,7 @@ CREATE TABLE "RULES_PROFILES" ( ); CREATE UNIQUE INDEX "UNIQ_QPROF_KEY" ON "RULES_PROFILES" ("KEE"); -CREATE TABLE "QPROFILES" ( +CREATE TABLE "ORG_QPROFILES" ( "UUID" VARCHAR(40) NOT NULL PRIMARY KEY, "ORGANIZATION_UUID" VARCHAR(40) NOT NULL, "RULES_PROFILE_UUID" VARCHAR(40) NOT NULL, @@ -23,4 +23,5 @@ CREATE TABLE "QPROFILES" ( "CREATED_AT" BIGINT NOT NULL, "UPDATED_AT" BIGINT NOT NULL ); -CREATE INDEX "QPROFILES_ORG_UUID" ON "QPROFILES" ("ORGANIZATION_UUID"); +CREATE INDEX "ORG_QPROFILES_ORG_UUID" ON "ORG_QPROFILES" ("ORGANIZATION_UUID"); +CREATE INDEX "ORG_QPROFILES_RP_UUID" ON "ORG_QPROFILES" ("RULES_PROFILE_UUID"); diff --git a/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStep.java b/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStep.java index b10b8745fb8..5898ef8b095 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStep.java +++ b/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStep.java @@ -31,7 +31,7 @@ import org.sonar.core.util.stream.MoreCollectors; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.scanner.protocol.output.ScannerReport; import org.sonar.scanner.protocol.output.ScannerReport.Metadata.QProfile; import org.sonar.server.computation.task.projectanalysis.analysis.MutableAnalysisMetadataHolder; @@ -107,10 +107,10 @@ public class LoadReportAnalysisMetadataHolderStep implements ComputationStep { .map(QProfile::getKey) .collect(toList(metadata.getQprofilesPerLanguage().size())); try (DbSession dbSession = dbClient.openSession(false)) { - List<RulesProfileDto> profiles = dbClient.qualityProfileDao().selectByKeys(dbSession, profileKeys); + List<QProfileDto> profiles = dbClient.qualityProfileDao().selectByUuids(dbSession, profileKeys); String badKeys = profiles.stream() .filter(p -> !p.getOrganizationUuid().equals(organization.getUuid())) - .map(RulesProfileDto::getKee) + .map(QProfileDto::getKee) .collect(MoreCollectors.join(Joiner.on(", "))); if (!badKeys.isEmpty()) { throw MessageException.of(format("Quality profiles with following keys don't exist in organization [%s]: %s", organization.getKey(), badKeys)); diff --git a/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStep.java b/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStep.java index 968e6874896..97aa1f60f7c 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStep.java +++ b/server/sonar-server/src/main/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStep.java @@ -26,7 +26,7 @@ import java.util.Set; import java.util.stream.Collectors; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.computation.task.projectanalysis.analysis.AnalysisMetadataHolder; import org.sonar.server.computation.task.projectanalysis.component.Component; import org.sonar.server.computation.task.projectanalysis.component.TreeRootHolder; @@ -68,7 +68,7 @@ public class UpdateQualityProfilesLastUsedDateStep implements ComputationStep { return; } - List<RulesProfileDto> dtos = dbClient.qualityProfileDao().selectByKeys(dbSession, qualityProfiles.stream().map(QualityProfile::getQpKey).collect(Collectors.toList())); + List<QProfileDto> dtos = dbClient.qualityProfileDao().selectByUuids(dbSession, qualityProfiles.stream().map(QualityProfile::getQpKey).collect(Collectors.toList())); dtos.addAll(getAncestors(dbSession, dtos)); long analysisDate = analysisMetadataHolder.getAnalysisDate(); dtos.forEach(dto -> { @@ -80,16 +80,16 @@ public class UpdateQualityProfilesLastUsedDateStep implements ComputationStep { } } - private List<RulesProfileDto> getAncestors(DbSession dbSession, List<RulesProfileDto> dtos) { - List<RulesProfileDto> ancestors = new ArrayList<>(); + private List<QProfileDto> getAncestors(DbSession dbSession, List<QProfileDto> dtos) { + List<QProfileDto> ancestors = new ArrayList<>(); dtos.forEach(dto -> incrementAncestors(dbSession, dto, ancestors)); return ancestors; } - private void incrementAncestors(DbSession session, RulesProfileDto profile, List<RulesProfileDto> ancestors) { + private void incrementAncestors(DbSession session, QProfileDto profile, List<QProfileDto> ancestors) { String parentKey = profile.getParentKee(); if (parentKey != null) { - RulesProfileDto parentDto = dbClient.qualityProfileDao().selectOrFailByKey(session, parentKey); + QProfileDto parentDto = dbClient.qualityProfileDao().selectOrFailByUuid(session, parentKey); ancestors.add(parentDto); incrementAncestors(session, parentDto, ancestors); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/organization/ws/DeleteAction.java b/server/sonar-server/src/main/java/org/sonar/server/organization/ws/DeleteAction.java index 5d11c6a0988..4b5d1cb9ae3 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/organization/ws/DeleteAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/organization/ws/DeleteAction.java @@ -28,7 +28,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.component.ComponentCleanerService; import org.sonar.server.organization.DefaultOrganization; import org.sonar.server.organization.DefaultOrganizationProvider; @@ -134,9 +134,9 @@ public class DeleteAction implements OrganizationsWsAction { } private void deleteQualityProfiles(DbSession dbSession, OrganizationDto organization) { - List<RulesProfileDto> profiles = dbClient.qualityProfileDao().selectAll(dbSession, organization); + List<QProfileDto> profiles = dbClient.qualityProfileDao().selectAll(dbSession, organization); List<String> profileKeys = profiles.stream() - .map(RulesProfileDto::getKee) + .map(QProfileDto::getKee) .collect(MoreCollectors.toArrayList(profiles.size())); qProfileFactory.deleteByKeys(dbSession, profileKeys); dbSession.commit(); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/BuiltInQProfileInsertImpl.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/BuiltInQProfileInsertImpl.java index 532b81ed0eb..67d3b61a3a2 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/BuiltInQProfileInsertImpl.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/BuiltInQProfileInsertImpl.java @@ -47,7 +47,7 @@ import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; import org.sonar.db.qualityprofile.DefaultQProfileDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleParamDto; import org.sonar.server.util.TypeValidations; @@ -75,7 +75,7 @@ public class BuiltInQProfileInsertImpl implements BuiltInQProfileInsert { initRuleRepository(batchSession); Date now = new Date(system2.now()); - RulesProfileDto profileDto = insertQualityProfile(session, builtInQProfile, organization, now); + QProfileDto profileDto = insertQualityProfile(session, builtInQProfile, organization, now); List<ActiveRuleChange> localChanges = builtInQProfile.getActiveRules() .stream() @@ -91,8 +91,8 @@ public class BuiltInQProfileInsertImpl implements BuiltInQProfileInsert { } } - private RulesProfileDto insertQualityProfile(DbSession dbSession, BuiltInQProfile builtInQProfile, OrganizationDto organization, Date now) { - RulesProfileDto profileDto = RulesProfileDto.createFor(uuidFactory.create()) + private QProfileDto insertQualityProfile(DbSession dbSession, BuiltInQProfile builtInQProfile, OrganizationDto organization, Date now) { + QProfileDto profileDto = QProfileDto.createFor(uuidFactory.create()) .setName(builtInQProfile.getName()) .setOrganizationUuid(organization.getUuid()) .setLanguage(builtInQProfile.getLanguage()) @@ -105,7 +105,7 @@ public class BuiltInQProfileInsertImpl implements BuiltInQProfileInsert { return profileDto; } - private ActiveRuleChange insertActiveRule(DbSession session, RulesProfileDto profileDto, org.sonar.api.rules.ActiveRule activeRule, long now) { + private ActiveRuleChange insertActiveRule(DbSession session, QProfileDto profileDto, org.sonar.api.rules.ActiveRule activeRule, long now) { RuleKey ruleKey = RuleKey.of(activeRule.getRepositoryKey(), activeRule.getRuleKey()); RuleDefinitionDto ruleDefinitionDto = ruleRepository.getDefinition(ruleKey) .orElseThrow(() -> new IllegalStateException("RuleDefinition not found for key " + ruleKey)); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuper.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuper.java index c641c53ed20..59feac2b206 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuper.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuper.java @@ -24,14 +24,14 @@ import java.io.Writer; import javax.annotation.Nullable; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; /** * Backup and restore a Quality profile. */ public interface QProfileBackuper { - void backup(DbSession dbSession, RulesProfileDto profile, Writer backupWriter); + void backup(DbSession dbSession, QProfileDto profile, Writer backupWriter); /** * Restore backup on a profile in the specified organization. The parameter {@code overriddenProfileName} @@ -43,5 +43,5 @@ public interface QProfileBackuper { /** * Restore backup on an existing profile. */ - QProfileRestoreSummary restore(DbSession dbSession, Reader backup, RulesProfileDto profile); + QProfileRestoreSummary restore(DbSession dbSession, Reader backup, QProfileDto profile); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuperImpl.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuperImpl.java index 69411175cd8..24e72bc5558 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuperImpl.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileBackuperImpl.java @@ -47,7 +47,7 @@ import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static com.google.common.base.Preconditions.checkArgument; @@ -82,13 +82,13 @@ public class QProfileBackuperImpl implements QProfileBackuper { } @Override - public void backup(DbSession dbSession, RulesProfileDto profileDto, Writer writer) { + public void backup(DbSession dbSession, QProfileDto profileDto, Writer writer) { List<ActiveRuleDto> activeRules = db.activeRuleDao().selectByProfileKey(dbSession, profileDto.getKee()); activeRules.sort(BackupActiveRuleComparator.INSTANCE); writeXml(dbSession, writer, profileDto, activeRules.iterator()); } - private void writeXml(DbSession dbSession, Writer writer, RulesProfileDto profile, Iterator<ActiveRuleDto> activeRules) { + private void writeXml(DbSession dbSession, Writer writer, QProfileDto profile, Iterator<ActiveRuleDto> activeRules) { XmlWriter xml = XmlWriter.of(writer).declaration(); xml.begin(ATTRIBUTE_PROFILE); xml.prop(ATTRIBUTE_NAME, profile.getName()); @@ -126,7 +126,7 @@ public class QProfileBackuperImpl implements QProfileBackuper { } @Override - public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, RulesProfileDto profile) { + public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, QProfileDto profile) { return restore(dbSession, backup, nameInBackup -> { checkArgument(profile.getLanguage().equals(nameInBackup.getLanguage()), "Can't restore %s backup on %s profile with key [%s]. Languages are different.", nameInBackup.getLanguage(), profile.getLanguage(), profile.getKee()); @@ -134,7 +134,7 @@ public class QProfileBackuperImpl implements QProfileBackuper { }); } - private QProfileRestoreSummary restore(DbSession dbSession, Reader backup, Function<QProfileName, RulesProfileDto> profileLoader) { + private QProfileRestoreSummary restore(DbSession dbSession, Reader backup, Function<QProfileName, QProfileDto> profileLoader) { try { String profileLang = null; String profileName = null; @@ -161,7 +161,7 @@ public class QProfileBackuperImpl implements QProfileBackuper { } QProfileName targetName = new QProfileName(profileLang, profileName); - RulesProfileDto targetProfile = profileLoader.apply(targetName); + QProfileDto targetProfile = profileLoader.apply(targetName); BulkChangeResult changes = profileReset.reset(dbSession, targetProfile, ruleActivations); return new QProfileRestoreSummary(targetProfile, changes); } catch (XMLStreamException e) { diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileComparison.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileComparison.java index 3d316f432aa..8a995cbb048 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileComparison.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileComparison.java @@ -36,7 +36,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; @ServerSide @ComputeEngineSide @@ -48,7 +48,7 @@ public class QProfileComparison { this.dbClient = dbClient; } - public QProfileComparisonResult compare(DbSession dbSession, RulesProfileDto left, RulesProfileDto right) { + public QProfileComparisonResult compare(DbSession dbSession, QProfileDto left, QProfileDto right) { Map<RuleKey, ActiveRuleDto> leftActiveRulesByRuleKey = loadActiveRules(dbSession, left); Map<RuleKey, ActiveRuleDto> rightActiveRulesByRuleKey = loadActiveRules(dbSession, right); @@ -86,29 +86,29 @@ public class QProfileComparison { } } - private Map<RuleKey, ActiveRuleDto> loadActiveRules(DbSession session, RulesProfileDto profile) { + private Map<RuleKey, ActiveRuleDto> loadActiveRules(DbSession session, QProfileDto profile) { return Maps.uniqueIndex(dbClient.activeRuleDao().selectByProfileKey(session, profile.getKee()), ActiveRuleToRuleKey.INSTANCE); } public static class QProfileComparisonResult { - private final RulesProfileDto left; - private final RulesProfileDto right; + private final QProfileDto left; + private final QProfileDto right; private final Map<RuleKey, ActiveRuleDto> inLeft = Maps.newHashMap(); private final Map<RuleKey, ActiveRuleDto> inRight = Maps.newHashMap(); private final Map<RuleKey, ActiveRuleDiff> modified = Maps.newHashMap(); private final Map<RuleKey, ActiveRuleDto> same = Maps.newHashMap(); - public QProfileComparisonResult(RulesProfileDto left, RulesProfileDto right) { + public QProfileComparisonResult(QProfileDto left, QProfileDto right) { this.left = left; this.right = right; } - public RulesProfileDto left() { + public QProfileDto left() { return left; } - public RulesProfileDto right() { + public QProfileDto right() { return right; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileCopier.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileCopier.java index 8403b749d6f..b2fd1a69879 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileCopier.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileCopier.java @@ -32,7 +32,7 @@ import org.sonar.api.utils.TempFolder; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static java.nio.charset.StandardCharsets.UTF_8; @@ -51,10 +51,10 @@ public class QProfileCopier { this.temp = temp; } - public RulesProfileDto copyToName(DbSession dbSession, RulesProfileDto sourceProfile, String toName) { + public QProfileDto copyToName(DbSession dbSession, QProfileDto sourceProfile, String toName) { OrganizationDto organization = db.organizationDao().selectByUuid(dbSession, sourceProfile.getOrganizationUuid()) .orElseThrow(() -> new IllegalStateException("Organization with UUID [" + sourceProfile.getOrganizationUuid() + "] does not exist")); - RulesProfileDto to = prepareTarget(dbSession, organization, sourceProfile, toName); + QProfileDto to = prepareTarget(dbSession, organization, sourceProfile, toName); File backupFile = temp.newFile(); try { backup(dbSession, sourceProfile, backupFile); @@ -65,10 +65,10 @@ public class QProfileCopier { } } - private RulesProfileDto prepareTarget(DbSession dbSession, OrganizationDto organization, RulesProfileDto sourceProfile, String toName) { + private QProfileDto prepareTarget(DbSession dbSession, OrganizationDto organization, QProfileDto sourceProfile, String toName) { QProfileName toProfileName = new QProfileName(sourceProfile.getLanguage(), toName); verify(sourceProfile, toProfileName); - RulesProfileDto toProfile = db.qualityProfileDao().selectByNameAndLanguage(organization, toProfileName.getName(), toProfileName.getLanguage(), dbSession); + QProfileDto toProfile = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, toProfileName.getName(), toProfileName.getLanguage()); if (toProfile == null) { toProfile = factory.checkAndCreateCustom(dbSession, organization, toProfileName); toProfile.setParentKee(sourceProfile.getParentKee()); @@ -78,7 +78,7 @@ public class QProfileCopier { return toProfile; } - private void verify(RulesProfileDto fromProfile, QProfileName toProfileName) { + private void verify(QProfileDto fromProfile, QProfileName toProfileName) { if (!StringUtils.equals(fromProfile.getLanguage(), toProfileName.getLanguage())) { throw new IllegalArgumentException(String.format( "Source and target profiles do not have the same language: %s and %s", @@ -90,7 +90,7 @@ public class QProfileCopier { } } - private void backup(DbSession dbSession, RulesProfileDto profile, File backupFile) { + private void backup(DbSession dbSession, QProfileDto profile, File backupFile) { try (Writer writer = new OutputStreamWriter(FileUtils.openOutputStream(backupFile), UTF_8)) { backuper.backup(dbSession, profile, writer); } catch (IOException e) { @@ -98,7 +98,7 @@ public class QProfileCopier { } } - private void restore(DbSession dbSession, File backupFile, RulesProfileDto profile) { + private void restore(DbSession dbSession, File backupFile, QProfileDto profile) { try (Reader reader = new InputStreamReader(FileUtils.openInputStream(backupFile), UTF_8)) { backuper.restore(dbSession, reader, profile); } catch (IOException e) { diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileExporters.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileExporters.java index 89f328d0a53..fc21a733039 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileExporters.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileExporters.java @@ -44,7 +44,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.exceptions.NotFoundException; @@ -103,12 +103,12 @@ public class QProfileExporters { return exporter.getMimeType(); } - public void export(RulesProfileDto profile, String exporterKey, Writer writer) { + public void export(QProfileDto profile, String exporterKey, Writer writer) { ProfileExporter exporter = findExporter(exporterKey); exporter.exportProfile(wrap(profile), writer); } - private RulesProfile wrap(RulesProfileDto profile) { + private RulesProfile wrap(QProfileDto profile) { try (DbSession dbSession = dbClient.openSession(false)) { RulesProfile target = new RulesProfile(profile.getName(), profile.getLanguage()); List<ActiveRuleDto> activeRuleDtos = dbClient.activeRuleDao().selectByProfileKey(dbSession, profile.getKee()); @@ -137,11 +137,11 @@ public class QProfileExporters { throw new NotFoundException("Unknown quality profile exporter: " + exporterKey); } - public QProfileResult importXml(RulesProfileDto profileDto, String importerKey, InputStream xml, DbSession dbSession) { + public QProfileResult importXml(QProfileDto profileDto, String importerKey, InputStream xml, DbSession dbSession) { return importXml(profileDto, importerKey, new InputStreamReader(xml, StandardCharsets.UTF_8), dbSession); } - private QProfileResult importXml(RulesProfileDto profileDto, String importerKey, Reader xml, DbSession dbSession) { + private QProfileResult importXml(QProfileDto profileDto, String importerKey, Reader xml, DbSession dbSession) { QProfileResult result = new QProfileResult(); ValidationMessages messages = ValidationMessages.create(); ProfileImporter importer = getProfileImporter(importerKey); @@ -152,7 +152,7 @@ public class QProfileExporters { return result; } - private List<ActiveRuleChange> importProfile(RulesProfileDto profileDto, RulesProfile rulesProfile, DbSession dbSession) { + private List<ActiveRuleChange> importProfile(QProfileDto profileDto, RulesProfile rulesProfile, DbSession dbSession) { List<ActiveRuleChange> changes = new ArrayList<>(); for (org.sonar.api.rules.ActiveRule activeRule : rulesProfile.getActiveRules()) { changes.addAll(ruleActivator.activate(dbSession, toRuleActivation(activeRule), profileDto)); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileFactory.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileFactory.java index 0236aa15972..442dc90a98c 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileFactory.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileFactory.java @@ -30,7 +30,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.DefaultQProfileDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.qualityprofile.index.ActiveRuleIndexer; @@ -61,9 +61,9 @@ public class QProfileFactory { return organization; } - RulesProfileDto getOrCreateCustom(DbSession dbSession, OrganizationDto organization, QProfileName name) { + QProfileDto getOrCreateCustom(DbSession dbSession, OrganizationDto organization, QProfileName name) { requireNonNull(organization); - RulesProfileDto profile = db.qualityProfileDao().selectByNameAndLanguage(organization, name.getName(), name.getLanguage(), dbSession); + QProfileDto profile = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, name.getName(), name.getLanguage()); if (profile == null) { profile = doCreate(dbSession, organization, name, false, false); } else { @@ -78,9 +78,9 @@ public class QProfileFactory { * * @throws BadRequestException if a quality profile with the specified name already exists */ - public RulesProfileDto checkAndCreateCustom(DbSession dbSession, OrganizationDto organization, QProfileName name) { + public QProfileDto checkAndCreateCustom(DbSession dbSession, OrganizationDto organization, QProfileName name) { requireNonNull(organization); - RulesProfileDto dto = db.qualityProfileDao().selectByNameAndLanguage(organization, name.getName(), name.getLanguage(), dbSession); + QProfileDto dto = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, name.getName(), name.getLanguage()); checkRequest(dto == null, "Quality profile already exists: %s", name); return doCreate(dbSession, organization, name, false, false); } @@ -90,16 +90,16 @@ public class QProfileFactory { * * A DB error will be thrown if the quality profile already exists. */ - public RulesProfileDto createBuiltIn(DbSession dbSession, OrganizationDto organization, QProfileName name, boolean isDefault) { + public QProfileDto createBuiltIn(DbSession dbSession, OrganizationDto organization, QProfileName name, boolean isDefault) { return doCreate(dbSession, requireNonNull(organization), name, isDefault, true); } - private RulesProfileDto doCreate(DbSession dbSession, OrganizationDto organization, QProfileName name, boolean isDefault, boolean isBuiltIn) { + private QProfileDto doCreate(DbSession dbSession, OrganizationDto organization, QProfileName name, boolean isDefault, boolean isBuiltIn) { if (StringUtils.isEmpty(name.getName())) { throw BadRequestException.create("quality_profiles.profile_name_cant_be_blank"); } Date now = new Date(system2.now()); - RulesProfileDto dto = RulesProfileDto.createFor(uuidFactory.create()) + QProfileDto dto = QProfileDto.createFor(uuidFactory.create()) .setName(name.getName()) .setOrganizationUuid(organization.getUuid()) .setLanguage(name.getLanguage()) @@ -120,16 +120,16 @@ public class QProfileFactory { * are deleted too. Deleting a parent profile does not delete descendants * if their keys are not listed. */ - public void deleteByKeys(DbSession dbSession, Collection<String> profileKeys) { - if (!profileKeys.isEmpty()) { - db.qualityProfileDao().deleteProjectAssociationsByProfileKeys(dbSession, profileKeys); - db.activeRuleDao().deleteParametersByProfileKeys(dbSession, profileKeys); - db.activeRuleDao().deleteByProfileKeys(dbSession, profileKeys); - db.qProfileChangeDao().deleteByProfileKeys(dbSession, profileKeys); - db.defaultQProfileDao().deleteByQProfileUuids(dbSession, profileKeys); - db.qualityProfileDao().deleteByKeys(dbSession, profileKeys); + public void deleteByKeys(DbSession dbSession, Collection<String> profileUuids) { + if (!profileUuids.isEmpty()) { + db.qualityProfileDao().deleteProjectAssociationsByProfileUuids(dbSession, profileUuids); + db.activeRuleDao().deleteParametersByProfileKeys(dbSession, profileUuids); + db.activeRuleDao().deleteByProfileKeys(dbSession, profileUuids); + db.qProfileChangeDao().deleteByProfileKeys(dbSession, profileUuids); + db.defaultQProfileDao().deleteByQProfileUuids(dbSession, profileUuids); + db.qualityProfileDao().deleteByUuids(dbSession, profileUuids); dbSession.commit(); - activeRuleIndexer.deleteByProfileKeys(profileKeys); + activeRuleIndexer.deleteByProfileKeys(profileUuids); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileLookup.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileLookup.java index db29f0ebe3c..77a7c5a6d0c 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileLookup.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileLookup.java @@ -19,12 +19,13 @@ */ package org.sonar.server.qualityprofile; +import java.util.Collection; import java.util.List; import org.sonar.api.server.ServerSide; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static com.google.common.collect.Lists.newArrayList; @@ -37,23 +38,23 @@ public class QProfileLookup { this.db = db; } - public List<RulesProfileDto> allProfiles(DbSession dbSession, OrganizationDto organization) { + public List<QProfileDto> allProfiles(DbSession dbSession, OrganizationDto organization) { return db.qualityProfileDao().selectAll(dbSession, organization); } - public List<RulesProfileDto> profiles(DbSession dbSession, String language, OrganizationDto organization) { + public Collection<QProfileDto> profiles(DbSession dbSession, String language, OrganizationDto organization) { return db.qualityProfileDao().selectByLanguage(dbSession, organization, language); } - public List<RulesProfileDto> ancestors(RulesProfileDto profile, DbSession session) { - List<RulesProfileDto> ancestors = newArrayList(); + public List<QProfileDto> ancestors(QProfileDto profile, DbSession session) { + List<QProfileDto> ancestors = newArrayList(); incrementAncestors(profile, ancestors, session); return ancestors; } - private void incrementAncestors(RulesProfileDto profile, List<RulesProfileDto> ancestors, DbSession session) { + private void incrementAncestors(QProfileDto profile, List<QProfileDto> ancestors, DbSession session) { if (profile.getParentKee() != null) { - RulesProfileDto parentDto = db.qualityProfileDao().selectByKey(session, profile.getParentKee()); + QProfileDto parentDto = db.qualityProfileDao().selectByUuid(session, profile.getParentKee()); if (parentDto == null) { throw new IllegalStateException("Cannot find parent of profile : " + profile.getId()); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileReset.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileReset.java index 97d8ecea193..280cd87062f 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileReset.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileReset.java @@ -21,12 +21,12 @@ package org.sonar.server.qualityprofile; import java.util.Collection; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; public interface QProfileReset { /** * Reset the rules of the specified profile. */ - BulkChangeResult reset(DbSession dbSession, RulesProfileDto profile, Collection<RuleActivation> activations); + BulkChangeResult reset(DbSession dbSession, QProfileDto profile, Collection<RuleActivation> activations); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResetImpl.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResetImpl.java index b4ae1d524cf..91cf16697c8 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResetImpl.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResetImpl.java @@ -30,7 +30,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.qualityprofile.index.ActiveRuleIndexer; @@ -51,7 +51,7 @@ public class QProfileResetImpl implements QProfileReset { } @Override - public BulkChangeResult reset(DbSession dbSession, RulesProfileDto profile, Collection<RuleActivation> activations) { + public BulkChangeResult reset(DbSession dbSession, QProfileDto profile, Collection<RuleActivation> activations) { requireNonNull(profile.getId(), "Quality profile must be persisted"); checkArgument(!profile.isBuiltIn(), "Operation forbidden for built-in Quality Profile '%s'", profile.getKee()); BulkChangeResult result = new BulkChangeResult(); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileRestoreSummary.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileRestoreSummary.java index b2d92b0a020..a78cd23a779 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileRestoreSummary.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileRestoreSummary.java @@ -19,20 +19,20 @@ */ package org.sonar.server.qualityprofile; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static java.util.Objects.requireNonNull; public final class QProfileRestoreSummary { - private final RulesProfileDto profile; + private final QProfileDto profile; private final BulkChangeResult ruleChanges; - public QProfileRestoreSummary(RulesProfileDto profile, BulkChangeResult ruleChanges) { + public QProfileRestoreSummary(QProfileDto profile, BulkChangeResult ruleChanges) { this.profile = requireNonNull(profile); this.ruleChanges = requireNonNull(ruleChanges); } - public RulesProfileDto getProfile() { + public QProfileDto getProfile() { return profile; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResult.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResult.java index bac92ad579d..39261221e64 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResult.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/QProfileResult.java @@ -21,14 +21,14 @@ package org.sonar.server.qualityprofile; import java.util.ArrayList; import java.util.List; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; public class QProfileResult { private List<String> warnings; private List<String> infos; - private RulesProfileDto profile; + private QProfileDto profile; private List<ActiveRuleChange> changes; @@ -56,11 +56,11 @@ public class QProfileResult { return this; } - public RulesProfileDto profile() { + public QProfileDto profile() { return profile; } - public QProfileResult setProfile(RulesProfileDto profile) { + public QProfileResult setProfile(QProfileDto profile) { this.profile = profile; return this; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RegisterQualityProfiles.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RegisterQualityProfiles.java index 544dd0385be..945fed7c534 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RegisterQualityProfiles.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RegisterQualityProfiles.java @@ -104,12 +104,12 @@ public class RegisterQualityProfiles { * built-in profile "Sonar way", which has probably different configuration. */ private void renameOutdatedProfiles(DbSession dbSession, BuiltInQProfile profile) { - Collection<String> profileKeys = dbClient.qualityProfileDao().selectOutdatedProfiles(dbSession, profile.getLanguage(), profile.getName()); - if (profileKeys.isEmpty()) { + Collection<String> uuids = dbClient.qualityProfileDao().selectUuidsOfCustomRulesProfiles(dbSession, profile.getLanguage(), profile.getName()); + if (uuids.isEmpty()) { return; } String newName = profile.getName() + " (outdated copy)"; - LOGGER.info("Rename Quality profiles [{}/{}] to [{}] in {}Â organizations", profile.getLanguage(), profile.getName(), newName, profileKeys.size()); - dbClient.qualityProfileDao().renameAndCommit(dbSession, profileKeys, newName); + LOGGER.info("Rename Quality profiles [{}/{}] to [{}] in {}Â organizations", profile.getLanguage(), profile.getName(), newName, uuids.size()); + dbClient.qualityProfileDao().renameRulesProfilesAndCommit(dbSession, uuids, newName); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivator.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivator.java index 82b40aa1385..ae0c7c2fd69 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivator.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivator.java @@ -38,7 +38,7 @@ import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleParamDto; import org.sonar.server.exceptions.BadRequestException; @@ -82,7 +82,7 @@ public class RuleActivator { return doActivate(dbSession, activation, context); } - public List<ActiveRuleChange> activate(DbSession dbSession, RuleActivation activation, RulesProfileDto profileDto) { + public List<ActiveRuleChange> activate(DbSession dbSession, RuleActivation activation, QProfileDto profileDto) { RuleActivatorContext context = contextFactory.create(profileDto, activation.getRuleKey(), dbSession); return doActivate(dbSession, activation, context); } @@ -146,7 +146,7 @@ public class RuleActivator { } private void updateProfileDates(DbSession dbSession, RuleActivatorContext context) { - RulesProfileDto profile = context.profile(); + QProfileDto profile = context.profile(); profile.setRulesUpdatedAtAsDate(context.getInitDate()); if (userSession.isLoggedIn()) { profile.setUserUpdatedAt(context.getInitDate().getTime()); @@ -224,20 +224,20 @@ public class RuleActivator { return null; } - private List<ActiveRuleChange> cascadeActivation(DbSession session, RuleActivation activation, RulesProfileDto rulesProfileDto) { + private List<ActiveRuleChange> cascadeActivation(DbSession session, RuleActivation activation, QProfileDto qProfileDto) { List<ActiveRuleChange> changes = Lists.newArrayList(); // get all inherited profiles - String qualityProfileKey = rulesProfileDto.getKee(); - List<RulesProfileDto> children = getChildren(session, qualityProfileKey); - for (RulesProfileDto child : children) { + String qualityProfileKey = qProfileDto.getKee(); + List<QProfileDto> children = getChildren(session, qualityProfileKey); + for (QProfileDto child : children) { RuleActivation childActivation = new RuleActivation(activation).setCascade(true); changes.addAll(activate(session, childActivation, child)); } return changes; } - protected List<RulesProfileDto> getChildren(DbSession session, String qualityProfileKey) { + protected List<QProfileDto> getChildren(DbSession session, String qualityProfileKey) { return db.qualityProfileDao().selectChildren(session, qualityProfileKey); } @@ -370,9 +370,9 @@ public class RuleActivator { persist(change, context, dbSession); // get all inherited profiles - List<RulesProfileDto> profiles = getChildren(dbSession, key.qProfile()); + List<QProfileDto> profiles = getChildren(dbSession, key.qProfile()); - for (RulesProfileDto profile : profiles) { + for (QProfileDto profile : profiles) { ActiveRuleKey activeRuleKey = ActiveRuleKey.of(profile.getKee(), key.ruleKey()); changes.addAll(cascadeDeactivation(activeRuleKey, dbSession, true, force)); } @@ -457,14 +457,14 @@ public class RuleActivator { } public List<ActiveRuleChange> setParent(DbSession dbSession, String profileKey, @Nullable String parentKey) { - RulesProfileDto profile = db.qualityProfileDao().selectOrFailByKey(dbSession, profileKey); + QProfileDto profile = db.qualityProfileDao().selectOrFailByUuid(dbSession, profileKey); List<ActiveRuleChange> changes = new ArrayList<>(); if (parentKey == null) { // unset if parent is defined, else nothing to do changes.addAll(removeParent(dbSession, profile)); } else if (profile.getParentKee() == null || !parentKey.equals(profile.getParentKee())) { - RulesProfileDto parentProfile = db.qualityProfileDao().selectOrFailByKey(dbSession, parentKey); + QProfileDto parentProfile = db.qualityProfileDao().selectOrFailByUuid(dbSession, parentKey); checkRequest(!isDescendant(dbSession, profile, parentProfile), "Descendant profile '%s' can not be selected as parent of '%s'", parentKey, profileKey); changes.addAll(removeParent(dbSession, profile)); @@ -489,7 +489,7 @@ public class RuleActivator { /** * Does not commit */ - private List<ActiveRuleChange> removeParent(DbSession dbSession, RulesProfileDto profileDto) { + private List<ActiveRuleChange> removeParent(DbSession dbSession, QProfileDto profileDto) { if (profileDto.getParentKee() != null) { List<ActiveRuleChange> changes = new ArrayList<>(); profileDto.setParentKee(null); @@ -509,15 +509,15 @@ public class RuleActivator { return Collections.emptyList(); } - boolean isDescendant(DbSession dbSession, RulesProfileDto childProfile, @Nullable RulesProfileDto parentProfile) { - RulesProfileDto currentParent = parentProfile; + boolean isDescendant(DbSession dbSession, QProfileDto childProfile, @Nullable QProfileDto parentProfile) { + QProfileDto currentParent = parentProfile; while (currentParent != null) { if (childProfile.getName().equals(currentParent.getName())) { return true; } String parentKey = currentParent.getParentKee(); if (parentKey != null) { - currentParent = db.qualityProfileDao().selectByKey(dbSession, parentKey); + currentParent = db.qualityProfileDao().selectByUuid(dbSession, parentKey); } else { currentParent = null; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContext.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContext.java index bced651ea9c..4c26b20b50b 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContext.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContext.java @@ -30,7 +30,7 @@ import org.sonar.api.rule.RuleStatus; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleParamDto; @@ -41,7 +41,7 @@ class RuleActivatorContext { private final Date initDate = new Date(); private RuleDefinitionDto rule; private final Map<String, RuleParamDto> ruleParams = Maps.newHashMap(); - private RulesProfileDto profile; + private QProfileDto profile; private ActiveRuleDto activeRule; private ActiveRuleDto parentActiveRule; private final Map<String, ActiveRuleParamDto> activeRuleParams = Maps.newHashMap(); @@ -83,11 +83,11 @@ class RuleActivatorContext { return this; } - RulesProfileDto profile() { + QProfileDto profile() { return profile; } - RuleActivatorContext setProfile(RulesProfileDto profile) { + RuleActivatorContext setProfile(QProfileDto profile) { this.profile = profile; return this; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContextFactory.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContextFactory.java index 8b38d7ed5c0..2e280e1a00c 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContextFactory.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/RuleActivatorContextFactory.java @@ -29,7 +29,7 @@ import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleParamDto; @@ -46,13 +46,13 @@ public class RuleActivatorContextFactory { RuleActivatorContext create(String profileKey, RuleKey ruleKey, DbSession session) { RuleActivatorContext context = new RuleActivatorContext(); - RulesProfileDto profile = getQualityProfileDto(session, profileKey); + QProfileDto profile = getQualityProfileDto(session, profileKey); checkRequest(profile != null, "Quality profile not found: %s", profileKey); context.setProfile(profile); return create(ruleKey, session, context); } - RuleActivatorContext create(RulesProfileDto profile, RuleKey ruleKey, DbSession session) { + RuleActivatorContext create(QProfileDto profile, RuleKey ruleKey, DbSession session) { return create(ruleKey, session, new RuleActivatorContext().setProfile(profile)); } @@ -91,8 +91,8 @@ public class RuleActivatorContextFactory { } } - RulesProfileDto getQualityProfileDto(DbSession session, String profileKey) { - return db.qualityProfileDao().selectByKey(session, profileKey); + QProfileDto getQualityProfileDto(DbSession session, String profileKey) { + return db.qualityProfileDao().selectByUuid(session, profileKey); } Optional<RuleDefinitionDto> getRule(DbSession dbSession, RuleKey ruleKey) { diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleDoc.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleDoc.java index bc84933d319..dac5a26ec57 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleDoc.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleDoc.java @@ -27,10 +27,9 @@ import org.sonar.server.qualityprofile.ActiveRule; import static com.google.common.base.Preconditions.checkNotNull; import static org.apache.commons.lang.StringUtils.containsIgnoreCase; -import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_ORGANIZATION_UUID; -import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_CREATED_AT; import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_INHERITANCE; import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_KEY; +import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_ORGANIZATION_UUID; import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_PROFILE_KEY; import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_REPOSITORY; import static org.sonar.server.rule.index.RuleIndexDefinition.FIELD_ACTIVE_RULE_RULE_KEY; @@ -107,15 +106,6 @@ public class ActiveRuleDoc extends BaseDoc { return this; } - long createdAt() { - return (Long) getField(FIELD_ACTIVE_RULE_CREATED_AT); - } - - public ActiveRuleDoc setCreatedAt(@Nullable Long l) { - setField(FIELD_ACTIVE_RULE_CREATED_AT, l); - return this; - } - long updatedAt() { return (Long) getField(FIELD_ACTIVE_RULE_UPDATED_AT); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIterator.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIterator.java index ac003881fde..c4ef0eb089f 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIterator.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIterator.java @@ -37,21 +37,21 @@ import org.sonar.server.qualityprofile.ActiveRule; public class ActiveRuleResultSetIterator extends ResultSetIterator<ActiveRuleDoc> { private static final String[] FIELDS = { - "a.failure_level", - "a.inheritance", + "ar.failure_level", + "ar.inheritance", "r.plugin_name", "r.plugin_rule_key", - "qp.organization_uuid", - "qp.kee", - "a.created_at", - "a.updated_at" + "oqp.organization_uuid", + "oqp.uuid", + "ar.updated_at" }; - private static final String SQL_ALL = "SELECT " + StringUtils.join(FIELDS, ",") + " FROM active_rules a " + - "INNER JOIN rules_profiles qp ON qp.id=a.profile_id " + - "INNER JOIN rules r ON r.id = a.rule_id"; + private static final String SQL_ALL = "select " + StringUtils.join(FIELDS, ",") + " from active_rules ar " + + " inner join rules_profiles rp on rp.id = ar.profile_id " + + " inner join org_qprofiles oqp on oqp.uuid = rp.kee " + + " inner join rules r on r.id = ar.rule_id "; - private static final String SQL_AFTER_DATE = SQL_ALL + " WHERE a.updated_at>?"; + private static final String SQL_AFTER_DATE = SQL_ALL + " where ar.updated_at>?"; private ActiveRuleResultSetIterator(PreparedStatement stmt) throws SQLException { super(stmt); @@ -86,8 +86,7 @@ public class ActiveRuleResultSetIterator extends ResultSetIterator<ActiveRuleDoc doc.setInheritance(inheritance == null ? ActiveRule.Inheritance.NONE.name() : inheritance); - doc.setCreatedAt(rs.getLong(7)); - doc.setUpdatedAt(rs.getLong(8)); + doc.setUpdatedAt(rs.getLong(7)); return doc; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRuleAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRuleAction.java index ae042d08121..494370f7cc2 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRuleAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRuleAction.java @@ -30,7 +30,7 @@ import org.sonar.api.utils.KeyValueFormat; import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.ActiveRuleChange; import org.sonar.server.qualityprofile.RuleActivation; import org.sonar.server.qualityprofile.RuleActivator; @@ -107,7 +107,7 @@ public class ActivateRuleAction implements QProfileWsAction { String profileKey = request.mandatoryParam(PARAM_PROFILE_KEY); userSession.checkLoggedIn(); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); wsSupport.checkPermission(dbSession, profile); wsSupport.checkNotBuiltInt(profile); List<ActiveRuleChange> changes = ruleActivator.activate(dbSession, activation, profileKey); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRulesAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRulesAction.java index 0afa944d72d..431b262f3ff 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRulesAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ActivateRulesAction.java @@ -26,7 +26,7 @@ import org.sonar.api.server.ws.Response; import org.sonar.api.server.ws.WebService; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.BulkChangeResult; import org.sonar.server.qualityprofile.RuleActivator; import org.sonar.server.rule.ws.RuleQueryFactory; @@ -83,7 +83,7 @@ public class ActivateRulesAction implements QProfileWsAction { userSession.checkLoggedIn(); BulkChangeResult result; try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, fromKey(qualityProfileKey)); + QProfileDto profile = wsSupport.getProfile(dbSession, fromKey(qualityProfileKey)); wsSupport.checkPermission(dbSession, profile); wsSupport.checkNotBuiltInt(profile); result = ruleActivator.bulkActivate(ruleQueryFactory.createRuleQuery(dbSession, request), qualityProfileKey, request.param(SEVERITY)); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/AddProjectAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/AddProjectAction.java index 953a4d1c63a..d0aef49c54e 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/AddProjectAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/AddProjectAction.java @@ -29,7 +29,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.component.ComponentDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.component.ComponentFinder; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.user.UserSession; @@ -81,13 +81,13 @@ public class AddProjectAction implements QProfileWsAction { try (DbSession dbSession = dbClient.openSession(false)) { ComponentDto project = loadProject(dbSession, request); - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); if (!profile.getOrganizationUuid().equals(project.getOrganizationUuid())) { throw new IllegalArgumentException("Project and Quality profile must have same organization"); } - RulesProfileDto currentProfile = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(dbSession, project, profile.getLanguage()); + QProfileDto currentProfile = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(dbSession, project, profile.getLanguage()); if (currentProfile == null) { // project uses the default profile dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, profile); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/BackupAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/BackupAction.java index 925d5a915b0..f1fa2df66a7 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/BackupAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/BackupAction.java @@ -28,7 +28,7 @@ import org.sonar.api.server.ws.WebService; import org.sonar.api.server.ws.WebService.NewAction; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileBackuper; import org.sonarqube.ws.MediaTypes; @@ -69,7 +69,7 @@ public class BackupAction implements QProfileWsAction { try (OutputStreamWriter writer = new OutputStreamWriter(stream.output(), UTF_8); DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); response.setHeader("Content-Disposition", String.format("attachment; filename=%s.xml", profile.getKee())); backuper.backup(dbSession, profile, writer); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangeParentAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangeParentAction.java index 90781127d12..2e97b124011 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangeParentAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangeParentAction.java @@ -28,7 +28,7 @@ import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.RuleActivator; import org.sonar.server.user.UserSession; @@ -85,7 +85,7 @@ public class ChangeParentAction implements QProfileWsAction { QProfileReference reference = QProfileReference.from(request); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, reference); + QProfileDto profile = wsSupport.getProfile(dbSession, reference); String organizationUuid = profile.getOrganizationUuid(); OrganizationDto organization = dbClient.organizationDao().selectByUuid(dbSession, organizationUuid) .orElseThrow(() -> new IllegalStateException(String.format("Could not find organization with uuid '%s' of profile '%s'", organizationUuid, profile.getKee()))); @@ -100,7 +100,7 @@ public class ChangeParentAction implements QProfileWsAction { String parentOrganizationKey = parentKey == null ? organization.getKey() : null; String parentLanguage = parentKey == null ? request.param(PARAM_LANGUAGE) : null; QProfileReference parentRef = QProfileReference.from(parentKey, parentOrganizationKey, parentLanguage, parentName); - RulesProfileDto parent = wsSupport.getProfile(dbSession, parentRef); + QProfileDto parent = wsSupport.getProfile(dbSession, parentRef); ruleActivator.setParent(dbSession, profile.getKee(), parent.getKee()); } response.noContent(); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogAction.java index 972c1d5e582..5d0877f0b6f 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogAction.java @@ -32,7 +32,7 @@ import org.sonar.api.utils.text.JsonWriter; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.QProfileChangeQuery; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static org.sonar.api.utils.DateUtils.parseEndingDateOrDateTime; import static org.sonar.api.utils.DateUtils.parseStartingDateOrDateTime; @@ -84,7 +84,7 @@ public class ChangelogAction implements QProfileWsAction { public void handle(Request request, Response response) throws Exception { QProfileReference reference = QProfileReference.from(request); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, reference); + QProfileDto profile = wsSupport.getProfile(dbSession, reference); QProfileChangeQuery query = new QProfileChangeQuery(profile.getKee()); Date since = parseStartingDateOrDateTime(request.param(PARAM_SINCE)); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogLoader.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogLoader.java index 2a0cf91dfb6..e04b6e121db 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogLoader.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ChangelogLoader.java @@ -58,7 +58,7 @@ public class ChangelogLoader { .collect(MoreCollectors.toList(dtos.size())); completeUserAndRuleNames(dbSession, changes); - int total = dbClient.qProfileChangeDao().countForProfileKey(dbSession, query.getProfileKey()); + int total = dbClient.qProfileChangeDao().countForProfileUuid(dbSession, query.getProfileUuid()); return new Changelog(total, changes); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CompareAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CompareAction.java index aa5dd97602f..6bd6685c4d0 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CompareAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CompareAction.java @@ -39,7 +39,7 @@ import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleRepositoryDto; import org.sonar.server.qualityprofile.QProfileComparison; @@ -104,9 +104,9 @@ public class CompareAction implements QProfileWsAction { String rightKey = request.mandatoryParam(PARAM_RIGHT_KEY); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto left = dbClient.qualityProfileDao().selectByKey(dbSession, leftKey); + QProfileDto left = dbClient.qualityProfileDao().selectByUuid(dbSession, leftKey); checkArgument(left != null, "Could not find left profile '%s'", leftKey); - RulesProfileDto right = dbClient.qualityProfileDao().selectByKey(dbSession, rightKey); + QProfileDto right = dbClient.qualityProfileDao().selectByUuid(dbSession, rightKey); checkArgument(right != null, "Could not find right profile '%s'", rightKey); checkArgument(Objects.equals(left.getOrganizationUuid(), right.getOrganizationUuid()), @@ -148,7 +148,7 @@ public class CompareAction implements QProfileWsAction { json.endObject().close(); } - private void writeProfile(JsonWriter json, RulesProfileDto profile) { + private void writeProfile(JsonWriter json, QProfileDto profile) { json.prop(ATTRIBUTE_KEY, profile.getKee()) .prop(ATTRIBUTE_NAME, profile.getName()); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CopyAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CopyAction.java index 03a6437866f..114f78c5a73 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CopyAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CopyAction.java @@ -29,7 +29,7 @@ import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileCopier; import org.sonar.server.user.UserSession; @@ -79,10 +79,10 @@ public class CopyAction implements QProfileWsAction { String profileKey = request.mandatoryParam(PARAM_PROFILE_KEY); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto sourceProfile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); + QProfileDto sourceProfile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); userSession.checkPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, sourceProfile.getOrganizationUuid()); - RulesProfileDto copiedProfile = profileCopier.copyToName(dbSession, sourceProfile, newName); + QProfileDto copiedProfile = profileCopier.copyToName(dbSession, sourceProfile, newName); boolean isDefault = dbClient.defaultQProfileDao().isDefault(dbSession, copiedProfile.getOrganizationUuid(), copiedProfile.getKee()); String languageKey = copiedProfile.getLanguage(); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CreateAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CreateAction.java index e0a165cef48..d97b94dc620 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CreateAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/CreateAction.java @@ -29,7 +29,7 @@ import org.sonar.api.server.ws.WebService.NewAction; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileExporters; import org.sonar.server.qualityprofile.QProfileFactory; import org.sonar.server.qualityprofile.QProfileName; @@ -123,7 +123,7 @@ public class CreateAction implements QProfileWsAction { private CreateWsResponse doHandle(DbSession dbSession, CreateRequest createRequest, Request request, OrganizationDto organization) { QProfileResult result = new QProfileResult(); - RulesProfileDto profile = profileFactory.checkAndCreateCustom(dbSession, organization, + QProfileDto profile = profileFactory.checkAndCreateCustom(dbSession, organization, QProfileName.createFor(createRequest.getLanguage(), createRequest.getProfileName())); result.setProfile(profile); for (ProfileImporter importer : importers) { diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRuleAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRuleAction.java index 43ae0be68b9..d1344c9d6d2 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRuleAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRuleAction.java @@ -28,7 +28,7 @@ import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleKey; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.RuleActivator; import org.sonar.server.user.UserSession; @@ -76,7 +76,7 @@ public class DeactivateRuleAction implements QProfileWsAction { String qualityProfileKey = request.mandatoryParam(PARAM_PROFILE_KEY); userSession.checkLoggedIn(); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(qualityProfileKey)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(qualityProfileKey)); wsSupport.checkPermission(dbSession, profile); wsSupport.checkNotBuiltInt(profile); ActiveRuleKey activeRuleKey = ActiveRuleKey.of(qualityProfileKey, ruleKey); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRulesAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRulesAction.java index 862be86aa71..aa82dc3615d 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRulesAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeactivateRulesAction.java @@ -25,7 +25,7 @@ import org.sonar.api.server.ws.Response; import org.sonar.api.server.ws.WebService; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.BulkChangeResult; import org.sonar.server.qualityprofile.RuleActivator; import org.sonar.server.rule.ws.RuleQueryFactory; @@ -77,7 +77,7 @@ public class DeactivateRulesAction implements QProfileWsAction { userSession.checkLoggedIn(); BulkChangeResult result; try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(qualityProfileKey)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(qualityProfileKey)); wsSupport.checkPermission(dbSession, profile); wsSupport.checkNotBuiltInt(profile); result = ruleActivator.bulkDeactivate(ruleQueryFactory.createRuleQuery(dbSession, request), qualityProfileKey); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeleteAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeleteAction.java index 8e838d80b79..f88014d8195 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeleteAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/DeleteAction.java @@ -31,7 +31,7 @@ import org.sonar.api.server.ws.WebService.NewController; import org.sonar.core.util.stream.MoreCollectors; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileFactory; import org.sonar.server.user.UserSession; @@ -72,11 +72,11 @@ public class DeleteAction implements QProfileWsAction { userSession.checkLoggedIn(); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); userSession.checkPermission(ADMINISTER_QUALITY_PROFILES, profile.getOrganizationUuid()); wsSupport.checkNotBuiltInt(profile); - List<RulesProfileDto> descendants = selectDescendants(dbSession, profile); + List<QProfileDto> descendants = selectDescendants(dbSession, profile); ensureNoneIsMarkedAsDefault(dbSession, profile, descendants); profileFactory.deleteByKeys(dbSession, toKeys(profile, descendants)); @@ -85,11 +85,11 @@ public class DeleteAction implements QProfileWsAction { response.noContent(); } - private List<RulesProfileDto> selectDescendants(DbSession dbSession, RulesProfileDto profile) { + private List<QProfileDto> selectDescendants(DbSession dbSession, QProfileDto profile) { return dbClient.qualityProfileDao().selectDescendants(dbSession, profile.getKee()); } - private void ensureNoneIsMarkedAsDefault(DbSession dbSession, RulesProfileDto profile, List<RulesProfileDto> descendants) { + private void ensureNoneIsMarkedAsDefault(DbSession dbSession, QProfileDto profile, List<QProfileDto> descendants) { Set<String> allUuids = new HashSet<>(); allUuids.add(profile.getKee()); descendants.forEach(p -> allUuids.add(p.getKee())); @@ -105,9 +105,9 @@ public class DeleteAction implements QProfileWsAction { }); } - private static List<String> toKeys(RulesProfileDto profile, List<RulesProfileDto> descendants) { + private static List<String> toKeys(QProfileDto profile, List<QProfileDto> descendants) { return Stream.concat(Stream.of(profile), descendants.stream()) - .map(RulesProfileDto::getKee) + .map(QProfileDto::getKee) .collect(MoreCollectors.toList(descendants.size() + 1)); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ExportAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ExportAction.java index d7b88cb8d6a..ecf0cf89f0a 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ExportAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ExportAction.java @@ -38,7 +38,7 @@ import org.sonar.core.util.stream.MoreCollectors; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileBackuper; import org.sonar.server.qualityprofile.QProfileExporters; import org.sonar.server.util.LanguageParamUtils; @@ -111,12 +111,12 @@ public class ExportAction implements QProfileWsAction { try (DbSession dbSession = dbClient.openSession(false)) { OrganizationDto organization = wsSupport.getOrganizationByKey(dbSession, request.param(PARAM_ORGANIZATION)); - RulesProfileDto profile = loadProfile(dbSession, organization, language, name); + QProfileDto profile = loadProfile(dbSession, organization, language, name); writeResponse(dbSession, profile, exporterKey, response); } } - private void writeResponse(DbSession dbSession, RulesProfileDto profile, @Nullable String exporterKey, Response response) throws IOException { + private void writeResponse(DbSession dbSession, QProfileDto profile, @Nullable String exporterKey, Response response) throws IOException { Stream stream = response.stream(); try ( OutputStream output = response.stream().output(); @@ -131,13 +131,13 @@ public class ExportAction implements QProfileWsAction { } } - private RulesProfileDto loadProfile(DbSession dbSession, OrganizationDto organization, String language, @Nullable String name) { - RulesProfileDto profile; + private QProfileDto loadProfile(DbSession dbSession, OrganizationDto organization, String language, @Nullable String name) { + QProfileDto profile; if (name == null) { // return the default profile profile = dbClient.qualityProfileDao().selectDefaultProfile(dbSession, organization, language); } else { - profile = dbClient.qualityProfileDao().selectByNameAndLanguage(organization, name, language, dbSession); + profile = dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, name, language); } return checkFound(profile, "Could not find profile with name '%s' for language '%s'", name, language); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/InheritanceAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/InheritanceAction.java index 829ecc69a72..69f0b9ad739 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/InheritanceAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/InheritanceAction.java @@ -32,7 +32,7 @@ import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileLookup; import org.sonarqube.ws.QualityProfiles.InheritanceWsResponse; import org.sonarqube.ws.QualityProfiles.InheritanceWsResponse.QualityProfile; @@ -71,19 +71,19 @@ public class InheritanceAction implements QProfileWsAction { public void handle(Request request, Response response) throws Exception { QProfileReference reference = QProfileReference.from(request); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto profile = wsSupport.getProfile(dbSession, reference); + QProfileDto profile = wsSupport.getProfile(dbSession, reference); String organizationUuid = profile.getOrganizationUuid(); OrganizationDto organization = dbClient.organizationDao().selectByUuid(dbSession, organizationUuid) .orElseThrow(() -> new IllegalStateException(String.format("Could not find organization with uuid '%s' for quality profile '%s'", organizationUuid, profile.getKee()))); - List<RulesProfileDto> ancestors = profileLookup.ancestors(profile, dbSession); - List<RulesProfileDto> children = dbClient.qualityProfileDao().selectChildren(dbSession, profile.getKee()); + List<QProfileDto> ancestors = profileLookup.ancestors(profile, dbSession); + List<QProfileDto> children = dbClient.qualityProfileDao().selectChildren(dbSession, profile.getKee()); Statistics statistics = new Statistics(dbSession, organization); writeProtobuf(buildResponse(profile, ancestors, children, statistics), request, response); } } - private static InheritanceWsResponse buildResponse(RulesProfileDto profile, List<RulesProfileDto> ancestors, List<RulesProfileDto> children, Statistics statistics) { + private static InheritanceWsResponse buildResponse(QProfileDto profile, List<QProfileDto> ancestors, List<QProfileDto> children, Statistics statistics) { return InheritanceWsResponse.newBuilder() .setProfile(buildProfile(profile, statistics)) .addAllAncestors(buildAncestors(ancestors, statistics)) @@ -91,19 +91,19 @@ public class InheritanceAction implements QProfileWsAction { .build(); } - private static Iterable<QualityProfile> buildAncestors(List<RulesProfileDto> ancestors, Statistics statistics) { + private static Iterable<QualityProfile> buildAncestors(List<QProfileDto> ancestors, Statistics statistics) { return ancestors.stream() .map(ancestor -> buildProfile(ancestor, statistics)) .collect(Collectors.toList()); } - private static Iterable<QualityProfile> buildChildren(List<RulesProfileDto> children, Statistics statistics) { + private static Iterable<QualityProfile> buildChildren(List<QProfileDto> children, Statistics statistics) { return children.stream() .map(child -> buildProfile(child, statistics)) .collect(Collectors.toList()); } - private static QualityProfile buildProfile(RulesProfileDto qualityProfile, Statistics statistics) { + private static QualityProfile buildProfile(QProfileDto qualityProfile, Statistics statistics) { String key = qualityProfile.getKee(); QualityProfile.Builder builder = QualityProfile.newBuilder() .setKey(key) diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/OldRestoreAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/OldRestoreAction.java index af4a35fb627..fd026b29ba9 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/OldRestoreAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/OldRestoreAction.java @@ -32,7 +32,7 @@ import org.sonar.api.utils.text.JsonWriter; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.BulkChangeResult; import org.sonar.server.qualityprofile.QProfileBackuper; import org.sonar.server.qualityprofile.QProfileRestoreSummary; @@ -102,7 +102,7 @@ public class OldRestoreAction implements WsAction { } private void writeResponse(JsonWriter json, QProfileRestoreSummary result) { - RulesProfileDto profile = result.getProfile(); + QProfileDto profile = result.getProfile(); String languageKey = profile.getLanguage(); Language language = languages.get(languageKey); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ProjectsAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ProjectsAction.java index cae23968911..bf1b85c41a8 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ProjectsAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/ProjectsAction.java @@ -40,7 +40,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ProjectQprofileAssociationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.user.UserSession; @@ -129,22 +129,22 @@ public class ProjectsAction implements QProfileWsAction { } private void checkProfileExists(String profileKey, DbSession session) { - if (dbClient.qualityProfileDao().selectByKey(session, profileKey) == null) { + if (dbClient.qualityProfileDao().selectByUuid(session, profileKey) == null) { throw new NotFoundException(String.format("Could not find a quality profile with key '%s'", profileKey)); } } private List<ProjectQprofileAssociationDto> loadProjects(String profileKey, DbSession session, String selected, String query) { - RulesProfileDto qualityProfile = dbClient.qualityProfileDao().selectByKey(session, profileKey); - OrganizationDto organization = wsSupport.getOrganization(session, qualityProfile); + QProfileDto profile = dbClient.qualityProfileDao().selectByUuid(session, profileKey); + OrganizationDto organization = wsSupport.getOrganization(session, profile); List<ProjectQprofileAssociationDto> projects = Lists.newArrayList(); SelectionMode selectionMode = SelectionMode.fromParam(selected); if (SelectionMode.SELECTED == selectionMode) { - projects.addAll(dbClient.qualityProfileDao().selectSelectedProjects(organization, profileKey, query, session)); + projects.addAll(dbClient.qualityProfileDao().selectSelectedProjects(session, organization, profile, query)); } else if (SelectionMode.DESELECTED == selectionMode) { - projects.addAll(dbClient.qualityProfileDao().selectDeselectedProjects(organization, profileKey, query, session)); + projects.addAll(dbClient.qualityProfileDao().selectDeselectedProjects(session, organization, profile, query)); } else { - projects.addAll(dbClient.qualityProfileDao().selectProjectAssociations(organization, profileKey, query, session)); + projects.addAll(dbClient.qualityProfileDao().selectProjectAssociations(session, organization, profile, query)); } return projects; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/QProfileWsSupport.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/QProfileWsSupport.java index 824b1fd14e9..cdbdd95ba6c 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/QProfileWsSupport.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/QProfileWsSupport.java @@ -28,7 +28,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.organization.DefaultOrganizationProvider; import org.sonar.server.user.UserSession; import org.sonar.server.ws.WsUtils; @@ -60,7 +60,7 @@ public class QProfileWsSupport { .setExampleValue("my-org"); } - public OrganizationDto getOrganization(DbSession dbSession, RulesProfileDto profile) { + public OrganizationDto getOrganization(DbSession dbSession, QProfileDto profile) { requireNonNull(profile); String organizationUuid = profile.getOrganizationUuid(); return dbClient.organizationDao().selectByUuid(dbSession, organizationUuid) @@ -80,26 +80,26 @@ public class QProfileWsSupport { * * @throws org.sonar.server.exceptions.NotFoundException if the specified organization or profile do not exist */ - public RulesProfileDto getProfile(DbSession dbSession, QProfileReference ref) { - RulesProfileDto profile; + public QProfileDto getProfile(DbSession dbSession, QProfileReference ref) { + QProfileDto profile; if (ref.hasKey()) { - profile = dbClient.qualityProfileDao().selectByKey(dbSession, ref.getKey()); + profile = dbClient.qualityProfileDao().selectByUuid(dbSession, ref.getKey()); checkFound(profile, "Quality Profile with key '%s' does not exist", ref.getKey()); } else { OrganizationDto org = getOrganizationByKey(dbSession, ref.getOrganizationKey().orElse(null)); - profile = dbClient.qualityProfileDao().selectByNameAndLanguage(org, ref.getName(), ref.getLanguage(), dbSession); + profile = dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, org, ref.getName(), ref.getLanguage()); checkFound(profile, "Quality Profile for language '%s' and name '%s' does not exist%s", ref.getLanguage(), ref.getName(), ref.getOrganizationKey().map(o -> " in organization '" + o + "'").orElse("")); } return profile; } - public void checkPermission(DbSession dbSession, RulesProfileDto rulesProfile) { + public void checkPermission(DbSession dbSession, QProfileDto rulesProfile) { OrganizationDto organization = getOrganization(dbSession, rulesProfile); userSession.checkPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, organization); } - public void checkNotBuiltInt(RulesProfileDto profile) { + public void checkNotBuiltInt(QProfileDto profile) { checkRequest(!profile.isBuiltIn(), "Operation forbidden for built-in Quality Profile '%s' with language '%s'", profile.getName(), profile.getLanguage()); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RemoveProjectAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RemoveProjectAction.java index 393ad87fb98..035890436f7 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RemoveProjectAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RemoveProjectAction.java @@ -29,7 +29,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.component.ComponentDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.component.ComponentFinder; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.user.UserSession; @@ -80,7 +80,7 @@ public class RemoveProjectAction implements QProfileWsAction { try (DbSession dbSession = dbClient.openSession(false)) { ComponentDto project = loadProject(dbSession, request); - RulesProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); + QProfileDto profile = wsSupport.getProfile(dbSession, QProfileReference.from(request)); if (!profile.getOrganizationUuid().equals(project.getOrganizationUuid())) { throw new IllegalArgumentException("Project and Quality profile must have same organization"); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RenameAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RenameAction.java index 1d46426707b..f6b43612c1e 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RenameAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RenameAction.java @@ -30,7 +30,7 @@ import org.sonar.core.util.Uuids; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.user.UserSession; @@ -89,7 +89,7 @@ public class RenameAction implements QProfileWsAction { userSession.checkLoggedIn(); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto qualityProfile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); + QProfileDto qualityProfile = wsSupport.getProfile(dbSession, QProfileReference.fromKey(profileKey)); String organizationUuid = qualityProfile.getOrganizationUuid(); userSession.checkPermission(ADMINISTER_QUALITY_PROFILES, organizationUuid); @@ -99,7 +99,7 @@ public class RenameAction implements QProfileWsAction { OrganizationDto organization = dbClient.organizationDao().selectByUuid(dbSession, organizationUuid) .orElseThrow(() -> new IllegalStateException("No organization found for uuid " + organizationUuid)); String language = qualityProfile.getLanguage(); - ofNullable(dbClient.qualityProfileDao().selectByNameAndLanguage(organization, newName, language, dbSession)) + ofNullable(dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, newName, language)) .ifPresent(found -> { throw BadRequestException.create(format("Quality profile already exists: %s", newName)); }); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RestoreAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RestoreAction.java index 0e6d3037006..eed6317380a 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RestoreAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/RestoreAction.java @@ -31,7 +31,7 @@ import org.sonar.api.utils.text.JsonWriter; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.BulkChangeResult; import org.sonar.server.qualityprofile.QProfileBackuper; import org.sonar.server.qualityprofile.QProfileRestoreSummary; @@ -102,7 +102,7 @@ public class RestoreAction implements QProfileWsAction { } private void writeResponse(JsonWriter json, OrganizationDto organization, QProfileRestoreSummary summary) { - RulesProfileDto profile = summary.getProfile(); + QProfileDto profile = summary.getProfile(); String languageKey = profile.getLanguage(); Language language = languages.get(languageKey); diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchAction.java index bba002aa86e..50ff44d7a87 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchAction.java @@ -36,7 +36,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.util.LanguageParamUtils; import org.sonarqube.ws.QualityProfiles.SearchWsResponse; import org.sonarqube.ws.QualityProfiles.SearchWsResponse.QualityProfile; @@ -156,15 +156,15 @@ public class SearchAction implements QProfileWsAction { } } - List<RulesProfileDto> profiles = dataLoader.findProfiles(dbSession, request, organization, project); - Set<String> defaultProfiles = dbClient.defaultQProfileDao().selectExistingQProfileUuids(dbSession, organization.getUuid(), profiles.stream().map(RulesProfileDto::getKee).collect(MoreCollectors.toList())); + List<QProfileDto> profiles = dataLoader.findProfiles(dbSession, request, organization, project); + Set<String> defaultProfiles = dbClient.defaultQProfileDao().selectExistingQProfileUuids(dbSession, organization.getUuid(), profiles.stream().map(QProfileDto::getKee).collect(MoreCollectors.toList())); return new SearchData() .setOrganization(organization) .setProfiles(profiles) .setActiveRuleCountByProfileKey(dbClient.activeRuleDao().countActiveRulesByProfileKey(dbSession, organization)) .setActiveDeprecatedRuleCountByProfileKey(dbClient.activeRuleDao().countActiveRulesForRuleStatusByProfileKey(dbSession, organization, RuleStatus.DEPRECATED)) - .setProjectCountByProfileKey(dbClient.qualityProfileDao().countProjectsByProfileKey(dbSession, organization)) + .setProjectCountByProfileKey(dbClient.qualityProfileDao().countProjectsByProfileUuid(dbSession, organization)) .setDefaultProfileKeys(defaultProfiles); } } @@ -190,12 +190,12 @@ public class SearchAction implements QProfileWsAction { } private SearchWsResponse buildResponse(SearchData data) { - List<RulesProfileDto> profiles = data.getProfiles(); - Map<String, RulesProfileDto> profilesByKey = profiles.stream().collect(Collectors.toMap(RulesProfileDto::getKee, identity())); + List<QProfileDto> profiles = data.getProfiles(); + Map<String, QProfileDto> profilesByKey = profiles.stream().collect(Collectors.toMap(QProfileDto::getKee, identity())); SearchWsResponse.Builder response = SearchWsResponse.newBuilder(); - for (RulesProfileDto profile : profiles) { + for (QProfileDto profile : profiles) { QualityProfile.Builder profileBuilder = response.addProfilesBuilder(); String profileKey = profile.getKee(); @@ -222,7 +222,7 @@ public class SearchAction implements QProfileWsAction { return response.build(); } - private void writeLanguageFields(QualityProfile.Builder profileBuilder, RulesProfileDto profile) { + private void writeLanguageFields(QualityProfile.Builder profileBuilder, QProfileDto profile) { String languageKey = profile.getLanguage(); if (languageKey == null) { return; @@ -235,14 +235,14 @@ public class SearchAction implements QProfileWsAction { } } - private static void writeParentFields(QualityProfile.Builder profileBuilder, RulesProfileDto profile, Map<String, RulesProfileDto> profilesByKey) { + private static void writeParentFields(QualityProfile.Builder profileBuilder, QProfileDto profile, Map<String, QProfileDto> profilesByKey) { String parentKey = profile.getParentKee(); if (parentKey == null) { return; } profileBuilder.setParentKey(parentKey); - RulesProfileDto parent = profilesByKey.get(parentKey); + QProfileDto parent = profilesByKey.get(parentKey); if (parent != null && parent.getName() != null) { profileBuilder.setParentName(parent.getName()); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchData.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchData.java index 8f98ab7367d..be04202b33d 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchData.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchData.java @@ -23,7 +23,7 @@ import java.util.List; import java.util.Map; import java.util.Set; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import static com.google.common.base.MoreObjects.firstNonNull; import static com.google.common.collect.ImmutableList.copyOf; @@ -31,7 +31,7 @@ import static com.google.common.collect.ImmutableMap.copyOf; public class SearchData { private OrganizationDto organization; - private List<RulesProfileDto> profiles; + private List<QProfileDto> profiles; private Map<String, Long> activeRuleCountByProfileKey; private Map<String, Long> activeDeprecatedRuleCountByProfileKey; private Map<String, Long> projectCountByProfileKey; @@ -46,11 +46,11 @@ public class SearchData { return organization; } - public List<RulesProfileDto> getProfiles() { + public List<QProfileDto> getProfiles() { return profiles; } - public SearchData setProfiles(List<RulesProfileDto> profiles) { + public SearchData setProfiles(List<QProfileDto> profiles) { this.profiles = copyOf(profiles); return this; } @@ -82,7 +82,7 @@ public class SearchData { return firstNonNull(activeDeprecatedRuleCountByProfileKey.get(profileKey), 0L); } - boolean isDefault(RulesProfileDto profile) { + boolean isDefault(QProfileDto profile) { return defaultProfileKeys.contains(profile.getKee()); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchDataLoader.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchDataLoader.java index 39449bf75cc..dcc7f8cadcb 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchDataLoader.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SearchDataLoader.java @@ -36,7 +36,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.qualityprofile.QProfileLookup; import org.sonarqube.ws.client.qualityprofile.SearchWsRequest; @@ -44,9 +44,9 @@ import static java.lang.String.format; public class SearchDataLoader { - private static final Comparator<RulesProfileDto> Q_PROFILE_COMPARATOR = Comparator - .comparing(RulesProfileDto::getLanguage) - .thenComparing(RulesProfileDto::getName); + private static final Comparator<QProfileDto> Q_PROFILE_COMPARATOR = Comparator + .comparing(QProfileDto::getLanguage) + .thenComparing(QProfileDto::getName); private final Languages languages; private final QProfileLookup profileLookup; @@ -59,8 +59,8 @@ public class SearchDataLoader { } @VisibleForTesting - List<RulesProfileDto> findProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization, @Nullable ComponentDto project) { - Collection<RulesProfileDto> profiles; + List<QProfileDto> findProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization, @Nullable ComponentDto project) { + Collection<QProfileDto> profiles; if (askDefaultProfiles(request)) { profiles = findDefaultProfiles(dbSession, request, organization); } else if (project != null) { @@ -72,11 +72,11 @@ public class SearchDataLoader { return profiles.stream().sorted(Q_PROFILE_COMPARATOR).collect(Collectors.toList()); } - private Collection<RulesProfileDto> findDefaultProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization) { + private Collection<QProfileDto> findDefaultProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization) { String profileName = request.getProfileName(); Set<String> languageKeys = getLanguageKeys(); - Map<String, RulesProfileDto> qualityProfiles = new HashMap<>(languageKeys.size()); + Map<String, QProfileDto> qualityProfiles = new HashMap<>(languageKeys.size()); Set<String> missingLanguageKeys = lookupByProfileName(dbSession, organization, qualityProfiles, languageKeys, profileName); Set<String> noDefaultProfileLanguageKeys = lookupDefaults(dbSession, organization, qualityProfiles, missingLanguageKeys); @@ -88,11 +88,11 @@ public class SearchDataLoader { return qualityProfiles.values(); } - private Collection<RulesProfileDto> findProjectProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization, ComponentDto project) { + private Collection<QProfileDto> findProjectProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization, ComponentDto project) { String profileName = request.getProfileName(); Set<String> languageKeys = getLanguageKeys(); - Map<String, RulesProfileDto> qualityProfiles = new HashMap<>(languageKeys.size()); + Map<String, QProfileDto> qualityProfiles = new HashMap<>(languageKeys.size()); // look up profiles by profileName (if any) for each language Set<String> unresolvedLanguages = lookupByProfileName(dbSession, organization, qualityProfiles, languageKeys, profileName); @@ -108,7 +108,7 @@ public class SearchDataLoader { return qualityProfiles.values(); } - private List<RulesProfileDto> findAllProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization) { + private Collection<QProfileDto> findAllProfiles(DbSession dbSession, SearchWsRequest request, OrganizationDto organization) { String language = request.getLanguage(); if (language == null) { @@ -117,20 +117,20 @@ public class SearchDataLoader { return profileLookup.profiles(dbSession, language, organization); } - private Set<String> lookupByProfileName(DbSession dbSession, OrganizationDto organization, Map<String, RulesProfileDto> qualityProfiles, Set<String> languageKeys, - @Nullable String profileName) { + private Set<String> lookupByProfileName(DbSession dbSession, OrganizationDto organization, Map<String, QProfileDto> qualityProfiles, Set<String> languageKeys, + @Nullable String profileName) { if (languageKeys.isEmpty() || profileName == null) { return languageKeys; } - dbClient.qualityProfileDao().selectByNameAndLanguages(organization, profileName, languageKeys, dbSession) + dbClient.qualityProfileDao().selectByNameAndLanguages(dbSession, organization, profileName, languageKeys) .forEach(qualityProfile -> qualityProfiles .put(qualityProfile.getLanguage(), qualityProfile)); return difference(languageKeys, qualityProfiles.keySet()); } - private Set<String> lookupByModule(DbSession dbSession, Map<String, RulesProfileDto> qualityProfiles, Set<String> languageKeys, - ComponentDto project) { + private Set<String> lookupByModule(DbSession dbSession, Map<String, QProfileDto> qualityProfiles, Set<String> languageKeys, + ComponentDto project) { if (languageKeys.isEmpty()) { return languageKeys; } @@ -140,7 +140,7 @@ public class SearchDataLoader { return difference(languageKeys, qualityProfiles.keySet()); } - private Set<String> lookupDefaults(DbSession dbSession, OrganizationDto organization, Map<String, RulesProfileDto> qualityProfiles, Set<String> languageKeys) { + private Set<String> lookupDefaults(DbSession dbSession, OrganizationDto organization, Map<String, QProfileDto> qualityProfiles, Set<String> languageKeys) { if (languageKeys.isEmpty()) { return languageKeys; } @@ -153,7 +153,7 @@ public class SearchDataLoader { return Sets.newHashSet(Sets.difference(languageKeys, set2)); } - private static void addAll(Map<String, RulesProfileDto> qualityProfiles, Collection<RulesProfileDto> list) { + private static void addAll(Map<String, QProfileDto> qualityProfiles, Collection<QProfileDto> list) { list.forEach(qualityProfile -> qualityProfiles.put(qualityProfile.getLanguage(), qualityProfile)); } @@ -161,7 +161,7 @@ public class SearchDataLoader { return Arrays.stream(languages.all()).map(Language::getKey).collect(Collectors.toSet()); } - private List<RulesProfileDto> findDefaultProfiles(final DbSession dbSession, OrganizationDto organization, Set<String> languageKeys) { + private List<QProfileDto> findDefaultProfiles(final DbSession dbSession, OrganizationDto organization, Set<String> languageKeys) { return dbClient.qualityProfileDao().selectDefaultProfiles(dbSession, organization, languageKeys); } diff --git a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SetDefaultAction.java b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SetDefaultAction.java index 54a9bc5f846..fc4069c27c0 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SetDefaultAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/qualityprofile/ws/SetDefaultAction.java @@ -27,7 +27,7 @@ import org.sonar.api.server.ws.WebService.NewAction; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.DefaultQProfileDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.user.UserSession; import static java.lang.String.format; @@ -66,7 +66,7 @@ public class SetDefaultAction implements QProfileWsAction { userSession.checkLoggedIn(); QProfileReference reference = QProfileReference.from(request); try (DbSession dbSession = dbClient.openSession(false)) { - RulesProfileDto qualityProfile = qProfileWsSupport.getProfile(dbSession, reference); + QProfileDto qualityProfile = qProfileWsSupport.getProfile(dbSession, reference); dbClient.organizationDao().selectByUuid(dbSession, qualityProfile.getOrganizationUuid()) .orElseThrow(() -> new IllegalStateException( format("Cannot find organization '%s' for quality profile '%s'", qualityProfile.getOrganizationUuid(), qualityProfile.getKee()))); @@ -77,7 +77,7 @@ public class SetDefaultAction implements QProfileWsAction { response.noContent(); } - public void setDefault(DbSession dbSession, RulesProfileDto profile) { + public void setDefault(DbSession dbSession, QProfileDto profile) { dbClient.defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(profile)); } } diff --git a/server/sonar-server/src/main/java/org/sonar/server/rule/index/RuleIndexDefinition.java b/server/sonar-server/src/main/java/org/sonar/server/rule/index/RuleIndexDefinition.java index 3fac16bec40..6bbe9d31295 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/rule/index/RuleIndexDefinition.java +++ b/server/sonar-server/src/main/java/org/sonar/server/rule/index/RuleIndexDefinition.java @@ -78,7 +78,6 @@ public class RuleIndexDefinition implements IndexDefinition { public static final String FIELD_ACTIVE_RULE_PROFILE_KEY = "profile"; public static final String FIELD_ACTIVE_RULE_SEVERITY = "severity"; public static final String FIELD_ACTIVE_RULE_RULE_KEY = "ruleKey"; - public static final String FIELD_ACTIVE_RULE_CREATED_AT = "createdAt"; public static final String FIELD_ACTIVE_RULE_UPDATED_AT = "updatedAt"; private final Settings settings; @@ -106,8 +105,6 @@ public class RuleIndexDefinition implements IndexDefinition { activeRuleMapping.stringFieldBuilder(FIELD_ACTIVE_RULE_PROFILE_KEY).disableNorms().build(); activeRuleMapping.stringFieldBuilder(FIELD_ACTIVE_RULE_INHERITANCE).disableNorms().build(); activeRuleMapping.stringFieldBuilder(FIELD_ACTIVE_RULE_SEVERITY).disableNorms().build(); - - activeRuleMapping.createLongField(FIELD_ACTIVE_RULE_CREATED_AT); activeRuleMapping.createLongField(FIELD_ACTIVE_RULE_UPDATED_AT); // Rule extension type diff --git a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/ActiveRuleCompleter.java b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/ActiveRuleCompleter.java index 21d42e8ed9f..5c27668f370 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/ActiveRuleCompleter.java +++ b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/ActiveRuleCompleter.java @@ -44,7 +44,7 @@ import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.server.qualityprofile.ActiveRule; @@ -178,10 +178,10 @@ public class ActiveRuleCompleter { } private Rules.QProfiles.Builder buildQProfiles(DbSession dbSession, Collection<String> harvestedProfileKeys) { - Map<String, RulesProfileDto> qProfilesByKey = new HashMap<>(); + Map<String, QProfileDto> qProfilesByKey = new HashMap<>(); for (String qProfileKey : harvestedProfileKeys) { if (!qProfilesByKey.containsKey(qProfileKey)) { - RulesProfileDto profile = loadProfile(dbSession, qProfileKey); + QProfileDto profile = loadProfile(dbSession, qProfileKey); if (profile == null) { LOG.warn("Could not find quality profile with key " + qProfileKey); continue; @@ -196,7 +196,7 @@ public class ActiveRuleCompleter { Rules.QProfiles.Builder qProfilesResponse = Rules.QProfiles.newBuilder(); Map<String, Rules.QProfile> qProfilesMapResponse = qProfilesResponse.getMutableQProfiles(); - for (RulesProfileDto profile : qProfilesByKey.values()) { + for (QProfileDto profile : qProfilesByKey.values()) { writeProfile(qProfilesMapResponse, profile); } @@ -204,11 +204,11 @@ public class ActiveRuleCompleter { } @CheckForNull - private RulesProfileDto loadProfile(DbSession dbSession, String qProfileKey) { - return dbClient.qualityProfileDao().selectByKey(dbSession, qProfileKey); + private QProfileDto loadProfile(DbSession dbSession, String qProfileKey) { + return dbClient.qualityProfileDao().selectByUuid(dbSession, qProfileKey); } - private void writeProfile(Map<String, Rules.QProfile> profilesResponse, RulesProfileDto profile) { + private void writeProfile(Map<String, Rules.QProfile> profilesResponse, QProfileDto profile) { Rules.QProfile.Builder profileResponse = Rules.QProfile.newBuilder(); setNullable(profile.getName(), profileResponse::setName); diff --git a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/AppAction.java b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/AppAction.java index bcf317abe07..8c7cee5c1a4 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/AppAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/AppAction.java @@ -29,7 +29,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.user.UserSession; import static org.sonarqube.ws.client.component.ComponentsWsParameters.PARAM_ORGANIZATION; @@ -87,7 +87,7 @@ public class AppAction implements RulesWsAction { private void addProfiles(DbSession dbSession, OrganizationDto organization, JsonWriter json) { json.name("qualityprofiles").beginArray(); - for (RulesProfileDto profile : dbClient.qualityProfileDao().selectAll(dbSession, organization)) { + for (QProfileDto profile : dbClient.qualityProfileDao().selectAll(dbSession, organization)) { if (languageIsSupported(profile)) { json .beginObject() @@ -102,7 +102,7 @@ public class AppAction implements RulesWsAction { json.endArray(); } - private boolean languageIsSupported(RulesProfileDto profile) { + private boolean languageIsSupported(QProfileDto profile) { return languages.get(profile.getLanguage()) != null; } diff --git a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/RuleQueryFactory.java b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/RuleQueryFactory.java index 73b8f36d9d8..aa0eb767c31 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/rule/ws/RuleQueryFactory.java +++ b/server/sonar-server/src/main/java/org/sonar/server/rule/ws/RuleQueryFactory.java @@ -32,7 +32,7 @@ import org.sonar.api.server.ws.WebService; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.rule.index.RuleQuery; import org.sonar.server.ws.WsUtils; @@ -88,8 +88,8 @@ public class RuleQueryFactory { organizationUuid = wsSupport.getOrganizationByKey(dbSession, organizationKey).getUuid(); languages = request.paramAsStrings(PARAM_LANGUAGES); } else { - RulesProfileDto qualityProfileOptional = dbClient.qualityProfileDao().selectByKey(dbSession, qualityProfileKey); - RulesProfileDto qualityProfile = WsUtils.checkFound(qualityProfileOptional, "The specified qualityProfile '%s' does not exist", qualityProfileKey); + QProfileDto qualityProfileOptional = dbClient.qualityProfileDao().selectByUuid(dbSession, qualityProfileKey); + QProfileDto qualityProfile = WsUtils.checkFound(qualityProfileOptional, "The specified qualityProfile '%s' does not exist", qualityProfileKey); query.setQProfileKey(qualityProfileKey); languages = ImmutableList.of(qualityProfile.getLanguage()); organizationUuid = qualityProfile.getOrganizationUuid(); @@ -121,8 +121,8 @@ public class RuleQueryFactory { } @CheckForNull - private RulesProfileDto getProfileByKey(DbSession dbSession, String key) { - return dbClient.qualityProfileDao().selectByKey(dbSession, key); + private QProfileDto getProfileByKey(DbSession dbSession, String key) { + return dbClient.qualityProfileDao().selectByUuid(dbSession, key); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderMediumTest.java index 1c9ee068195..f9dc210ac5f 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/batch/ProjectDataLoaderMediumTest.java @@ -38,7 +38,7 @@ import org.sonar.db.organization.OrganizationDto; import org.sonar.db.organization.OrganizationTesting; import org.sonar.db.property.PropertyDto; import org.sonar.db.qualityprofile.DefaultQProfileDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.source.FileSourceDao; import org.sonar.db.source.FileSourceDto; import org.sonar.db.source.FileSourceDto.Type; @@ -605,7 +605,7 @@ public class ProjectDataLoaderMediumTest { private void addDefaultProfile() { OrganizationDto organizationDto = OrganizationTesting.newOrganizationDto(); dbClient.organizationDao().insert(dbSession, organizationDto, false); - RulesProfileDto profileDto = newQProfileDto(organizationDto, QProfileName.createFor(ServerTester.Xoo.KEY, "SonarQube way"), "abcd").setRulesUpdatedAt( + QProfileDto profileDto = newQProfileDto(organizationDto, QProfileName.createFor(ServerTester.Xoo.KEY, "SonarQube way"), "abcd").setRulesUpdatedAt( formatDateTime(new Date())); dbClient.qualityProfileDao().insert(dbSession, profileDto); dbClient.defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(profileDto)); diff --git a/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStepTest.java b/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStepTest.java index bc0a286f29e..f8ffe401af0 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStepTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/LoadReportAnalysisMetadataHolderStepTest.java @@ -274,7 +274,7 @@ public class LoadReportAnalysisMetadataHolderStepTest { metadataBuilder.getMutableQprofilesPerLanguage().put("js", ScannerReport.Metadata.QProfile.newBuilder().setKey("p1").setName("Sonar way").setLanguage("js").build()); reportReader.setMetadata(metadataBuilder.build()); - dbTester.qualityProfiles().insert(organization, p -> p.setLanguage("js"), p -> p.setKey("p1")); + dbTester.qualityProfiles().insert(organization, p -> p.setLanguage("js").setKey("p1")); ComputationStep underTest = createStep(createCeTask(PROJECT_KEY, organization.getUuid())); @@ -292,8 +292,8 @@ public class LoadReportAnalysisMetadataHolderStepTest { metadataBuilder.getMutableQprofilesPerLanguage().put("php", ScannerReport.Metadata.QProfile.newBuilder().setKey("phpInOrg2").setName("PHP way").setLanguage("php").build()); reportReader.setMetadata(metadataBuilder.build()); - dbTester.qualityProfiles().insert(organization1, p -> p.setLanguage("js"), p -> p.setKey("jsInOrg1")); - dbTester.qualityProfiles().insert(organization2, p -> p.setLanguage("php"), p -> p.setKey("phpInOrg2")); + dbTester.qualityProfiles().insert(organization1, p -> p.setLanguage("js").setKey("jsInOrg1")); + dbTester.qualityProfiles().insert(organization2, p -> p.setLanguage("php").setKey("phpInOrg2")); ComputationStep underTest = createStep(createCeTask(PROJECT_KEY, organization1.getUuid())); diff --git a/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStepTest.java b/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStepTest.java index ee9733c0096..bb3ba269086 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStepTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/computation/task/projectanalysis/step/UpdateQualityProfilesLastUsedDateStepTest.java @@ -32,7 +32,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.RowNotFoundException; import org.sonar.db.qualityprofile.QualityProfileDbTester; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.computation.task.projectanalysis.analysis.AnalysisMetadataHolderRule; import org.sonar.server.computation.task.projectanalysis.component.Component; import org.sonar.server.computation.task.projectanalysis.component.ReportComponent; @@ -51,9 +51,9 @@ import static org.sonar.db.qualityprofile.QualityProfileTesting.newQualityProfil public class UpdateQualityProfilesLastUsedDateStepTest { static final long ANALYSIS_DATE = 1_123_456_789L; private static final Component PROJECT = ReportComponent.DUMB_PROJECT; - private RulesProfileDto sonarWayJava = newQualityProfileDto().setKey("sonar-way-java"); - private RulesProfileDto sonarWayPhp = newQualityProfileDto().setKey("sonar-way-php"); - private RulesProfileDto myQualityProfile = newQualityProfileDto().setKey("my-qp"); + private QProfileDto sonarWayJava = newQualityProfileDto().setKey("sonar-way-java"); + private QProfileDto sonarWayPhp = newQualityProfileDto().setKey("sonar-way-php"); + private QProfileDto myQualityProfile = newQualityProfileDto().setKey("my-qp"); @Rule public ExpectedException expectedException = ExpectedException.none(); @@ -81,7 +81,7 @@ public class UpdateQualityProfilesLastUsedDateStepTest { @Test public void doest_not_update_profiles_when_no_measure() { - qualityProfileDb.insertQualityProfiles(sonarWayJava, sonarWayPhp, myQualityProfile); + qualityProfileDb.insert(sonarWayJava, sonarWayPhp, myQualityProfile); underTest.execute(); @@ -92,7 +92,7 @@ public class UpdateQualityProfilesLastUsedDateStepTest { @Test public void update_profiles_defined_in_quality_profiles_measure() { - qualityProfileDb.insertQualityProfiles(sonarWayJava, sonarWayPhp, myQualityProfile); + qualityProfileDb.insert(sonarWayJava, sonarWayPhp, myQualityProfile); measureRepository.addRawMeasure(1, QUALITY_PROFILES_KEY, Measure.newMeasureBuilder().create( toJson(sonarWayJava.getKee(), myQualityProfile.getKee()))); @@ -107,13 +107,13 @@ public class UpdateQualityProfilesLastUsedDateStepTest { @Test public void ancestor_profiles_are_updated() throws Exception { // Parent profiles should be updated - RulesProfileDto rootProfile = newQualityProfileDto().setKey("root"); - RulesProfileDto parentProfile = newQualityProfileDto().setKey("parent").setParentKee(rootProfile.getKee()); + QProfileDto rootProfile = newQualityProfileDto().setKey("root"); + QProfileDto parentProfile = newQualityProfileDto().setKey("parent").setParentKee(rootProfile.getKee()); // Current profile => should be updated - RulesProfileDto currentProfile = newQualityProfileDto().setKey("current").setParentKee(parentProfile.getKee()); + QProfileDto currentProfile = newQualityProfileDto().setKey("current").setParentKee(parentProfile.getKee()); // Child of current profile => should not be updated - RulesProfileDto childProfile = newQualityProfileDto().setKey("child").setParentKee(currentProfile.getKee()); - qualityProfileDb.insertQualityProfiles(rootProfile, parentProfile, currentProfile, childProfile); + QProfileDto childProfile = newQualityProfileDto().setKey("child").setParentKee(currentProfile.getKee()); + qualityProfileDb.insert(rootProfile, parentProfile, currentProfile, childProfile); measureRepository.addRawMeasure(1, QUALITY_PROFILES_KEY, Measure.newMeasureBuilder().create(toJson(currentProfile.getKee()))); @@ -127,8 +127,8 @@ public class UpdateQualityProfilesLastUsedDateStepTest { @Test public void fail_when_profile_is_linked_to_unknown_parent() throws Exception { - RulesProfileDto currentProfile = newQualityProfileDto().setKey("current").setParentKee("unknown"); - qualityProfileDb.insertQualityProfiles(currentProfile); + QProfileDto currentProfile = newQualityProfileDto().setKey("current").setParentKee("unknown"); + qualityProfileDb.insert(currentProfile); measureRepository.addRawMeasure(1, QUALITY_PROFILES_KEY, Measure.newMeasureBuilder().create(toJson(currentProfile.getKee()))); @@ -141,17 +141,17 @@ public class UpdateQualityProfilesLastUsedDateStepTest { assertThat(underTest.getDescription()).isEqualTo("Update last usage date of quality profiles"); } - private void assertQualityProfileIsUpdated(RulesProfileDto qp) { + private void assertQualityProfileIsUpdated(QProfileDto qp) { assertThat(selectLastUser(qp.getKee())).withFailMessage("Quality profile '%s' hasn't been updated. Value: %d", qp.getKee(), qp.getLastUsed()).isEqualTo(ANALYSIS_DATE); } - private void assertQualityProfileIsTheSame(RulesProfileDto qp) { + private void assertQualityProfileIsTheSame(QProfileDto qp) { assertThat(selectLastUser(qp.getKee())).isEqualTo(qp.getLastUsed()); } @CheckForNull private Long selectLastUser(String qualityProfileKey) { - return dbClient.qualityProfileDao().selectByKey(dbSession, qualityProfileKey).getLastUsed(); + return dbClient.qualityProfileDao().selectByUuid(dbSession, qualityProfileKey).getLastUsed(); } private static String toJson(String... keys) { diff --git a/server/sonar-server/src/test/java/org/sonar/server/organization/ws/DeleteActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/organization/ws/DeleteActionTest.java index 24320dffb9d..24902363824 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/organization/ws/DeleteActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/organization/ws/DeleteActionTest.java @@ -37,7 +37,7 @@ import org.sonar.db.component.ComponentDto; import org.sonar.db.component.ComponentTesting; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.template.PermissionTemplateDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.user.GroupDto; import org.sonar.db.user.UserDto; import org.sonar.server.component.ComponentCleanerService; @@ -321,8 +321,8 @@ public class DeleteActionTest { public void request_also_deletes_quality_profiles_of_specified_organization() { OrganizationDto org = db.organizations().insert(); OrganizationDto otherOrg = db.organizations().insert(); - RulesProfileDto profileInOrg = db.qualityProfiles().insert(org); - RulesProfileDto profileInOtherOrg = db.qualityProfiles().insert(otherOrg); + QProfileDto profileInOrg = db.qualityProfiles().insert(org); + QProfileDto profileInOtherOrg = db.qualityProfiles().insert(otherOrg); logInAsAdministrator(org); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileBackuperMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileBackuperMediumTest.java index 9ee4522a455..f848acb9a64 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileBackuperMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileBackuperMediumTest.java @@ -44,7 +44,7 @@ import org.sonar.db.organization.OrganizationTesting; import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; @@ -126,14 +126,14 @@ public class QProfileBackuperMediumTest { ruleIndexer.indexRuleDefinition(blahRule.getKey()); // create profile P1 with rules x2 and x1 activated - RulesProfileDto profile = newXooP1(organization); + QProfileDto profile = newXooP1(organization); db.qualityProfileDao().insert(dbSession, profile); RuleActivation activation1 = new RuleActivation(XOO_X2).setSeverity("MINOR"); RuleActivation activation2 = new RuleActivation(XOO_X1); RuleActivation activation3 = new RuleActivation(blahRuleKey); activation2.setSeverity(Severity.BLOCKER); activation2.setParameter("max", "7"); - RulesProfileDto profileDto = get(XOO_P1_NAME); + QProfileDto profileDto = get(XOO_P1_NAME); tester.get(RuleActivator.class).activate(dbSession, activation1, profileDto); tester.get(RuleActivator.class).activate(dbSession, activation2, profileDto); tester.get(RuleActivator.class).activate(dbSession, activation3, profileDto); @@ -156,7 +156,7 @@ public class QProfileBackuperMediumTest { organization, null); // Check in db - RulesProfileDto profile = db.qualityProfileDao().selectByNameAndLanguage(organization, "P1", "xoo", dbSession); + QProfileDto profile = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "P1", "xoo"); assertThat(profile).isNotNull(); List<ActiveRuleDto> activeRules = db.activeRuleDao().selectByProfileKey(dbSession, profile.getKee()); @@ -182,7 +182,7 @@ public class QProfileBackuperMediumTest { RuleActivation activation = new RuleActivation(XOO_X1); activation.setSeverity(Severity.INFO); activation.setParameter("max", "10"); - RulesProfileDto profileDto = get(XOO_P1_NAME); + QProfileDto profileDto = get(XOO_P1_NAME); tester.get(RuleActivator.class).activate(dbSession, activation, profileDto); activation = new RuleActivation(XOO_X2); @@ -379,7 +379,7 @@ public class QProfileBackuperMediumTest { List<ActiveRuleDto> activeRules = db.activeRuleDao().selectByProfileKey(dbSession, XOO_P1_KEY); assertThat(activeRules).hasSize(0); - RulesProfileDto target = db.qualityProfileDao().selectByNameAndLanguage(organization, "P3", "xoo", dbSession); + QProfileDto target = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "P3", "xoo"); assertThat(target).isNotNull(); assertThat(db.activeRuleDao().selectByProfileKey(dbSession, target.getKee())).hasSize(1); } @@ -392,7 +392,7 @@ public class QProfileBackuperMediumTest { dbSession.clearCache(); assertThat(anyActiveRuleExists()).isFalse(); - List<RulesProfileDto> profiles = db.qualityProfileDao().selectAll(dbSession, organization); + List<QProfileDto> profiles = db.qualityProfileDao().selectAll(dbSession, organization); assertThat(profiles).hasSize(1); assertThat(profiles.get(0).getName()).isEqualTo("P1"); } @@ -404,7 +404,7 @@ public class QProfileBackuperMediumTest { } } - private RulesProfileDto get(QProfileName profileName) { - return db.qualityProfileDao().selectByNameAndLanguage(organization, profileName.getName(), profileName.getLanguage(), dbSession); + private QProfileDto get(QProfileName profileName) { + return db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, profileName.getName(), profileName.getLanguage()); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileComparisonMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileComparisonMediumTest.java index 01b8db02cc9..31e4c19eba8 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileComparisonMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileComparisonMediumTest.java @@ -30,7 +30,7 @@ import org.sonar.api.rule.Severity; import org.sonar.api.server.rule.RuleParamType; import org.sonar.db.DbClient; import org.sonar.db.DbSession; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; import org.sonar.db.rule.RuleTesting; @@ -56,8 +56,8 @@ public class QProfileComparisonMediumTest { RuleDto xooRule1; RuleDto xooRule2; - RulesProfileDto left; - RulesProfileDto right; + QProfileDto left; + QProfileDto right; @Before public void before() { diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileCopierMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileCopierMediumTest.java index ed703457cba..9939f343438 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileCopierMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileCopierMediumTest.java @@ -35,7 +35,7 @@ import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; @@ -65,7 +65,7 @@ public class QProfileCopierMediumTest { private RuleIndexer ruleIndexer; private ActiveRuleIndexer activeRuleIndexer; private OrganizationDto organization; - private RulesProfileDto sourceProfile; + private QProfileDto sourceProfile; @Before public void before() { @@ -169,7 +169,7 @@ public class QProfileCopierMediumTest { copier.copyToName(dbSession, sourceProfile, QProfileTesting.XOO_P2_NAME.getName()); verifyOneActiveRule(QProfileTesting.XOO_P2_KEY, Severity.BLOCKER, ActiveRuleDto.INHERITED, ImmutableMap.of("max", "7")); - RulesProfileDto profile2Dto = db.qualityProfileDao().selectByKey(dbSession, QProfileTesting.XOO_P2_KEY); + QProfileDto profile2Dto = db.qualityProfileDao().selectByUuid(dbSession, QProfileTesting.XOO_P2_KEY); assertThat(profile2Dto.getParentKee()).isEqualTo(QProfileTesting.XOO_P1_KEY); } @@ -193,7 +193,7 @@ public class QProfileCopierMediumTest { private void verifyOneActiveRule(QProfileName profileName, String expectedSeverity, @Nullable String expectedInheritance, Map<String, String> expectedParams) { - RulesProfileDto dto = db.qualityProfileDao().selectByNameAndLanguage(organization, profileName.getName(), profileName.getLanguage(), dbSession); + QProfileDto dto = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, profileName.getName(), profileName.getLanguage()); verifyOneActiveRule(dto.getKee(), expectedSeverity, expectedInheritance, expectedParams); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileExportersTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileExportersTest.java index 8a7240bd06c..8c3b8a6bb30 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileExportersTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileExportersTest.java @@ -41,7 +41,7 @@ import org.sonar.api.utils.ValidationMessages; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.qualityprofile.index.ActiveRuleIndexer; import org.sonar.server.rule.index.RuleIndex; @@ -102,7 +102,7 @@ public class QProfileExportersTest { @Test public void import_xml() { - RulesProfileDto profileDto = QProfileTesting.newQProfileDto("org-123", QProfileName.createFor("xoo", "import_xml"), "import_xml"); + QProfileDto profileDto = QProfileTesting.newQProfileDto("org-123", QProfileName.createFor("xoo", "import_xml"), "import_xml"); db.qualityProfileDao().insert(dbSession, profileDto); dbSession.commit(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryMediumTest.java index 376bf919ae0..6a649addf50 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryMediumTest.java @@ -29,7 +29,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.organization.OrganizationTesting; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.tester.ServerTester; import org.sonar.server.tester.UserSessionRule; @@ -69,7 +69,7 @@ public class QProfileFactoryMediumTest { public void checkAndCreate() { String uuid = organization.getUuid(); - RulesProfileDto writtenDto = factory.checkAndCreateCustom(dbSession, organization, new QProfileName("xoo", "P1")); + QProfileDto writtenDto = factory.checkAndCreateCustom(dbSession, organization, new QProfileName("xoo", "P1")); dbSession.commit(); dbSession.clearCache(); assertThat(writtenDto.getOrganizationUuid()).isEqualTo(uuid); @@ -80,7 +80,7 @@ public class QProfileFactoryMediumTest { assertThat(writtenDto.isBuiltIn()).isFalse(); // reload the dto - RulesProfileDto readDto = db.qualityProfileDao().selectByNameAndLanguage(organization, "P1", "xoo", dbSession); + QProfileDto readDto = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "P1", "xoo"); assertEqual(writtenDto, readDto); assertThat(db.qualityProfileDao().selectAll(dbSession, organization)).hasSize(1); @@ -90,7 +90,7 @@ public class QProfileFactoryMediumTest { public void create() { String uuid = organization.getUuid(); - RulesProfileDto writtenDto = factory.createBuiltIn(dbSession, organization, new QProfileName("xoo", "P1"), true); + QProfileDto writtenDto = factory.createBuiltIn(dbSession, organization, new QProfileName("xoo", "P1"), true); dbSession.commit(); dbSession.clearCache(); assertThat(writtenDto.getOrganizationUuid()).isEqualTo(uuid); @@ -101,7 +101,7 @@ public class QProfileFactoryMediumTest { assertThat(writtenDto.getParentKee()).isNull(); // reload the dto - RulesProfileDto readDto = db.qualityProfileDao().selectByNameAndLanguage(organization, "P1", "xoo", dbSession); + QProfileDto readDto = db.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "P1", "xoo"); assertEqual(writtenDto, readDto); assertThat(db.qualityProfileDao().selectAll(dbSession, organization)).hasSize(1); @@ -170,7 +170,7 @@ public class QProfileFactoryMediumTest { thrown.expectMessage(message); } - private static void assertEqual(RulesProfileDto writtenDto, RulesProfileDto readDto) { + private static void assertEqual(QProfileDto writtenDto, QProfileDto readDto) { assertThat(readDto.getOrganizationUuid()).isEqualTo(writtenDto.getOrganizationUuid()); assertThat(readDto.getName()).isEqualTo(writtenDto.getName()); assertThat(readDto.getKee()).startsWith(writtenDto.getKee()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryTest.java index 45e765d5113..29dfea82819 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileFactoryTest.java @@ -34,7 +34,7 @@ import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleParamDto; import org.sonar.server.qualityprofile.index.ActiveRuleIndexer; @@ -65,9 +65,9 @@ public class QProfileFactoryTest { @Test public void deleteByKeys_deletes_profiles_in_db_and_elasticsearch() { OrganizationDto org = db.organizations().insert(); - RulesProfileDto profile1 = createRandomProfile(org); - RulesProfileDto profile2 = createRandomProfile(org); - RulesProfileDto profile3 = createRandomProfile(org); + QProfileDto profile1 = createRandomProfile(org); + QProfileDto profile2 = createRandomProfile(org); + QProfileDto profile3 = createRandomProfile(org); List<String> profileKeys = asList(profile1.getKee(), profile2.getKee(), "does_not_exist"); underTest.deleteByKeys(db.getSession(), profileKeys); @@ -81,7 +81,7 @@ public class QProfileFactoryTest { @Test public void deleteByKeys_accepts_empty_list_of_keys() { OrganizationDto org = db.organizations().insert(); - RulesProfileDto profile1 = createRandomProfile(org); + QProfileDto profile1 = createRandomProfile(org); underTest.deleteByKeys(db.getSession(), Collections.emptyList()); @@ -89,10 +89,10 @@ public class QProfileFactoryTest { assertQualityProfileFromDb(profile1).isNotNull(); } - private RulesProfileDto createRandomProfile(OrganizationDto org) { - RulesProfileDto profile = db.qualityProfiles().insert(org); + private QProfileDto createRandomProfile(OrganizationDto org) { + QProfileDto profile = db.qualityProfiles().insert(org); ComponentDto project = db.components().insertPrivateProject(org); - db.qualityProfiles().associateProjectWithQualityProfile(project, profile); + db.qualityProfiles().associateWithProject(project, profile); ActiveRuleDto activeRuleDto = new ActiveRuleDto() .setProfileId(profile.getId()) .setRuleId(rule.getId()) @@ -107,7 +107,7 @@ public class QProfileFactoryTest { return profile; } - private AbstractObjectAssert<?, RulesProfileDto> assertQualityProfileFromDb(RulesProfileDto profile) { - return assertThat(db.getDbClient().qualityProfileDao().selectByKey(db.getSession(), profile.getKee())); + private AbstractObjectAssert<?, QProfileDto> assertQualityProfileFromDb(QProfileDto profile) { + return assertThat(db.getDbClient().qualityProfileDao().selectByUuid(db.getSession(), profile.getKee())); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileTesting.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileTesting.java index 8d92dd0bb8b..8e4461c1c45 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileTesting.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/QProfileTesting.java @@ -22,7 +22,7 @@ package org.sonar.server.qualityprofile; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.organization.DefaultOrganizationProvider; import org.sonar.server.tester.ServerTester; @@ -42,15 +42,15 @@ public class QProfileTesting { * @deprecated provide organization as dto */ @Deprecated - public static RulesProfileDto newQProfileDto(String organizationUuid, QProfileName name, String key) { - return RulesProfileDto.createFor(key).setOrganizationUuid(organizationUuid).setName(name.getName()).setLanguage(name.getLanguage()); + public static QProfileDto newQProfileDto(String organizationUuid, QProfileName name, String key) { + return QProfileDto.createFor(key).setOrganizationUuid(organizationUuid).setName(name.getName()).setLanguage(name.getLanguage()); } /** * @deprecated provide organization as dto */ @Deprecated - public static RulesProfileDto newXooP1(String organizationUuid) { + public static QProfileDto newXooP1(String organizationUuid) { return newQProfileDto(organizationUuid, XOO_P1_NAME, XOO_P1_KEY); } @@ -58,7 +58,7 @@ public class QProfileTesting { * @deprecated provide organization as dto */ @Deprecated - public static RulesProfileDto newXooP2(String organizationUuid) { + public static QProfileDto newXooP2(String organizationUuid) { return newQProfileDto(organizationUuid, XOO_P2_NAME, XOO_P2_KEY); } @@ -66,23 +66,23 @@ public class QProfileTesting { * @deprecated provide organization as dto */ @Deprecated - public static RulesProfileDto newXooP3(String organizationUuid) { + public static QProfileDto newXooP3(String organizationUuid) { return newQProfileDto(organizationUuid, XOO_P3_NAME, XOO_P3_KEY); } - public static RulesProfileDto newQProfileDto(OrganizationDto organization, QProfileName name, String key) { - return RulesProfileDto.createFor(key).setOrganizationUuid(organization.getUuid()).setName(name.getName()).setLanguage(name.getLanguage()); + public static QProfileDto newQProfileDto(OrganizationDto organization, QProfileName name, String key) { + return QProfileDto.createFor(key).setOrganizationUuid(organization.getUuid()).setName(name.getName()).setLanguage(name.getLanguage()); } - public static RulesProfileDto newXooP1(OrganizationDto organization) { + public static QProfileDto newXooP1(OrganizationDto organization) { return newQProfileDto(organization, XOO_P1_NAME, XOO_P1_KEY); } - public static RulesProfileDto newXooP2(OrganizationDto organization) { + public static QProfileDto newXooP2(OrganizationDto organization) { return newQProfileDto(organization, XOO_P2_NAME, XOO_P2_KEY); } - public static RulesProfileDto newXooP3(OrganizationDto organization) { + public static QProfileDto newXooP3(OrganizationDto organization) { return newQProfileDto(organization, XOO_P3_NAME, XOO_P3_KEY); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesMediumTest.java index 50d68aa9852..e12879c18fe 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesMediumTest.java @@ -41,7 +41,7 @@ import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; import org.sonar.db.qualityprofile.DefaultQProfileDto; import org.sonar.db.qualityprofile.QualityProfileDao; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.es.SearchOptions; import org.sonar.server.platform.Platform; import org.sonar.server.rule.index.RuleIndex; @@ -80,7 +80,7 @@ public class RegisterQualityProfilesMediumTest { // Check Profile in DB QualityProfileDao qualityProfileDao = dbClient.qualityProfileDao(); assertThat(qualityProfileDao.selectAll(dbSession, organization)).hasSize(1); - RulesProfileDto profile = qualityProfileDao.selectByNameAndLanguage(organization, "Basic", "xoo", dbSession); + QProfileDto profile = qualityProfileDao.selectByNameAndLanguage(dbSession, organization, "Basic", "xoo"); assertThat(profile).isNotNull(); assertThat(profile.isBuiltIn()).isTrue(); @@ -130,7 +130,7 @@ public class RegisterQualityProfilesMediumTest { // Check Profile in DB QualityProfileDao qualityProfileDao = dbClient.qualityProfileDao(); assertThat(qualityProfileDao.selectAll(dbSession, organization)).hasSize(1); - RulesProfileDto profile = qualityProfileDao.selectByNameAndLanguage(organization, "Basic", "xoo", dbSession); + QProfileDto profile = qualityProfileDao.selectByNameAndLanguage(dbSession, organization, "Basic", "xoo"); assertThat(profile).isNotNull(); assertThat(profile.isBuiltIn()).isTrue(); @@ -212,7 +212,7 @@ public class RegisterQualityProfilesMediumTest { dbSession = dbClient().openSession(false); OrganizationDto organization = getDefaultOrganization(tester, dbClient, dbSession); - RulesProfileDto profile = dbClient.qualityProfileDao().selectByNameAndLanguage(organization, "two", "xoo", dbSession); + QProfileDto profile = dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "two", "xoo"); dbClient.defaultQProfileDao().insertOrUpdate(dbSession, DefaultQProfileDto.from(profile)); dbSession.commit(); @@ -225,7 +225,7 @@ public class RegisterQualityProfilesMediumTest { private void verifyDefaultProfile(OrganizationDto organization, String language, String name) { dbSession = dbClient().openSession(false); - RulesProfileDto defaultProfile = dbClient().qualityProfileDao().selectDefaultProfile(dbSession, organization, language); + QProfileDto defaultProfile = dbClient().qualityProfileDao().selectDefaultProfile(dbSession, organization, language); assertThat(defaultProfile).isNotNull(); assertThat(defaultProfile.getName()).isEqualTo(name); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesTest.java index b5d09e4ff26..1d8479ad6a5 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RegisterQualityProfilesTest.java @@ -33,7 +33,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.language.LanguageTesting; import org.sonar.server.qualityprofile.index.ActiveRuleIndexer; import org.sonar.server.tester.UserSessionRule; @@ -108,15 +108,15 @@ public class RegisterQualityProfilesTest { OrganizationDto org1 = dbTester.organizations().insert(org -> org.setKey("org1")); OrganizationDto org2 = dbTester.organizations().insert(org -> org.setKey("org2")); - RulesProfileDto outdatedProfileInOrg1 = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage(FOO_LANGUAGE.getKey()).setName("Sonar way")); - RulesProfileDto outdatedProfileInOrg2 = dbTester.qualityProfiles().insert(org2, p -> p.setIsBuiltIn(false).setLanguage(FOO_LANGUAGE.getKey()).setName("Sonar way")); + QProfileDto outdatedProfileInOrg1 = dbTester.qualityProfiles().insert(org1, p -> p.setIsBuiltIn(false).setLanguage(FOO_LANGUAGE.getKey()).setName("Sonar way")); + QProfileDto outdatedProfileInOrg2 = dbTester.qualityProfiles().insert(org2, p -> p.setIsBuiltIn(false).setLanguage(FOO_LANGUAGE.getKey()).setName("Sonar way")); builtInQProfileRepositoryRule.add(FOO_LANGUAGE, "Sonar way", false); builtInQProfileRepositoryRule.initialize(); underTest.start(); - assertThat(dbTester.qualityProfiles().selectByKey(outdatedProfileInOrg1.getKee()).get().getName()).isEqualTo("Sonar way (outdated copy)"); - assertThat(dbTester.qualityProfiles().selectByKey(outdatedProfileInOrg2.getKee()).get().getName()).isEqualTo("Sonar way (outdated copy)"); + assertThat(dbTester.qualityProfiles().selectByUuid(outdatedProfileInOrg1.getKee()).get().getName()).isEqualTo("Sonar way (outdated copy)"); + assertThat(dbTester.qualityProfiles().selectByUuid(outdatedProfileInOrg2.getKee()).get().getName()).isEqualTo("Sonar way (outdated copy)"); assertThat(logTester.logs(LoggerLevel.INFO)).contains("Rename Quality profiles [foo/Sonar way] to [Sonar way (outdated copy)] in 2Â organizations"); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RuleActivatorMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RuleActivatorMediumTest.java index 15bb60a2e73..bdf0405f685 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RuleActivatorMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/RuleActivatorMediumTest.java @@ -40,7 +40,7 @@ import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; @@ -98,7 +98,7 @@ public class RuleActivatorMediumTest { ActiveRuleIndexer activeRuleIndexer; - RulesProfileDto profileDto; + QProfileDto profileDto; private OrganizationDto organization; @Before @@ -964,7 +964,7 @@ public class RuleActivatorMediumTest { // set parent -> child profile inherits rule x1 and still has x2 ruleActivator.setParent(dbSession, XOO_P2_KEY, XOO_P1_KEY); dbSession.clearCache(); - assertThat(db.qualityProfileDao().selectByKey(dbSession, XOO_P2_KEY).getParentKee()).isEqualTo(XOO_P1_KEY); + assertThat(db.qualityProfileDao().selectByUuid(dbSession, XOO_P2_KEY).getParentKee()).isEqualTo(XOO_P1_KEY); verifyHasActiveRuleInDbAndIndex(ActiveRuleKey.of(XOO_P2_KEY, XOO_X1), MAJOR, INHERITED, ImmutableMap.of("max", "10")); verifyHasActiveRuleInDbAndIndex(ActiveRuleKey.of(XOO_P2_KEY, XOO_X2), MAJOR, null, Collections.emptyMap()); @@ -973,7 +973,7 @@ public class RuleActivatorMediumTest { dbSession.clearCache(); ruleActivator.setParent(dbSession, XOO_P2_KEY, null); assertThat(countActiveRules(XOO_P2_KEY)).isEqualTo(1); - assertThat(db.qualityProfileDao().selectByKey(dbSession, XOO_P2_KEY).getParentKee()).isNull(); + assertThat(db.qualityProfileDao().selectByUuid(dbSession, XOO_P2_KEY).getParentKee()).isNull(); verifyHasActiveRuleInDbAndIndex(ActiveRuleKey.of(XOO_P2_KEY, XOO_X2), MAJOR, null, Collections.emptyMap()); } @@ -981,7 +981,7 @@ public class RuleActivatorMediumTest { public void unset_no_parent_does_not_fail() { // P1 has no parent ! ruleActivator.setParent(dbSession, XOO_P1_KEY, null); - assertThat(db.qualityProfileDao().selectByKey(dbSession, XOO_P1_KEY).getParentKee()).isNull(); + assertThat(db.qualityProfileDao().selectByUuid(dbSession, XOO_P1_KEY).getParentKee()).isNull(); } @Test @@ -1022,7 +1022,7 @@ public class RuleActivatorMediumTest { // unset parent -> keep x1 ruleActivator.setParent(dbSession, XOO_P2_KEY, null); dbSession.clearCache(); - assertThat(db.qualityProfileDao().selectByKey(dbSession, XOO_P2_KEY).getParentKee()).isNull(); + assertThat(db.qualityProfileDao().selectByUuid(dbSession, XOO_P2_KEY).getParentKee()).isNull(); verifyOneActiveRuleInDbAndIndex(XOO_P2_KEY, XOO_X1, BLOCKER, null, ImmutableMap.of("max", "333")); } @@ -1048,7 +1048,7 @@ public class RuleActivatorMediumTest { ruleActivator.setParent(dbSession, XOO_P2_KEY, XOO_P1_KEY); dbSession.clearCache(); - assertThat(db.qualityProfileDao().selectByKey(dbSession, XOO_P2_KEY).getParentKee()).isEqualTo(XOO_P1_KEY); + assertThat(db.qualityProfileDao().selectByUuid(dbSession, XOO_P2_KEY).getParentKee()).isEqualTo(XOO_P1_KEY); assertThat(countActiveRules(XOO_P2_KEY)).isEqualTo(1); verifyHasActiveRuleInDbAndIndex(ActiveRuleKey.of(XOO_P2_KEY, XOO_X2), MAJOR, INHERITED, Collections.emptyMap()); } @@ -1197,13 +1197,13 @@ public class RuleActivatorMediumTest { } private void assertProfileHasBeenUpdatedManually(String profileKey) { - RulesProfileDto profile = db.qualityProfileDao().selectByKey(dbSession, profileKey); + QProfileDto profile = db.qualityProfileDao().selectByUuid(dbSession, profileKey); assertThat(profile.getRulesUpdatedAt()).isNotEmpty(); assertThat(profile.getUserUpdatedAt()).isNotNull(); } private void assertProfileHasBeenUpdatedAutomatically(String profileKey) { - RulesProfileDto profile = db.qualityProfileDao().selectByKey(dbSession, profileKey); + QProfileDto profile = db.qualityProfileDao().selectByUuid(dbSession, profileKey); assertThat(profile.getRulesUpdatedAt()).isNotEmpty(); assertThat(profile.getUserUpdatedAt()).isNull(); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleDocTesting.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleDocTesting.java index bbb79fb205f..e1346250df8 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleDocTesting.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleDocTesting.java @@ -35,7 +35,7 @@ public class ActiveRuleDocTesting { return new ActiveRuleDoc(key) .setOrganizationUuid(randomAlphabetic(40)) .setSeverity(Severity.CRITICAL) - .setInheritance(null).setCreatedAt(150000000L) - .setUpdatedAt(160000000L); + .setInheritance(null) + .setUpdatedAt(1_600_000_000L); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleIndexerTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleIndexerTest.java index f1a7a3d73ce..95cc05a6240 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleIndexerTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleIndexerTest.java @@ -24,14 +24,12 @@ import org.junit.Rule; import org.junit.Test; import org.sonar.api.config.MapSettings; import org.sonar.api.rule.RuleKey; -import org.sonar.api.rule.Severity; import org.sonar.api.utils.System2; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.organization.OrganizationTesting; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.es.EsTester; @@ -60,23 +58,24 @@ public class ActiveRuleIndexerTest { public EsTester esTester = new EsTester(new RuleIndexDefinition(new MapSettings())); @Rule - public DbTester dbTester = DbTester.create(System2.INSTANCE); + public DbTester db = DbTester.create(System2.INSTANCE); - private ActiveRuleIndexer indexer = new ActiveRuleIndexer(system2, dbTester.getDbClient(), esTester.client()); - - private OrganizationDto organization = OrganizationTesting.newOrganizationDto(); + private ActiveRuleIndexer underTest = new ActiveRuleIndexer(system2, db.getDbClient(), esTester.client()); @Test public void index_nothing() { - indexer.index(Iterators.emptyIterator()); + underTest.index(Iterators.emptyIterator()); assertThat(esTester.countDocuments(INDEX_TYPE_ACTIVE_RULE)).isZero(); } @Test - public void index() { - dbTester.prepareDbUnit(getClass(), "index.xml"); + public void test_index() { + RuleDefinitionDto rule = db.rules().insert(); + OrganizationDto org = db.organizations().insert(); + QProfileDto profile = db.qualityProfiles().insert(org); + db.qualityProfiles().activateRule(profile, rule); - indexer.index(); + underTest.index(); assertThat(esTester.countDocuments(INDEX_TYPE_ACTIVE_RULE)).isEqualTo(1); } @@ -90,7 +89,7 @@ public class ActiveRuleIndexerTest { newDoc(ActiveRuleKey.of(QUALITY_PROFILE_KEY2, RULE_KEY_3))); assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).hasSize(4); - indexer.deleteByProfileKeys(asList(QUALITY_PROFILE_KEY1)); + underTest.deleteByProfileKeys(asList(QUALITY_PROFILE_KEY1)); assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).containsOnly( ActiveRuleKey.of(QUALITY_PROFILE_KEY2, RULE_KEY_2).toString(), @@ -106,7 +105,7 @@ public class ActiveRuleIndexerTest { newDoc(ActiveRuleKey.of(QUALITY_PROFILE_KEY2, RULE_KEY_3))); assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).hasSize(4); - indexer.deleteByProfileKeys(asList(QUALITY_PROFILE_KEY1, QUALITY_PROFILE_KEY2)); + underTest.deleteByProfileKeys(asList(QUALITY_PROFILE_KEY1, QUALITY_PROFILE_KEY2)); assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).isEmpty(); } @@ -126,7 +125,7 @@ public class ActiveRuleIndexerTest { assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).hasSize(4); - indexer.index(asList( + underTest.index(asList( ActiveRuleChange.createFor(ACTIVATED, activeRuleKey1), ActiveRuleChange.createFor(DEACTIVATED, activeRuleKey2), ActiveRuleChange.createFor(DEACTIVATED, activeRuleKey3))); @@ -138,43 +137,30 @@ public class ActiveRuleIndexerTest { @Test public void index_from_changes_index_new_active_rule() throws Exception { - long yesterday = 1000000L; - long now = 2000000L; - - // Index one active rule - RuleDefinitionDto rule = RuleTesting.newRule(RULE_KEY_1); - dbTester.rules().insert(rule); - RulesProfileDto profile = RulesProfileDto.createFor("qp") - .setOrganizationUuid(organization.getUuid()) - .setLanguage("xoo") - .setName("profile"); - dbTester.getDbClient().qualityProfileDao().insert(dbTester.getSession(), profile); - ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule).setSeverity(Severity.BLOCKER) - .setCreatedAt(yesterday).setUpdatedAt(yesterday); - dbTester.getDbClient().activeRuleDao().insert(dbTester.getSession(), activeRule); - dbTester.getSession().commit(); - - indexer.index(); - - assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).containsOnly(activeRule.getKey().toString()); + long yesterday = 1_000; + long now = 2_000L; + RuleDefinitionDto rule = db.rules().insert(); + OrganizationDto org = db.organizations().insert(); + QProfileDto profile1 = db.qualityProfiles().insert(org); + ActiveRuleDto activeRule1 = db.qualityProfiles().activateRule(profile1, rule, ar -> ar.setUpdatedAt(yesterday)); + + underTest.index(); + + assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).containsOnly(activeRule1.getKey().toString()); // Index another active rule - RuleDefinitionDto rule2 = RuleTesting.newRule(RULE_KEY_2); - dbTester.rules().insert(rule2); - ActiveRuleDto activeRule2 = ActiveRuleDto.createFor(profile, rule2).setSeverity(Severity.CRITICAL) - .setCreatedAt(now).setUpdatedAt(now); - dbTester.getDbClient().activeRuleDao().insert(dbTester.getSession(), activeRule2); - dbTester.getSession().commit(); + QProfileDto profile2 = db.qualityProfiles().insert(org); + ActiveRuleDto activeRule2 = db.qualityProfiles().activateRule(profile2, rule, ar -> ar.setUpdatedAt(now)); - indexer.index(singletonList(ActiveRuleChange.createFor(ACTIVATED, activeRule2.getKey()))); + underTest.index(singletonList(ActiveRuleChange.createFor(ACTIVATED, activeRule2.getKey()))); assertThat(esTester.getIds(INDEX_TYPE_ACTIVE_RULE)).containsOnly( - activeRule.getKey().toString(), + activeRule1.getKey().toString(), activeRule2.getKey().toString()); } private void indexActiveRules(ActiveRuleDoc... docs) { - indexer.index(asList(docs).iterator()); + underTest.index(asList(docs).iterator()); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIteratorTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIteratorTest.java index abd481a0b3a..467a91be551 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIteratorTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/index/ActiveRuleResultSetIteratorTest.java @@ -21,117 +21,92 @@ package org.sonar.server.qualityprofile.index; import com.google.common.collect.Maps; import java.util.Map; +import org.junit.Before; import org.junit.Rule; import org.junit.Test; -import org.sonar.api.rule.RuleKey; import org.sonar.api.utils.System2; import org.sonar.db.DbTester; +import org.sonar.db.organization.OrganizationDto; +import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; +import org.sonar.db.qualityprofile.QProfileDto; +import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.server.qualityprofile.ActiveRule; import static org.assertj.core.api.Assertions.assertThat; -import static org.sonar.api.rule.Severity.BLOCKER; import static org.sonar.api.rule.Severity.CRITICAL; -import static org.sonar.api.rule.Severity.INFO; import static org.sonar.server.qualityprofile.ActiveRule.Inheritance.INHERITED; public class ActiveRuleResultSetIteratorTest { @Rule - public DbTester dbTester = DbTester.create(System2.INSTANCE); - + public DbTester db = DbTester.create(System2.INSTANCE); + + private RuleDefinitionDto rule; + private OrganizationDto org; + private QProfileDto profile1; + private QProfileDto profile2; + + @Before + public void before() { + rule = db.rules().insert(); + org = db.organizations().insert(); + profile1 = db.qualityProfiles().insert(org); + profile2 = db.qualityProfiles().insert(org); + } @Test - public void iterator_over_one_active_rule() { - dbTester.prepareDbUnit(getClass(), "one_active_rule.xml"); - ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(dbTester.getDbClient(), dbTester.getSession(), 0L); + public void iterate_over_one_active_rule() { + ActiveRuleDto dto = db.qualityProfiles().activateRule(profile1, rule, ar -> ar.setSeverity(CRITICAL).setInheritance(null)); + + ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(db.getDbClient(), db.getSession(), 0L); Map<ActiveRuleKey, ActiveRuleDoc> activeRulesByKey = activeRulesByKey(it); it.close(); assertThat(activeRulesByKey).hasSize(1); - ActiveRuleKey key = ActiveRuleKey.of("sonar-way", RuleKey.of("xoo", "S001")); + ActiveRuleKey key = ActiveRuleKey.of(profile1.getKee(), rule.getKey()); ActiveRuleDoc activeRule = activeRulesByKey.get(key); - assertThat(activeRule.organizationUuid()).isEqualTo("org-123"); + assertThat(activeRule.organizationUuid()).isEqualTo(org.getUuid()); assertThat(activeRule.key()).isEqualTo(key); assertThat(activeRule.severity()).isEqualTo(CRITICAL); assertThat(activeRule.inheritance()).isEqualTo(ActiveRule.Inheritance.NONE); - assertThat(activeRule.createdAt()).isEqualTo(1_500_000_000_000L); - assertThat(activeRule.updatedAt()).isEqualTo(1_600_000_000_000L); + assertThat(activeRule.updatedAt()).isEqualTo(dto.getUpdatedAt()); } @Test - public void iterator_over_active_rules() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); - ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(dbTester.getDbClient(), dbTester.getSession(), 0L); - Map<ActiveRuleKey, ActiveRuleDoc> activeRulesByKey = activeRulesByKey(it); - it.close(); - - assertThat(activeRulesByKey).hasSize(3); + public void iterate_over_multiple_active_rules() { + ActiveRuleDto dto1 = db.qualityProfiles().activateRule(profile1, rule); + ActiveRuleDto dto2 = db.qualityProfiles().activateRule(profile2, rule); - ActiveRuleKey key = ActiveRuleKey.of("sonar-way", RuleKey.of("xoo", "S002")); - ActiveRuleDoc activeRule = activeRulesByKey.get(key); - assertThat(activeRule.organizationUuid()).isEqualTo("org-123"); - assertThat(activeRule.key()).isEqualTo(key); - assertThat(activeRule.severity()).isEqualTo(CRITICAL); - assertThat(activeRule.inheritance()).isEqualTo(ActiveRule.Inheritance.NONE); - assertThat(activeRule.createdAt()).isEqualTo(2_000_000_000_000L); - assertThat(activeRule.updatedAt()).isEqualTo(2_100_000_000_000L); - - key = ActiveRuleKey.of("parent", RuleKey.of("xoo", "S001")); - activeRule = activeRulesByKey.get(key); - assertThat(activeRule.organizationUuid()).isEqualTo("org-123"); - assertThat(activeRule.key()).isEqualTo(key); - assertThat(activeRule.severity()).isEqualTo(INFO); - assertThat(activeRule.inheritance()).isEqualTo(ActiveRule.Inheritance.NONE); - assertThat(activeRule.createdAt()).isEqualTo(1_700_000_000_000L); - assertThat(activeRule.updatedAt()).isEqualTo(1_800_000_000_000L); - - key = ActiveRuleKey.of("child", RuleKey.of("xoo", "S001")); - activeRule = activeRulesByKey.get(key); - assertThat(activeRule.organizationUuid()).isEqualTo("org-123"); - assertThat(activeRule.key()).isEqualTo(key); - assertThat(activeRule.severity()).isEqualTo(BLOCKER); - assertThat(activeRule.inheritance()).isEqualTo(INHERITED); - assertThat(activeRule.createdAt()).isEqualTo(1_500_000_000_000L); - assertThat(activeRule.updatedAt()).isEqualTo(1_600_000_000_000L); - } - - @Test - public void active_rule_with_inherited_inheritance() { - dbTester.prepareDbUnit(getClass(), "active_rule_with_inherited_inheritance.xml"); - ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(dbTester.getDbClient(), dbTester.getSession(), 0L); + ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(db.getDbClient(), db.getSession(), 0L); Map<ActiveRuleKey, ActiveRuleDoc> activeRulesByKey = activeRulesByKey(it); it.close(); assertThat(activeRulesByKey).hasSize(2); - - ActiveRuleKey key = ActiveRuleKey.of("child", RuleKey.of("xoo", "S001")); - ActiveRuleDoc activeRule = activeRulesByKey.get(key); - assertThat(activeRule.inheritance()).isEqualTo(INHERITED); + assertThat(activeRulesByKey.keySet()).containsExactlyInAnyOrder(dto1.getKey(), dto2.getKey()); } @Test - public void active_rule_with_overrides_inheritance() { - dbTester.prepareDbUnit(getClass(), "active_rule_with_overrides_inheritance.xml"); - ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(dbTester.getDbClient(), dbTester.getSession(), 0L); + public void iterate_inherited_active_rule() { + ActiveRuleDto dto = db.qualityProfiles().activateRule(profile1, rule, ar -> ar.setInheritance(INHERITED.name())); + + ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(db.getDbClient(), db.getSession(), 0L); Map<ActiveRuleKey, ActiveRuleDoc> activeRulesByKey = activeRulesByKey(it); it.close(); - assertThat(activeRulesByKey).hasSize(2); - - ActiveRuleKey key = ActiveRuleKey.of("child", RuleKey.of("xoo", "S001")); - ActiveRuleDoc activeRule = activeRulesByKey.get(key); - assertThat(activeRule.inheritance()).isEqualTo(ActiveRule.Inheritance.OVERRIDES); + assertThat(activeRulesByKey).hasSize(1); + assertThat(activeRulesByKey.get(dto.getKey()).inheritance()).isEqualTo(INHERITED); } @Test public void select_after_date() { - dbTester.prepareDbUnit(getClass(), "shared.xml"); - ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(dbTester.getDbClient(), dbTester.getSession(), 1_900_000_000_000L); + ActiveRuleDto dto1 = db.qualityProfiles().activateRule(profile1, rule, ar -> ar.setUpdatedAt(1_500L)); + ActiveRuleDto dto2 = db.qualityProfiles().activateRule(profile2, rule, ar -> ar.setUpdatedAt(1_600L)); + ActiveRuleResultSetIterator it = ActiveRuleResultSetIterator.create(db.getDbClient(), db.getSession(), 1_550L); assertThat(it.hasNext()).isTrue(); ActiveRuleDoc doc = it.next(); - assertThat(doc.key()).isEqualTo(ActiveRuleKey.of("sonar-way", RuleKey.of("xoo", "S002"))); + assertThat(doc.key()).isEqualTo(dto2.getKey()); assertThat(it.hasNext()).isFalse(); it.close(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRuleActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRuleActionTest.java index e672b00b864..2147e7b5be7 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRuleActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRuleActionTest.java @@ -34,7 +34,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.exceptions.ForbiddenException; @@ -102,7 +102,7 @@ public class ActivateRuleActionTest { @Test public void should_fail_if_not_organization_quality_profile_administrator() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("rule_key", RuleTesting.newRuleDto().getKey().toString()) @@ -117,7 +117,7 @@ public class ActivateRuleActionTest { public void fail_activate_if_built_in_profile() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, profile -> profile.setIsBuiltIn(true).setName("Xoo profile").setLanguage("xoo")); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, profile -> profile.setIsBuiltIn(true).setName("Xoo profile").setLanguage("xoo")); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("rule_key", RuleTesting.newRuleDto().getKey().toString()) @@ -132,7 +132,7 @@ public class ActivateRuleActionTest { @Test public void activate_rule_in_default_organization() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization); RuleKey ruleKey = RuleTesting.randomRuleKey(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") @@ -156,7 +156,7 @@ public class ActivateRuleActionTest { @Test public void activate_rule_in_specific_organization() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, organization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); RuleKey ruleKey = RuleTesting.randomRuleKey(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRulesActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRulesActionTest.java index f12867f12c0..4c53be97188 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRulesActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ActivateRulesActionTest.java @@ -28,7 +28,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.UnauthorizedException; @@ -110,7 +110,7 @@ public class ActivateRulesActionTest { @Test public void fail_if_built_in_profile() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, p -> p.setIsBuiltIn(true)); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, p -> p.setIsBuiltIn(true)); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("profile_key", qualityProfile.getKee()); @@ -123,7 +123,7 @@ public class ActivateRulesActionTest { @Test public void should_fail_if_not_organization_quality_profile_administrator() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("profile_key", qualityProfile.getKee()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/AddProjectActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/AddProjectActionTest.java index 31c72d476c7..842f92cda66 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/AddProjectActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/AddProjectActionTest.java @@ -31,7 +31,7 @@ import org.sonar.db.DbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; import org.sonar.server.component.TestComponentFinder; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.exceptions.UnauthorizedException; @@ -83,7 +83,7 @@ public class AddProjectActionTest { public void add_project_on_profile_of_default_organization() { logInAsProfileAdmin(db.getDefaultOrganization()); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); TestResponse response = call(project, profile); assertThat(response.getStatus()).isEqualTo(HttpURLConnection.HTTP_NO_CONTENT); @@ -96,7 +96,7 @@ public class AddProjectActionTest { OrganizationDto org1 = db.organizations().insert(); logInAsProfileAdmin(org1); ComponentDto project = db.components().insertPrivateProject(org1); - RulesProfileDto profile = db.qualityProfiles().insert(org1, p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profile = db.qualityProfiles().insert(org1, p -> p.setLanguage(LANGUAGE_1)); TestResponse response = call(org1, project, profile); assertThat(response.getStatus()).isEqualTo(HttpURLConnection.HTTP_NO_CONTENT); @@ -110,7 +110,7 @@ public class AddProjectActionTest { OrganizationDto org2 = db.organizations().insert(); logInAsProfileAdmin(org1); ComponentDto project = db.components().insertPrivateProject(org1); - RulesProfileDto profileInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profileInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(LANGUAGE_1)); expectedException.expect(IllegalArgumentException.class); expectedException.expectMessage("Project and Quality profile must have same organization"); @@ -126,7 +126,7 @@ public class AddProjectActionTest { OrganizationDto org2 = db.organizations().insert(); logInAsProfileAdmin(org1); ComponentDto project = db.components().insertPrivateProject(org1); - RulesProfileDto profileInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profileInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(LANGUAGE_1)); expectedException.expect(NotFoundException.class); expectedException @@ -143,9 +143,9 @@ public class AddProjectActionTest { ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); // two profiles on same language - RulesProfileDto profile1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); - RulesProfileDto profile2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); - db.qualityProfiles().associateProjectWithQualityProfile(project, profile1); + QProfileDto profile1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profile2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); + db.qualityProfiles().associateWithProject(project, profile1); call(project, profile2); @@ -157,10 +157,10 @@ public class AddProjectActionTest { public void changing_association_does_not_change_other_language_associations() throws Exception { logInAsProfileAdmin(db.getDefaultOrganization()); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile1Language1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); - RulesProfileDto profile2Language2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_2)); - RulesProfileDto profile3Language1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); - db.qualityProfiles().associateProjectWithQualityProfile(project, profile1Language1, profile2Language2); + QProfileDto profile1Language1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profile2Language2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_2)); + QProfileDto profile3Language1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); + db.qualityProfiles().associateWithProject(project, profile1Language1, profile2Language2); call(project, profile3Language1); @@ -171,7 +171,7 @@ public class AddProjectActionTest { @Test public void project_administrator_can_change_profile() throws Exception { ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); userSession.logIn().addProjectPermission(UserRole.ADMIN, project); call(project, profile); @@ -183,7 +183,7 @@ public class AddProjectActionTest { public void throw_ForbiddenException_if_not_project_nor_organization_administrator() { userSession.logIn(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(ForbiddenException.class); expectedException.expectMessage("Insufficient privileges"); @@ -195,7 +195,7 @@ public class AddProjectActionTest { public void throw_UnauthorizedException_if_not_logged_in() { userSession.anonymous(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(UnauthorizedException.class); expectedException.expectMessage("Authentication is required"); @@ -206,7 +206,7 @@ public class AddProjectActionTest { @Test public void throw_NotFoundException_if_project_does_not_exist() { logInAsProfileAdmin(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(NotFoundException.class); expectedException.expectMessage("Component id 'unknown' not found"); @@ -231,13 +231,13 @@ public class AddProjectActionTest { .execute(); } - private void assertProjectIsAssociatedToProfile(ComponentDto project, RulesProfileDto profile) { - RulesProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); + private void assertProjectIsAssociatedToProfile(ComponentDto project, QProfileDto profile) { + QProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); assertThat(loaded.getKee()).isEqualTo(profile.getKee()); } - private void assertProjectIsNotAssociatedToProfile(ComponentDto project, RulesProfileDto profile) { - RulesProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); + private void assertProjectIsNotAssociatedToProfile(ComponentDto project, QProfileDto profile) { + QProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); assertThat(loaded == null || !loaded.getKee().equals(profile.getKee())).isTrue(); } @@ -245,14 +245,14 @@ public class AddProjectActionTest { userSession.logIn().addPermission(ADMINISTER_QUALITY_PROFILES, organization); } - private TestResponse call(ComponentDto project, RulesProfileDto qualityProfile) { + private TestResponse call(ComponentDto project, QProfileDto qualityProfile) { TestRequest request = tester.newRequest() .setParam("projectUuid", project.uuid()) .setParam("profileKey", qualityProfile.getKee()); return request.execute(); } - private TestResponse call(OrganizationDto organization, ComponentDto project, RulesProfileDto qualityProfile) { + private TestResponse call(OrganizationDto organization, ComponentDto project, QProfileDto qualityProfile) { TestRequest request = tester.newRequest() .setParam("organization", organization.getKey()) .setParam("projectUuid", project.uuid()) diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/BackupActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/BackupActionTest.java index 35e5c90a6b0..e7a7f0b9a95 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/BackupActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/BackupActionTest.java @@ -26,7 +26,7 @@ import org.sonar.api.resources.Languages; import org.sonar.api.server.ws.WebService; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.language.LanguageTesting; @@ -78,7 +78,7 @@ public class BackupActionTest { @Test public void returns_backup_of_profile_with_specified_key() throws Exception { - RulesProfileDto profile = db.qualityProfiles().insertQualityProfile(QualityProfileTesting.newQualityProfileDto()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); TestResponse response = tester.newRequest().setParam("profileKey", profile.getKee()).execute(); assertThat(response.getMediaType()).isEqualTo("application/xml"); @@ -88,8 +88,7 @@ public class BackupActionTest { @Test public void returns_backup_of_profile_with_specified_name_on_default_organization() throws Exception { - RulesProfileDto profile = newProfile(db.getDefaultOrganization()); - db.qualityProfiles().insertQualityProfile(profile); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(A_LANGUAGE)); TestResponse response = tester.newRequest() .setParam("language", profile.getLanguage()) @@ -101,8 +100,7 @@ public class BackupActionTest { @Test public void returns_backup_of_profile_with_specified_name_and_organization() throws Exception { OrganizationDto org = db.organizations().insert(); - RulesProfileDto profile = newProfile(org); - db.qualityProfiles().insertQualityProfile(profile); + QProfileDto profile = db.qualityProfiles().insert(org, p -> p.setLanguage(A_LANGUAGE)); TestResponse response = tester.newRequest() .setParam("organization", org.getKey()) @@ -135,13 +133,12 @@ public class BackupActionTest { @Test public void throws_NotFoundException_if_profile_name_exists_but_in_another_organization() throws Exception { OrganizationDto org1 = db.organizations().insert(); - RulesProfileDto profileInOrg1 = newProfile(org1); - db.qualityProfiles().insertQualityProfile(profileInOrg1); + QProfileDto profileInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(A_LANGUAGE)); OrganizationDto org2 = db.organizations().insert(); - RulesProfileDto profileInOrg2 = newProfile(org2).setLanguage(profileInOrg1.getLanguage()); + QProfileDto profileInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(A_LANGUAGE)); expectedException.expect(NotFoundException.class); - expectedException.expectMessage("Quality Profile for language 'xoo' and name '" + profileInOrg1.getName() + "' does not exist in organization '" + org2.getKey() +"'"); + expectedException.expectMessage("Quality Profile for language 'xoo' and name '" + profileInOrg1.getName() + "' does not exist in organization '" + org2.getKey() + "'"); tester.newRequest() .setParam("organization", org2.getKey()) @@ -157,7 +154,7 @@ public class BackupActionTest { tester.newRequest().execute(); } - private static String xmlForProfileWithoutRules(RulesProfileDto profile) { + private static String xmlForProfileWithoutRules(QProfileDto profile) { return "<?xml version='1.0' encoding='UTF-8'?>" + "<profile>" + " <name>" + profile.getName() + "</name>" + @@ -166,7 +163,7 @@ public class BackupActionTest { "</profile>"; } - private static RulesProfileDto newProfile(OrganizationDto org) { + private static QProfileDto newProfile(OrganizationDto org) { return QualityProfileTesting.newQualityProfileDto() .setLanguage(A_LANGUAGE) .setOrganizationUuid(org.getUuid()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangeParentActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangeParentActionTest.java index 7cb6d5ce44a..7ccb0d9a78a 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangeParentActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangeParentActionTest.java @@ -40,8 +40,8 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; -import org.sonar.db.qualityprofile.RulesProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.es.EsClient; @@ -154,8 +154,8 @@ public class ChangeParentActionTest { @Test public void change_parent_with_no_parent_before() throws Exception { - RulesProfileDto parent1 = createProfile(); - RulesProfileDto child = createProfile(); + QProfileDto parent1 = createProfile(); + QProfileDto child = createProfile(); RuleDefinitionDto rule1 = createRule(); createActiveRule(rule1, parent1); @@ -181,9 +181,9 @@ public class ChangeParentActionTest { @Test public void replace_existing_parent() throws Exception { - RulesProfileDto parent1 = createProfile(); - RulesProfileDto parent2 = createProfile(); - RulesProfileDto child = createProfile(); + QProfileDto parent1 = createProfile(); + QProfileDto parent2 = createProfile(); + QProfileDto child = createProfile(); RuleDefinitionDto rule1 = createRule(); RuleDefinitionDto rule2 = createRule(); @@ -212,8 +212,8 @@ public class ChangeParentActionTest { @Test public void remove_parent() throws Exception { - RulesProfileDto parent = createProfile(); - RulesProfileDto child = createProfile(); + QProfileDto parent = createProfile(); + QProfileDto child = createProfile(); RuleDefinitionDto rule1 = createRule(); createActiveRule(rule1, parent); @@ -238,9 +238,9 @@ public class ChangeParentActionTest { @Test public void change_parent_with_names() throws Exception { - RulesProfileDto parent1 = createProfile(); - RulesProfileDto parent2 = createProfile(); - RulesProfileDto child = createProfile(); + QProfileDto parent1 = createProfile(); + QProfileDto parent2 = createProfile(); + QProfileDto child = createProfile(); RuleDefinitionDto rule1 = createRule(); RuleDefinitionDto rule2 = createRule(); @@ -300,8 +300,8 @@ public class ChangeParentActionTest { @Test public void remove_parent_with_empty_key() throws Exception { - RulesProfileDto parent = createProfile(); - RulesProfileDto child = createProfile(); + QProfileDto parent = createProfile(); + QProfileDto child = createProfile(); RuleDefinitionDto rule1 = createRule(); createActiveRule(rule1, parent); @@ -328,7 +328,7 @@ public class ChangeParentActionTest { @Test public void fail_if_built_in_profile() { - RulesProfileDto child = dbTester.qualityProfiles().insert(organization, p -> p + QProfileDto child = dbTester.qualityProfiles().insert(organization, p -> p .setLanguage(language.getKey()) .setIsBuiltIn(true)); @@ -347,7 +347,7 @@ public class ChangeParentActionTest { @Test public void fail_if_parent_key_and_name_both_set() throws Exception { - RulesProfileDto child = createProfile(); + QProfileDto child = createProfile(); assertThat(dbClient.activeRuleDao().selectByProfileKey(dbSession, child.getKee())).isEmpty(); assertThat(ruleIndex.search(new RuleQuery().setActivation(true).setQProfileKey(child.getKee()), new SearchOptions()).getIds()).isEmpty(); @@ -364,7 +364,7 @@ public class ChangeParentActionTest { @Test public void fail_if_profile_key_and_name_both_set() throws Exception { - RulesProfileDto child = createProfile(); + QProfileDto child = createProfile(); assertThat(dbClient.activeRuleDao().selectByProfileKey(dbSession, child.getKee())).isEmpty(); assertThat(ruleIndex.search(new RuleQuery().setActivation(true).setQProfileKey(child.getKee()), new SearchOptions()).getIds()).isEmpty(); @@ -384,7 +384,7 @@ public class ChangeParentActionTest { public void fail_if_missing_permission() throws Exception { userSessionRule.logIn(); - RulesProfileDto child = createProfile(); + QProfileDto child = createProfile(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") @@ -400,7 +400,7 @@ public class ChangeParentActionTest { OrganizationDto organization2 = dbTester.organizations().insert(); userSessionRule.logIn().addPermission(ADMINISTER_QUALITY_PROFILES, organization2.getUuid()); - RulesProfileDto child = createProfile(); + QProfileDto child = createProfile(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") @@ -411,8 +411,8 @@ public class ChangeParentActionTest { request.execute(); } - private RulesProfileDto createProfile() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto() + private QProfileDto createProfile() { + QProfileDto profile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()) .setLanguage(language.getKey()); dbClient.qualityProfileDao().insert(dbSession, profile); @@ -430,7 +430,7 @@ public class ChangeParentActionTest { return rule; } - private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, RulesProfileDto profile) { + private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, QProfileDto profile) { ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule) .setSeverity(rule.getSeverityString()); dbClient.activeRuleDao().insert(dbSession, activeRule); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogActionDatabaseTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogActionDatabaseTest.java index 5cf45fdfd42..4238b37a41d 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogActionDatabaseTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogActionDatabaseTest.java @@ -29,7 +29,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.QProfileChangeDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.organization.DefaultOrganizationProvider; @@ -67,7 +67,7 @@ public class ChangelogActionDatabaseTest { @Test public void find_changelog_by_profileKey() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); String response = wsTester.newRequest() .setMethod("GET") @@ -80,7 +80,7 @@ public class ChangelogActionDatabaseTest { @Test public void find_changelog_by_language_and_name() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(dbTester.getDefaultOrganization()); String response = wsTester.newRequest() .setMethod("GET") @@ -94,7 +94,7 @@ public class ChangelogActionDatabaseTest { @Test public void find_changelog_by_organization_and_language_and_name() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); String response = wsTester.newRequest() .setMethod("GET") @@ -112,7 +112,7 @@ public class ChangelogActionDatabaseTest { OrganizationDto organization1 = dbTester.organizations().insert(); OrganizationDto organization2 = dbTester.organizations().insert(); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization1); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization1); TestRequest request = wsTester.newRequest() .setMethod("GET") @@ -127,7 +127,7 @@ public class ChangelogActionDatabaseTest { @Test public void changelog_empty() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); String response = wsTester.newRequest() .setMethod("GET") @@ -141,7 +141,7 @@ public class ChangelogActionDatabaseTest { @Test public void changelog_not_empty() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); QProfileChangeDto change = QualityProfileTesting.newQProfileChangeDto() .setKey(null) .setCreatedAt(0) diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogLoaderTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogLoaderTest.java index 5bed5e40245..f479d14af9c 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogLoaderTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ChangelogLoaderTest.java @@ -29,6 +29,7 @@ import org.sonar.api.utils.System2; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.qualityprofile.QProfileChangeDto; +import org.sonar.db.qualityprofile.QProfileChangeMapper; import org.sonar.db.qualityprofile.QProfileChangeQuery; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.db.rule.RuleDefinitionDto; @@ -155,7 +156,7 @@ public class ChangelogLoaderTest { .setLogin(login) .setChangeType(type.name()) .setData(data); - QualityProfileTesting.insert(dbTester, dto); + insert(dto); } private void insertRule(RuleKey key, String name) { @@ -171,4 +172,13 @@ public class ChangelogLoaderTest { dbTester.getDbClient().userDao().insert(dbTester.getSession(), dto); dbTester.getSession().commit(); } + + public void insert(QProfileChangeDto dto) { + // do not use QProfileChangeDao so that generated fields key and creation date + // can be defined by tests + DbSession dbSession = dbTester.getSession(); + QProfileChangeMapper mapper = dbSession.getMapper(QProfileChangeMapper.class); + mapper.insert(dto); + dbSession.commit(); + } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionMediumTest.java index 0c1c00f6af0..4de309afa09 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionMediumTest.java @@ -34,7 +34,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; @@ -99,7 +99,7 @@ public class CompareActionMediumTest { * - rule 4 active with different parameters => "modified" * - rule 5 active with different severity => "modified" */ - RulesProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); + QProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); createActiveRule(rule1, profile1); createActiveRule(rule2, profile1); createActiveRuleWithParam(rule4, profile1, "polop"); @@ -112,7 +112,7 @@ public class CompareActionMediumTest { * - rule 3 active (only in this profile) => "inRight" * - rule 4 active with different parameters => "modified" */ - RulesProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); + QProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); createActiveRule(rule1, profile2); createActiveRule(rule3, profile2); createActiveRuleWithParam(rule4, profile2, "palap"); @@ -129,9 +129,9 @@ public class CompareActionMediumTest { public void compare_param_on_left() throws Exception { RuleDefinitionDto rule1 = createRuleWithParam("xoo", "rule1"); createRepository("blah", "xoo", "Blah"); - RulesProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); + QProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); createActiveRuleWithParam(rule1, profile1, "polop"); - RulesProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); + QProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); createActiveRule(rule1, profile2); session.commit(); @@ -145,9 +145,9 @@ public class CompareActionMediumTest { public void compare_param_on_right() throws Exception { RuleDefinitionDto rule1 = createRuleWithParam("xoo", "rule1"); createRepository("blah", "xoo", "Blah"); - RulesProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); + QProfileDto profile1 = createProfile("xoo", "Profile 1", "xoo-profile-1-01234"); createActiveRule(rule1, profile1); - RulesProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); + QProfileDto profile2 = createProfile("xoo", "Profile 2", "xoo-profile-2-12345"); createActiveRuleWithParam(rule1, profile2, "polop"); session.commit(); @@ -189,8 +189,8 @@ public class CompareActionMediumTest { .execute(); } - private RulesProfileDto createProfile(String lang, String name, String key) { - RulesProfileDto profile = QProfileTesting.newQProfileDto("org-123", new QProfileName(lang, name), key); + private QProfileDto createProfile(String lang, String name, String key) { + QProfileDto profile = QProfileTesting.newQProfileDto("org-123", new QProfileName(lang, name), key); db.qualityProfileDao().insert(session, profile); session.commit(); return profile; @@ -218,14 +218,14 @@ public class CompareActionMediumTest { return rule; } - private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, RulesProfileDto profile) { + private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, QProfileDto profile) { ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule) .setSeverity(rule.getSeverityString()); db.activeRuleDao().insert(session, activeRule); return activeRule; } - private ActiveRuleDto createActiveRuleWithParam(RuleDefinitionDto rule, RulesProfileDto profile, String value) { + private ActiveRuleDto createActiveRuleWithParam(RuleDefinitionDto rule, QProfileDto profile, String value) { ActiveRuleDto activeRule = createActiveRule(rule, profile); RuleParamDto paramDto = db.ruleDao().selectRuleParamsByRuleKey(session, rule.getKey()).get(0); ActiveRuleParamDto activeRuleParam = ActiveRuleParamDto.createFor(paramDto).setValue(value); @@ -233,7 +233,7 @@ public class CompareActionMediumTest { return activeRule; } - private ActiveRuleDto createActiveRuleWithSeverity(RuleDefinitionDto rule, RulesProfileDto profile, String severity) { + private ActiveRuleDto createActiveRuleWithSeverity(RuleDefinitionDto rule, QProfileDto profile, String severity) { ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule) .setSeverity(severity); db.activeRuleDao().insert(session, activeRule); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionTest.java index d546ff3968d..6f00aa6f86d 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CompareActionTest.java @@ -25,7 +25,7 @@ import org.junit.Test; import org.junit.rules.ExpectedException; import org.sonar.api.resources.Languages; import org.sonar.db.DbTester; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.qualityprofile.QProfileComparison; import org.sonar.server.tester.UserSessionRule; @@ -51,9 +51,9 @@ public class CompareActionTest { @Test public void should_not_allow_to_compare_quality_profiles_from_different_organizations() { - RulesProfileDto left = QualityProfileTesting.newQualityProfileDto(); - RulesProfileDto right = QualityProfileTesting.newQualityProfileDto(); - dbTester.qualityProfiles().insertQualityProfiles(left, right); + QProfileDto left = QualityProfileTesting.newQualityProfileDto(); + QProfileDto right = QualityProfileTesting.newQualityProfileDto(); + dbTester.qualityProfiles().insert(left, right); TestRequest request = wsTester.newRequest().setMethod("POST") .setParam("leftKey", left.getKee()) diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CopyActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CopyActionTest.java index afa90c5e8b3..a7f7fc21bcd 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CopyActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CopyActionTest.java @@ -34,7 +34,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.UnauthorizedException; import org.sonar.server.language.LanguageTesting; @@ -96,7 +96,7 @@ public class CopyActionTest { OrganizationDto organization = db.organizations().insert(); logInAsQProfileAdministrator(organization); - RulesProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); TestResponse response = tester.newRequest() .setMethod("POST") .setParam("fromKey", sourceProfile.getKee()) @@ -112,8 +112,8 @@ public class CopyActionTest { " \"isDefault\": false," + " \"isInherited\": false" + "}"); - RulesProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByNameAndLanguage(organization, "target-name", sourceProfile.getLanguage(), - db.getSession()); + QProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByNameAndLanguage(db.getSession(), organization, "target-name", sourceProfile.getLanguage() + ); assertThat(loadedProfile.getKee()).isEqualTo(generatedUuid); assertThat(loadedProfile.getParentKee()).isNull(); @@ -129,8 +129,8 @@ public class CopyActionTest { public void copy_rules_on_existing_profile_in_default_organization() throws Exception { OrganizationDto organization = db.organizations().insert(); logInAsQProfileAdministrator(organization); - RulesProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); - RulesProfileDto targetProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto targetProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); TestResponse response = tester.newRequest() .setMethod("POST") @@ -146,7 +146,7 @@ public class CopyActionTest { " \"isDefault\": false," + " \"isInherited\": false" + "}"); - RulesProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByKey(db.getSession(), targetProfile.getKee()); + QProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByUuid(db.getSession(), targetProfile.getKee()); assertThat(loadedProfile).isNotNull(); assertThat(backuper.backupedProfile.getKee()).isEqualTo(sourceProfile.getKee()); @@ -158,8 +158,8 @@ public class CopyActionTest { OrganizationDto organization = db.organizations().insert(); logInAsQProfileAdministrator(organization); - RulesProfileDto parentProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); - RulesProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE), p -> p.setParentKee(parentProfile.getKee())); + QProfileDto parentProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto sourceProfile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE).setParentKee(parentProfile.getKee())); TestResponse response = tester.newRequest() .setMethod("POST") @@ -176,8 +176,8 @@ public class CopyActionTest { " \"isDefault\": false," + " \"isInherited\": true" + "}"); - RulesProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByNameAndLanguage(organization, "target-name", sourceProfile.getLanguage(), - db.getSession()); + QProfileDto loadedProfile = db.getDbClient().qualityProfileDao().selectByNameAndLanguage(db.getSession(), organization, "target-name", sourceProfile.getLanguage() + ); assertThat(loadedProfile.getKee()).isEqualTo(generatedUuid); assertThat(loadedProfile.getParentKee()).isEqualTo(parentProfile.getKee()); @@ -206,7 +206,7 @@ public class CopyActionTest { @Test public void throw_ForbiddenException_if_not_profile_administrator_of_organization() { OrganizationDto organization = db.organizations().insert(); - RulesProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); userSession.logIn().addPermission(OrganizationPermission.SCAN, organization); expectedException.expect(ForbiddenException.class); @@ -222,7 +222,7 @@ public class CopyActionTest { @Test public void throw_ForbiddenException_if_not_profile_administrator() { OrganizationDto organization = db.organizations().insert(); - RulesProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); + QProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); userSession.logIn().addPermission(OrganizationPermission.SCAN, organization); expectedException.expect(ForbiddenException.class); @@ -269,11 +269,11 @@ public class CopyActionTest { private static class TestBackuper implements QProfileBackuper { - private RulesProfileDto backupedProfile; - private RulesProfileDto restoredProfile; + private QProfileDto backupedProfile; + private QProfileDto restoredProfile; @Override - public void backup(DbSession dbSession, RulesProfileDto profile, Writer backupWriter) { + public void backup(DbSession dbSession, QProfileDto profile, Writer backupWriter) { if (this.backupedProfile != null) { throw new IllegalStateException("Already backup-ed/backed-up"); } @@ -286,7 +286,7 @@ public class CopyActionTest { } @Override - public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, RulesProfileDto profile) { + public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, QProfileDto profile) { if (this.restoredProfile != null) { throw new IllegalStateException("Already restored"); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CreateActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CreateActionTest.java index e3d1f3961e1..ec2a070e406 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CreateActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/CreateActionTest.java @@ -38,7 +38,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.es.EsTester; @@ -115,7 +115,7 @@ public class CreateActionTest { CreateWsResponse response = executeRequest("New Profile", XOO_LANGUAGE); - RulesProfileDto dto = dbClient.qualityProfileDao().selectByNameAndLanguage(organization, "New Profile", XOO_LANGUAGE, dbSession); + QProfileDto dto = dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "New Profile", XOO_LANGUAGE); assertThat(dto.getKee()).isNotNull(); assertThat(dto.getLanguage()).isEqualTo(XOO_LANGUAGE); assertThat(dto.getName()).isEqualTo("New Profile"); @@ -137,7 +137,7 @@ public class CreateActionTest { executeRequest("New Profile", XOO_LANGUAGE, ImmutableMap.of("xoo_lint", "<xml/>")); - RulesProfileDto dto = dbClient.qualityProfileDao().selectByNameAndLanguage(organization, "New Profile", XOO_LANGUAGE, dbSession); + QProfileDto dto = dbClient.qualityProfileDao().selectByNameAndLanguage(dbSession, organization, "New Profile", XOO_LANGUAGE); assertThat(dto.getKee()).isNotNull(); assertThat(dbClient.activeRuleDao().selectByProfileKey(dbSession, dto.getKee())).hasSize(1); assertThat(ruleIndex.searchAll(new RuleQuery().setQProfileKey(dto.getKee()).setActivation(true))).hasSize(1); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRuleActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRuleActionTest.java index f4fb92d191a..06b47cab85d 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRuleActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRuleActionTest.java @@ -34,7 +34,7 @@ import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; import org.sonar.db.qualityprofile.ActiveRuleKey; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.exceptions.ForbiddenException; @@ -97,7 +97,7 @@ public class DeactivateRuleActionTest { @Test public void should_fail_if_not_organization_quality_profile_administrator() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("rule_key", RuleTesting.newRuleDto().getKey().toString()) @@ -111,7 +111,7 @@ public class DeactivateRuleActionTest { public void fail_deactivate_if_built_in_profile() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, profile -> profile.setIsBuiltIn(true)); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, profile -> profile.setIsBuiltIn(true)); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("rule_key", RuleTesting.newRuleDto().getKey().toString()) @@ -125,7 +125,7 @@ public class DeactivateRuleActionTest { @Test public void deactivate_rule_in_default_organization() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization); RuleKey ruleKey = RuleTesting.randomRuleKey(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") @@ -144,7 +144,7 @@ public class DeactivateRuleActionTest { @Test public void deactivate_rule_in_specific_organization() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, organization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); RuleKey ruleKey = RuleTesting.randomRuleKey(); TestRequest request = wsActionTester.newRequest() .setMethod("POST") diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRulesActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRulesActionTest.java index 667c612985a..f53472a4ddb 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRulesActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeactivateRulesActionTest.java @@ -28,8 +28,8 @@ import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; import org.sonar.server.exceptions.BadRequestException; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.UnauthorizedException; import org.sonar.server.organization.TestDefaultOrganizationProvider; @@ -108,7 +108,7 @@ public class DeactivateRulesActionTest { @Test public void fail_if_built_in_profile() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, p -> p.setIsBuiltIn(true)); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(defaultOrganization, p -> p.setIsBuiltIn(true)); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("profile_key", qualityProfile.getKee()); @@ -121,7 +121,7 @@ public class DeactivateRulesActionTest { @Test public void should_fail_if_not_organization_quality_profile_administrator() { userSession.logIn().addPermission(OrganizationPermission.ADMINISTER_QUALITY_PROFILES, defaultOrganization); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); TestRequest request = wsActionTester.newRequest() .setMethod("POST") .setParam("profile_key", qualityProfile.getKee()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeleteActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeleteActionTest.java index e2f93cd6666..a1b8bdb03c1 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeleteActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/DeleteActionTest.java @@ -31,8 +31,8 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; import org.sonar.server.exceptions.BadRequestException; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.exceptions.UnauthorizedException; @@ -73,9 +73,9 @@ public class DeleteActionTest { public void delete_profile_by_key() { OrganizationDto organization = dbTester.organizations().insert(); ComponentDto project = dbTester.components().insertPrivateProject(organization); - RulesProfileDto profile1 = createProfile(organization); - RulesProfileDto profile2 = createProfile(organization); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project, profile1); + QProfileDto profile1 = createProfile(organization); + QProfileDto profile2 = createProfile(organization); + dbTester.qualityProfiles().associateWithProject(project, profile1); logInAsQProfileAdministrator(organization); @@ -93,9 +93,9 @@ public class DeleteActionTest { public void delete_profile_by_language_and_name_in_default_organization() throws Exception { OrganizationDto organization = dbTester.getDefaultOrganization(); ComponentDto project = dbTester.components().insertPrivateProject(organization); - RulesProfileDto profile1 = createProfile(organization); - RulesProfileDto profile2 = createProfile(organization); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project, profile1); + QProfileDto profile1 = createProfile(organization); + QProfileDto profile2 = createProfile(organization); + dbTester.qualityProfiles().associateWithProject(project, profile1); logInAsQProfileAdministrator(organization); @@ -115,9 +115,9 @@ public class DeleteActionTest { public void delete_profile_by_language_and_name_in_specified_organization() { OrganizationDto organization = dbTester.organizations().insert(); ComponentDto project = dbTester.components().insertPrivateProject(organization); - RulesProfileDto profile1 = createProfile(organization); - RulesProfileDto profile2 = createProfile(organization); - dbTester.qualityProfiles().associateProjectWithQualityProfile(project, profile1); + QProfileDto profile1 = createProfile(organization); + QProfileDto profile2 = createProfile(organization); + dbTester.qualityProfiles().associateWithProject(project, profile1); logInAsQProfileAdministrator(organization); TestResponse response = tester.newRequest() @@ -135,7 +135,7 @@ public class DeleteActionTest { @Test public void fail_if_built_in_profile() { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile1 = dbTester.qualityProfiles().insert(organization, p -> p.setIsBuiltIn(true)); + QProfileDto profile1 = dbTester.qualityProfiles().insert(organization, p -> p.setIsBuiltIn(true)); logInAsQProfileAdministrator(organization); expectedException.expect(BadRequestException.class); @@ -151,8 +151,8 @@ public class DeleteActionTest { OrganizationDto organization1 = dbTester.organizations().insert(); OrganizationDto organization2 = dbTester.organizations().insert(); - RulesProfileDto profileInOrg1 = createProfile(organization1); - RulesProfileDto profileInOrg2 = createProfile(organization2); + QProfileDto profileInOrg1 = createProfile(organization1); + QProfileDto profileInOrg2 = createProfile(organization2); logInAsQProfileAdministrator(organization1); @@ -167,7 +167,7 @@ public class DeleteActionTest { @Test public void throw_UnauthorizedException_if_not_logged_in() { - RulesProfileDto profile = createProfile(dbTester.getDefaultOrganization()); + QProfileDto profile = createProfile(dbTester.getDefaultOrganization()); expectedException.expect(UnauthorizedException.class); @@ -192,7 +192,7 @@ public class DeleteActionTest { @Test public void throw_IAE_if_missing_language_parameter() { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = createProfile(organization); + QProfileDto profile = createProfile(organization); logInAsQProfileAdministrator(organization); expectedException.expect(IllegalArgumentException.class); @@ -208,7 +208,7 @@ public class DeleteActionTest { @Test public void throw_IAE_if_missing_name_parameter() throws Exception { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = createProfile(organization); + QProfileDto profile = createProfile(organization); logInAsQProfileAdministrator(organization); expectedException.expect(IllegalArgumentException.class); @@ -224,7 +224,7 @@ public class DeleteActionTest { @Test public void throw_IAE_if_too_many_parameters_to_reference_profile() { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = createProfile(organization); + QProfileDto profile = createProfile(organization); logInAsQProfileAdministrator(organization); expectedException.expect(IllegalArgumentException.class); @@ -255,8 +255,8 @@ public class DeleteActionTest { @Test public void throw_ISE_if_deleting_default_profile() { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = createProfile(organization); - dbTester.qualityProfiles().markAsDefault(profile); + QProfileDto profile = createProfile(organization); + dbTester.qualityProfiles().setAsDefault(profile); logInAsQProfileAdministrator(organization); expectedException.expect(IllegalArgumentException.class); @@ -271,10 +271,9 @@ public class DeleteActionTest { @Test public void throw_ISE_if_a_descendant_is_marked_as_default() { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto parentProfile = createProfile(organization); - RulesProfileDto childProfile = dbTester.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE), - p -> p.setParentKee(parentProfile.getKee())); - dbTester.qualityProfiles().markAsDefault(childProfile); + QProfileDto parentProfile = createProfile(organization); + QProfileDto childProfile = dbTester.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE).setParentKee(parentProfile.getKee())); + dbTester.qualityProfiles().setAsDefault(childProfile); logInAsQProfileAdministrator(organization); expectedException.expect(IllegalArgumentException.class); @@ -293,16 +292,16 @@ public class DeleteActionTest { .addPermission(ADMINISTER_QUALITY_PROFILES, organization); } - private void verifyProfileDoesNotExist(RulesProfileDto profile, OrganizationDto organization) { - assertThat(dbClient.qualityProfileDao().selectByKey(session, profile.getKee())).isNull(); - assertThat(dbClient.qualityProfileDao().selectSelectedProjects(organization, profile.getKee(), null, session)).isEmpty(); + private void verifyProfileDoesNotExist(QProfileDto profile, OrganizationDto organization) { + assertThat(dbClient.qualityProfileDao().selectByUuid(session, profile.getKee())).isNull(); + assertThat(dbClient.qualityProfileDao().selectSelectedProjects(session, organization, profile, null)).isEmpty(); } - private void verifyProfileExists(RulesProfileDto profile) { - assertThat(dbClient.qualityProfileDao().selectByKey(session, profile.getKee())).isNotNull(); + private void verifyProfileExists(QProfileDto profile) { + assertThat(dbClient.qualityProfileDao().selectByUuid(session, profile.getKee())).isNotNull(); } - private RulesProfileDto createProfile(OrganizationDto organization) { + private QProfileDto createProfile(OrganizationDto organization) { return dbTester.qualityProfiles().insert(organization, p -> p.setLanguage(A_LANGUAGE)); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ExportActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ExportActionTest.java index c98e763228a..397a0b4b76b 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ExportActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ExportActionTest.java @@ -35,7 +35,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.language.LanguageTesting; import org.sonar.server.organization.TestDefaultOrganizationProvider; @@ -92,7 +92,7 @@ public class ExportActionTest { @Test public void export_profile_in_default_organization() { - RulesProfileDto profile = createProfile(db.getDefaultOrganization(), false); + QProfileDto profile = createProfile(db.getDefaultOrganization(), false); WsActionTester tester = newWsActionTester(newExporter("polop"), newExporter("palap")); String result = tester.newRequest() @@ -107,7 +107,7 @@ public class ExportActionTest { @Test public void export_profile_in_specified_organization() { OrganizationDto organization = db.organizations().insert(); - RulesProfileDto profile = createProfile(organization, false); + QProfileDto profile = createProfile(organization, false); WsActionTester tester = newWsActionTester(newExporter("polop"), newExporter("palap")); String result = tester.newRequest() @@ -137,8 +137,8 @@ public class ExportActionTest { @Test public void export_default_profile() throws Exception { - RulesProfileDto nonDefaultProfile = createProfile(db.getDefaultOrganization(), false); - RulesProfileDto defaultProfile = createProfile(db.getDefaultOrganization(), true); + QProfileDto nonDefaultProfile = createProfile(db.getDefaultOrganization(), false); + QProfileDto defaultProfile = createProfile(db.getDefaultOrganization(), true); WsActionTester tester = newWsActionTester(newExporter("polop"), newExporter("palap")); String result = tester.newRequest() @@ -172,7 +172,7 @@ public class ExportActionTest { @Test public void return_backup_when_exporter_is_not_specified() throws Exception { OrganizationDto organization = db.getDefaultOrganization(); - RulesProfileDto profile = createProfile(organization, false); + QProfileDto profile = createProfile(organization, false); String result = newWsActionTester(newExporter("polop")).newRequest() .setParam("language", profile.getLanguage()) @@ -187,15 +187,15 @@ public class ExportActionTest { public void do_not_mismatch_profiles_with_other_organizations_and_languages() { OrganizationDto org1 = db.organizations().insert(); OrganizationDto org2 = db.organizations().insert(); - RulesProfileDto defaultJavaInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(JAVA_LANGUAGE), p -> p.setName("Sonar Way")); - RulesProfileDto nonDefaultJavaInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(JAVA_LANGUAGE), p -> p.setName("My Way")); - RulesProfileDto defaultXooInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(XOO_LANGUAGE), p -> p.setName("Sonar Way")); - RulesProfileDto nonDefaultXooInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(XOO_LANGUAGE), p -> p.setName("My Way")); - RulesProfileDto defaultJavaInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(JAVA_LANGUAGE), p -> p.setName("Sonar Way")); - RulesProfileDto nonDefaultJavaInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(JAVA_LANGUAGE), p -> p.setName("My Way")); - RulesProfileDto defaultXooInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(XOO_LANGUAGE), p -> p.setName("Sonar Way")); - RulesProfileDto nonDefaultXooInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(XOO_LANGUAGE), p -> p.setName("My Way")); - db.qualityProfiles().markAsDefault(defaultJavaInOrg1, defaultJavaInOrg2, defaultXooInOrg1, defaultXooInOrg2); + QProfileDto defaultJavaInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(JAVA_LANGUAGE).setName("Sonar Way")); + QProfileDto nonDefaultJavaInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(JAVA_LANGUAGE).setName("My Way")); + QProfileDto defaultXooInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(XOO_LANGUAGE).setName("Sonar Way")); + QProfileDto nonDefaultXooInOrg1 = db.qualityProfiles().insert(org1, p -> p.setLanguage(XOO_LANGUAGE).setName("My Way")); + QProfileDto defaultJavaInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(JAVA_LANGUAGE).setName("Sonar Way")); + QProfileDto nonDefaultJavaInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(JAVA_LANGUAGE).setName("My Way")); + QProfileDto defaultXooInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(XOO_LANGUAGE).setName("Sonar Way")); + QProfileDto nonDefaultXooInOrg2 = db.qualityProfiles().insert(org2, p -> p.setLanguage(XOO_LANGUAGE).setName("My Way")); + db.qualityProfiles().setAsDefault(defaultJavaInOrg1, defaultJavaInOrg2, defaultXooInOrg1, defaultXooInOrg2); WsActionTester tester = newWsActionTester(); @@ -218,10 +218,10 @@ public class ExportActionTest { .isEqualTo("Backup of java/" + defaultJavaInOrg1.getKee()); } - private RulesProfileDto createProfile(OrganizationDto organization, boolean isDefault) { - RulesProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(XOO_LANGUAGE)); + private QProfileDto createProfile(OrganizationDto organization, boolean isDefault) { + QProfileDto profile = db.qualityProfiles().insert(organization, p -> p.setLanguage(XOO_LANGUAGE)); if (isDefault) { - db.qualityProfiles().markAsDefault(profile); + db.qualityProfiles().setAsDefault(profile); } return profile; } @@ -252,7 +252,7 @@ public class ExportActionTest { private static class TestBackuper implements QProfileBackuper { @Override - public void backup(DbSession dbSession, RulesProfileDto profile, Writer backupWriter) { + public void backup(DbSession dbSession, QProfileDto profile, Writer backupWriter) { try { backupWriter.write(format("Backup of %s/%s", profile.getLanguage(), profile.getKee())); } catch (IOException e) { @@ -266,7 +266,7 @@ public class ExportActionTest { } @Override - public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, RulesProfileDto profile) { + public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, QProfileDto profile) { throw new UnsupportedOperationException(); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/InheritanceActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/InheritanceActionTest.java index ecd6231471c..d7a73b48858 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/InheritanceActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/InheritanceActionTest.java @@ -36,7 +36,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.es.EsClient; @@ -115,28 +115,28 @@ public class InheritanceActionTest { /* * sonar way (2) <- companyWide (2) <- buWide (2, 1 overriding) <- (forProject1 (2), forProject2 (2)) */ - RulesProfileDto sonarway = dbTester.qualityProfiles().insertQualityProfile( - newQProfileDto(organization, QProfileName.createFor("xoo", "Sonar way"), "xoo-sonar-way").setIsBuiltIn(true)); + QProfileDto sonarway = dbTester.qualityProfiles().insert(organization, p -> + p.setKee("xoo-sonar-way").setLanguage("xoo").setName("Sonar way").setIsBuiltIn(true)); createActiveRule(rule1, sonarway); createActiveRule(rule2, sonarway); dbSession.commit(); activeRuleIndexer.index(); - RulesProfileDto companyWide = createProfile("xoo", "My Company Profile", "xoo-my-company-profile-12345"); + QProfileDto companyWide = createProfile("xoo", "My Company Profile", "xoo-my-company-profile-12345"); setParent(sonarway, companyWide); - RulesProfileDto buWide = createProfile("xoo", "My BU Profile", "xoo-my-bu-profile-23456"); + QProfileDto buWide = createProfile("xoo", "My BU Profile", "xoo-my-bu-profile-23456"); setParent(companyWide, buWide); overrideActiveRuleSeverity(rule1, buWide, Severity.CRITICAL); - RulesProfileDto forProject1 = createProfile("xoo", "For Project One", "xoo-for-project-one-34567"); + QProfileDto forProject1 = createProfile("xoo", "For Project One", "xoo-for-project-one-34567"); setParent(buWide, forProject1); createActiveRule(rule3, forProject1); dbSession.commit(); activeRuleIndexer.index(); - RulesProfileDto forProject2 = createProfile("xoo", "For Project Two", "xoo-for-project-two-45678"); + QProfileDto forProject2 = createProfile("xoo", "For Project Two", "xoo-for-project-two-45678"); setParent(buWide, forProject2); overrideActiveRuleSeverity(rule2, forProject2, Severity.CRITICAL); @@ -160,12 +160,12 @@ public class InheritanceActionTest { RuleDefinitionDto rule3 = dbTester.rules().insert(); ruleIndexer.indexRuleDefinition(rule1.getKey()); - RulesProfileDto parent = dbTester.qualityProfiles().insert(organization); + QProfileDto parent = dbTester.qualityProfiles().insert(organization); dbTester.qualityProfiles().activateRule(parent, rule1); dbTester.qualityProfiles().activateRule(parent, rule2); long parentRules = 2; - RulesProfileDto child = dbTester.qualityProfiles().insert(organization, q -> q.setParentKee(parent.getKee())); + QProfileDto child = dbTester.qualityProfiles().insert(organization, q -> q.setParentKee(parent.getKee())); dbTester.qualityProfiles().activateRule(child, rule3); long childRules = 1; @@ -192,7 +192,7 @@ public class InheritanceActionTest { RuleDefinitionDto rule = dbTester.rules().insert(r -> r.setStatus(RuleStatus.REMOVED)); ruleIndexer.indexRuleDefinition(rule.getKey()); - RulesProfileDto profile = dbTester.qualityProfiles().insert(organization); + QProfileDto profile = dbTester.qualityProfiles().insert(organization); dbTester.qualityProfiles().activateRule(profile, rule); long activeRules = 0; @@ -213,7 +213,7 @@ public class InheritanceActionTest { @Test public void inheritance_no_family() throws Exception { // Simple profile, no parent, no child - RulesProfileDto remi = createProfile("xoo", "Nobodys Boy", "xoo-nobody-s-boy-01234"); + QProfileDto remi = createProfile("xoo", "Nobodys Boy", "xoo-nobody-s-boy-01234"); String response = wsActionTester.newRequest() .setMethod("GET") @@ -230,14 +230,14 @@ public class InheritanceActionTest { .setMethod("GET").setParam("profileKey", "polop").execute(); } - private RulesProfileDto createProfile(String lang, String name, String key) { - RulesProfileDto profile = newQProfileDto(organization, new QProfileName(lang, name), key); + private QProfileDto createProfile(String lang, String name, String key) { + QProfileDto profile = newQProfileDto(organization, new QProfileName(lang, name), key); dbClient.qualityProfileDao().insert(dbSession, profile); dbSession.commit(); return profile; } - private void setParent(RulesProfileDto profile, RulesProfileDto parent) { + private void setParent(QProfileDto profile, QProfileDto parent) { ruleActivator.setParent(dbSession, parent.getKee(), profile.getKee()); } @@ -255,7 +255,7 @@ public class InheritanceActionTest { return rule; } - private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, RulesProfileDto profile) { + private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, QProfileDto profile) { long now = new Date().getTime(); ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule) .setSeverity(rule.getSeverityString()) @@ -265,7 +265,7 @@ public class InheritanceActionTest { return activeRule; } - private void overrideActiveRuleSeverity(RuleDefinitionDto rule, RulesProfileDto profile, String severity) { + private void overrideActiveRuleSeverity(RuleDefinitionDto rule, QProfileDto profile, String severity) { ruleActivator.activate(dbSession, new RuleActivation(rule.getKey()).setSeverity(severity), profile.getKee()); dbSession.commit(); activeRuleIndexer.index(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ProjectsActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ProjectsActionTest.java index ddd2e4a3d64..579c73ce642 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ProjectsActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/ProjectsActionTest.java @@ -30,7 +30,7 @@ import org.sonar.db.DbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.component.ComponentTesting; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.user.UserDto; import org.sonar.db.user.UserTesting; import org.sonar.server.exceptions.NotFoundException; @@ -52,8 +52,8 @@ public class ProjectsActionTest { private OrganizationDto organizationDto; private UserDto user; - private RulesProfileDto xooP1; - private RulesProfileDto xooP2; + private QProfileDto xooP1; + private QProfileDto xooP2; private ComponentDto project1; private ComponentDto project2; private ComponentDto project3; @@ -205,7 +205,7 @@ public class ProjectsActionTest { return ComponentTesting.newPrivateProjectDto(organizationDto, uuid).setName(name); } - private void associateProjectsWithProfile(DbSession dbSession, RulesProfileDto profile, ComponentDto... projects) { + private void associateProjectsWithProfile(DbSession dbSession, QProfileDto profile, ComponentDto... projects) { for (ComponentDto project : projects) { dbClient.qualityProfileDao().insertProjectProfileAssociation(dbSession, project, profile); } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfileWsSupportTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfileWsSupportTest.java index 51958153504..2e59e846494 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfileWsSupportTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfileWsSupportTest.java @@ -24,7 +24,7 @@ import org.junit.Test; import org.junit.rules.ExpectedException; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.organization.DefaultOrganizationProvider; @@ -48,9 +48,9 @@ public class QProfileWsSupportTest { @Test public void getProfile_returns_the_profile_specified_by_key() { - RulesProfileDto profile = db.qualityProfiles().insertQualityProfile(QualityProfileTesting.newQualityProfileDto()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); - RulesProfileDto loaded = underTest.getProfile(db.getSession(), QProfileReference.fromKey(profile.getKee())); + QProfileDto loaded = underTest.getProfile(db.getSession(), QProfileReference.fromKey(profile.getKee())); assertThat(loaded.getKee()).isEqualTo(profile.getKee()); assertThat(loaded.getOrganizationUuid()).isEqualTo(profile.getOrganizationUuid()); @@ -68,10 +68,10 @@ public class QProfileWsSupportTest { @Test public void getProfile_returns_the_profile_specified_by_name_and_default_organization() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(db.getDefaultOrganization().getUuid()); - db.qualityProfiles().insertQualityProfile(profile); + QProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(db.getDefaultOrganization().getUuid()); + db.qualityProfiles().insert(profile); - RulesProfileDto loaded = underTest.getProfile(db.getSession(), QProfileReference.fromName(null, profile.getLanguage(), profile.getName())); + QProfileDto loaded = underTest.getProfile(db.getSession(), QProfileReference.fromName(null, profile.getLanguage(), profile.getName())); assertThat(loaded.getKee()).isEqualTo(profile.getKee()); assertThat(loaded.getOrganizationUuid()).isEqualTo(profile.getOrganizationUuid()); @@ -81,8 +81,8 @@ public class QProfileWsSupportTest { @Test public void getProfile_throws_NotFoundException_if_specified_name_does_not_exist_on_default_organization() { - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(db.getDefaultOrganization().getUuid()); - db.qualityProfiles().insertQualityProfile(profile); + QProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(db.getDefaultOrganization().getUuid()); + db.qualityProfiles().insert(profile); expectedException.expect(NotFoundException.class); expectedException.expectMessage("Quality Profile for language 'java' and name 'missing' does not exist"); @@ -93,8 +93,8 @@ public class QProfileWsSupportTest { @Test public void getProfile_throws_NotFoundException_if_specified_name_does_not_exist_on_specified_organization() { OrganizationDto org1 = db.organizations().insert(); - RulesProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(org1.getUuid()); - db.qualityProfiles().insertQualityProfile(profile); + QProfileDto profile = QualityProfileTesting.newQualityProfileDto().setOrganizationUuid(org1.getUuid()); + db.qualityProfiles().insert(profile); OrganizationDto org2 = db.organizations().insert(); expectedException.expect(NotFoundException.class); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfilesWsMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfilesWsMediumTest.java index b54c0147f14..d332ed9359b 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfilesWsMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/QProfilesWsMediumTest.java @@ -37,7 +37,7 @@ import org.sonar.db.organization.OrganizationTesting; import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleTesting; import org.sonar.server.es.SearchOptions; @@ -98,7 +98,7 @@ public class QProfilesWsMediumTest { @Test public void deactivate_rule() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule = createRule(profile.getLanguage(), "toto"); createActiveRule(rule, profile); session.commit(); @@ -121,7 +121,7 @@ public class QProfilesWsMediumTest { @Test public void bulk_deactivate_rule() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule0 = createRule(profile.getLanguage(), "toto1"); RuleDefinitionDto rule1 = createRule(profile.getLanguage(), "toto2"); RuleDefinitionDto rule2 = createRule(profile.getLanguage(), "toto3"); @@ -148,8 +148,8 @@ public class QProfilesWsMediumTest { @Test public void bulk_deactivate_rule_not_all() throws Exception { - RulesProfileDto profile = createProfile("java"); - RulesProfileDto php = createProfile("php"); + QProfileDto profile = createProfile("java"); + QProfileDto php = createProfile("php"); RuleDefinitionDto rule0 = createRule(profile.getLanguage(), "toto1"); RuleDefinitionDto rule1 = createRule(profile.getLanguage(), "toto2"); createActiveRule(rule0, profile); @@ -175,7 +175,7 @@ public class QProfilesWsMediumTest { @Test public void bulk_deactivate_rule_by_profile() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule0 = createRule(profile.getLanguage(), "hello"); RuleDefinitionDto rule1 = createRule(profile.getLanguage(), "world"); createActiveRule(rule0, profile); @@ -199,7 +199,7 @@ public class QProfilesWsMediumTest { @Test public void activate_rule() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule = createRule(profile.getLanguage(), "toto"); session.commit(); ruleIndexer.indexRuleDefinition(rule.getKey()); @@ -220,7 +220,7 @@ public class QProfilesWsMediumTest { @Test public void activate_rule_diff_languages() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule = createRule("php", "toto"); session.commit(); ruleIndexer.indexRuleDefinition(rule.getKey()); @@ -243,7 +243,7 @@ public class QProfilesWsMediumTest { @Test public void activate_rule_override_severity() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule = createRule(profile.getLanguage(), "toto"); session.commit(); ruleIndexer.indexRuleDefinition(rule.getKey()); @@ -268,7 +268,7 @@ public class QProfilesWsMediumTest { @Test public void bulk_activate_rule() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); createRule(profile.getLanguage(), "toto"); createRule(profile.getLanguage(), "tata"); createRule(profile.getLanguage(), "hello"); @@ -291,8 +291,8 @@ public class QProfilesWsMediumTest { @Test public void bulk_activate_rule_not_all() throws Exception { - RulesProfileDto java = createProfile("java"); - RulesProfileDto php = createProfile("php"); + QProfileDto java = createProfile("java"); + QProfileDto php = createProfile("php"); createRule(java.getLanguage(), "toto"); createRule(java.getLanguage(), "tata"); createRule(php.getLanguage(), "hello"); @@ -315,7 +315,7 @@ public class QProfilesWsMediumTest { @Test public void bulk_activate_rule_by_query() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); createRule(profile.getLanguage(), "toto"); createRule(profile.getLanguage(), "tata"); createRule(profile.getLanguage(), "hello"); @@ -348,7 +348,7 @@ public class QProfilesWsMediumTest { @Test public void bulk_activate_rule_by_query_with_severity() throws Exception { - RulesProfileDto profile = createProfile("java"); + QProfileDto profile = createProfile("java"); RuleDefinitionDto rule0 = createRule(profile.getLanguage(), "toto"); RuleDefinitionDto rule1 = createRule(profile.getLanguage(), "tata"); session.commit(); @@ -379,10 +379,10 @@ public class QProfilesWsMediumTest { @Test public void does_not_return_warnings_when_bulk_activate_on_profile_and_rules_exist_on_another_language_than_profile() throws Exception { - RulesProfileDto javaProfile = createProfile("java"); + QProfileDto javaProfile = createProfile("java"); createRule(javaProfile.getLanguage(), "toto"); createRule(javaProfile.getLanguage(), "tata"); - RulesProfileDto phpProfile = createProfile("php"); + QProfileDto phpProfile = createProfile("php"); createRule(phpProfile.getLanguage(), "hello"); createRule(phpProfile.getLanguage(), "world"); session.commit(); @@ -401,8 +401,8 @@ public class QProfilesWsMediumTest { @Test public void reset() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1(organization); - RulesProfileDto subProfile = QProfileTesting.newXooP2(organization).setParentKee(QProfileTesting.XOO_P1_KEY); + QProfileDto profile = QProfileTesting.newXooP1(organization); + QProfileDto subProfile = QProfileTesting.newXooP2(organization).setParentKee(QProfileTesting.XOO_P1_KEY); db.qualityProfileDao().insert(session, profile, subProfile); RuleDefinitionDto rule = createRule(profile.getLanguage(), "rule"); @@ -431,8 +431,8 @@ public class QProfilesWsMediumTest { assertThat(db.activeRuleDao().selectOrFailByKey(session, active2.getKey()).getSeverityString()).isNotEqualTo("MINOR"); } - private RulesProfileDto createProfile(String lang) { - RulesProfileDto profile = QProfileTesting.newQProfileDto(organization, new QProfileName(lang, "P" + lang), "p" + lang); + private QProfileDto createProfile(String lang) { + QProfileDto profile = QProfileTesting.newQProfileDto(organization, new QProfileName(lang, "P" + lang), "p" + lang); db.qualityProfileDao().insert(session, profile); return profile; } @@ -448,7 +448,7 @@ public class QProfilesWsMediumTest { return rule; } - private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, RulesProfileDto profile) { + private ActiveRuleDto createActiveRule(RuleDefinitionDto rule, QProfileDto profile) { ActiveRuleDto activeRule = ActiveRuleDto.createFor(profile, rule) .setSeverity(rule.getSeverityString()); db.activeRuleDao().insert(session, activeRule); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RemoveProjectActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RemoveProjectActionTest.java index 2610ea9f219..0c0aba001a8 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RemoveProjectActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RemoveProjectActionTest.java @@ -31,7 +31,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.component.ResourceTypesRule; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.component.ComponentFinder; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.NotFoundException; @@ -85,10 +85,10 @@ public class RemoveProjectActionTest { logInAsProfileAdmin(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profileLang1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); - RulesProfileDto profileLang2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_2)); - db.qualityProfiles().associateProjectWithQualityProfile(project, profileLang1); - db.qualityProfiles().associateProjectWithQualityProfile(project, profileLang2); + QProfileDto profileLang1 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_1)); + QProfileDto profileLang2 = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(LANGUAGE_2)); + db.qualityProfiles().associateWithProject(project, profileLang1); + db.qualityProfiles().associateWithProject(project, profileLang2); TestResponse response = call(project, profileLang1); assertThat(response.getStatus()).isEqualTo(HttpURLConnection.HTTP_NO_CONTENT); @@ -102,7 +102,7 @@ public class RemoveProjectActionTest { logInAsProfileAdmin(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); TestResponse response = call(project, profile); assertThat(response.getStatus()).isEqualTo(HttpURLConnection.HTTP_NO_CONTENT); @@ -113,8 +113,8 @@ public class RemoveProjectActionTest { @Test public void project_administrator_can_remove_profile() throws Exception { ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); - db.qualityProfiles().associateProjectWithQualityProfile(project, profile); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + db.qualityProfiles().associateWithProject(project, profile); userSession.logIn().addProjectPermission(UserRole.ADMIN, project); call(project, profile); @@ -126,7 +126,7 @@ public class RemoveProjectActionTest { public void throw_ForbiddenException_if_not_project_nor_organization_administrator() { userSession.logIn(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(ForbiddenException.class); expectedException.expectMessage("Insufficient privileges"); @@ -138,7 +138,7 @@ public class RemoveProjectActionTest { public void throw_UnauthorizedException_if_not_logged_in() { userSession.anonymous(); ComponentDto project = db.components().insertPrivateProject(db.getDefaultOrganization()); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(UnauthorizedException.class); expectedException.expectMessage("Authentication is required"); @@ -149,7 +149,7 @@ public class RemoveProjectActionTest { @Test public void throw_NotFoundException_if_project_does_not_exist() { logInAsProfileAdmin(); - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization()); expectedException.expect(NotFoundException.class); expectedException.expectMessage("Component id 'unknown' not found"); @@ -174,13 +174,13 @@ public class RemoveProjectActionTest { .execute(); } - private void assertProjectIsAssociatedToProfile(ComponentDto project, RulesProfileDto profile) { - RulesProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); + private void assertProjectIsAssociatedToProfile(ComponentDto project, QProfileDto profile) { + QProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); assertThat(loaded.getKee()).isEqualTo(profile.getKee()); } - private void assertProjectIsNotAssociatedToProfile(ComponentDto project, RulesProfileDto profile) { - RulesProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); + private void assertProjectIsNotAssociatedToProfile(ComponentDto project, QProfileDto profile) { + QProfileDto loaded = dbClient.qualityProfileDao().selectAssociatedToProjectAndLanguage(db.getSession(), project, profile.getLanguage()); assertThat(loaded == null || !loaded.getKee().equals(profile.getKee())).isTrue(); } @@ -188,7 +188,7 @@ public class RemoveProjectActionTest { userSession.logIn().addPermission(ADMINISTER_QUALITY_PROFILES, db.getDefaultOrganization()); } - private TestResponse call(ComponentDto project, RulesProfileDto qualityProfile) { + private TestResponse call(ComponentDto project, QProfileDto qualityProfile) { TestRequest request = tester.newRequest() .setParam("projectUuid", project.uuid()) .setParam("profileKey", qualityProfile.getKee()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RenameActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RenameActionTest.java index 442e974f702..ffb47f3ffd6 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RenameActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RenameActionTest.java @@ -27,7 +27,7 @@ import org.sonar.api.utils.System2; import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.exceptions.ForbiddenException; @@ -81,7 +81,7 @@ public class RenameActionTest { underTest.doHandle("the new name", qualityProfileKey); - RulesProfileDto reloaded = db.getDbClient().qualityProfileDao().selectByKey(db.getSession(), qualityProfileKey); + QProfileDto reloaded = db.getDbClient().qualityProfileDao().selectByUuid(db.getSession(), qualityProfileKey); assertThat(reloaded.getName()).isEqualTo("the new name"); } @@ -89,18 +89,18 @@ public class RenameActionTest { public void fail_renaming_if_name_already_exists() { logInAsQProfileAdministrator(); - RulesProfileDto qualityProfile1 = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile1 = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()) .setLanguage("xoo") .setName("Old, valid name"); - db.qualityProfiles().insertQualityProfile(qualityProfile1); + db.qualityProfiles().insert(qualityProfile1); String qualityProfileKey1 = qualityProfile1.getKee(); - RulesProfileDto qualityProfile2 = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile2 = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()) .setLanguage("xoo") .setName("Invalid, duplicated name"); - db.qualityProfiles().insertQualityProfile(qualityProfile2); + db.qualityProfiles().insert(qualityProfile2); String qualityProfileKey2 = qualityProfile2.getKee(); expectedException.expect(BadRequestException.class); @@ -116,23 +116,23 @@ public class RenameActionTest { userSessionRule.logIn() .addPermission(ADMINISTER_QUALITY_PROFILES, organizationX); - RulesProfileDto qualityProfile1 = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile1 = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organizationX.getUuid()) .setLanguage("xoo") .setName("Old, unique name"); - db.qualityProfiles().insertQualityProfile(qualityProfile1); + db.qualityProfiles().insert(qualityProfile1); String qualityProfileKey1 = qualityProfile1.getKee(); - RulesProfileDto qualityProfile2 = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile2 = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organizationY.getUuid()) .setLanguage("xoo") .setName("Duplicated name"); - db.qualityProfiles().insertQualityProfile(qualityProfile2); + db.qualityProfiles().insert(qualityProfile2); String qualityProfileKey2 = qualityProfile2.getKee(); underTest.doHandle("Duplicated name", qualityProfileKey1); - RulesProfileDto reloaded = db.getDbClient().qualityProfileDao().selectByKey(db.getSession(), qualityProfileKey1); + QProfileDto reloaded = db.getDbClient().qualityProfileDao().selectByUuid(db.getSession(), qualityProfileKey1); assertThat(reloaded.getName()).isEqualTo("Duplicated name"); } @@ -167,9 +167,9 @@ public class RenameActionTest { userSessionRule.logIn() .addPermission(ADMINISTER_QUALITY_PROFILES, organizationX); - RulesProfileDto qualityProfile = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organizationY.getUuid()); - db.qualityProfiles().insertQualityProfile(qualityProfile); + db.qualityProfiles().insert(qualityProfile); String qualityProfileKey = qualityProfile.getKee(); expectedException.expect(ForbiddenException.class); @@ -248,26 +248,26 @@ public class RenameActionTest { } private String createNewValidQualityProfileKey() { - RulesProfileDto qualityProfile = QualityProfileTesting.newQualityProfileDto() + QProfileDto qualityProfile = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization.getUuid()); - db.qualityProfiles().insertQualityProfile(qualityProfile); + db.qualityProfiles().insert(qualityProfile); return qualityProfile.getKee(); } private void createProfiles() { String orgUuid = organization.getUuid(); dbClient.qualityProfileDao().insert(db.getSession(), - RulesProfileDto.createFor("sonar-way-xoo1-12345") + QProfileDto.createFor("sonar-way-xoo1-12345") .setOrganizationUuid(orgUuid) .setLanguage(xoo1Key) .setName("Sonar way"), - RulesProfileDto.createFor("sonar-way-xoo2-23456") + QProfileDto.createFor("sonar-way-xoo2-23456") .setOrganizationUuid(orgUuid) .setLanguage(xoo2Key) .setName("Sonar way"), - RulesProfileDto.createFor("my-sonar-way-xoo2-34567") + QProfileDto.createFor("my-sonar-way-xoo2-34567") .setOrganizationUuid(orgUuid) .setLanguage(xoo2Key) .setName("My Sonar way") diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RestoreActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RestoreActionTest.java index 6433815b4ff..a0b04465cb7 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RestoreActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/RestoreActionTest.java @@ -32,7 +32,7 @@ import org.sonar.api.server.ws.WebService; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.exceptions.UnauthorizedException; @@ -206,7 +206,7 @@ public class RestoreActionTest { private QProfileRestoreSummary restoredSummary; @Override - public void backup(DbSession dbSession, RulesProfileDto profile, Writer backupWriter) { + public void backup(DbSession dbSession, QProfileDto profile, Writer backupWriter) { throw new UnsupportedOperationException(); } @@ -220,7 +220,7 @@ public class RestoreActionTest { } catch (IOException e) { throw new IllegalStateException(e); } - RulesProfileDto profile = RulesProfileDto.createFor("P1") + QProfileDto profile = QProfileDto.createFor("P1") .setLanguage("xoo") .setName(overriddenProfileName != null ? overriddenProfileName : "the-name-in-backup"); restoredSummary = new QProfileRestoreSummary(profile, new BulkChangeResult()); @@ -228,7 +228,7 @@ public class RestoreActionTest { } @Override - public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, RulesProfileDto profile) { + public QProfileRestoreSummary restore(DbSession dbSession, Reader backup, QProfileDto profile) { throw new UnsupportedOperationException(); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchActionTest.java index 5ecb400568a..60a110c736a 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchActionTest.java @@ -38,10 +38,9 @@ import org.sonar.db.component.ComponentDbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.organization.OrganizationTesting; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileDao; import org.sonar.db.qualityprofile.QualityProfileDbTester; -import org.sonar.db.qualityprofile.QualityProfileTesting; -import org.sonar.db.qualityprofile.RulesProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.server.exceptions.BadRequestException; import org.sonar.server.language.LanguageTesting; @@ -141,34 +140,34 @@ public class SearchActionTest { public void ws_returns_the_profiles_of_default_organization() throws Exception { OrganizationDto organization = getDefaultOrganization(); - RulesProfileDto defaultProfile = RulesProfileDto.createFor("sonar-way-xoo1-12345") + QProfileDto defaultProfile = QProfileDto.createFor("sonar-way-xoo1-12345") .setOrganizationUuid(organization.getUuid()) .setLanguage(xoo1.getKey()) .setName("Sonar way") .setIsBuiltIn(false); - RulesProfileDto parentProfile = RulesProfileDto + QProfileDto parentProfile = QProfileDto .createFor("sonar-way-xoo2-23456") .setOrganizationUuid(organization.getUuid()) .setLanguage(xoo2.getKey()) .setName("Sonar way") .setIsBuiltIn(true); - RulesProfileDto childProfile = RulesProfileDto + QProfileDto childProfile = QProfileDto .createFor("my-sonar-way-xoo2-34567") .setOrganizationUuid(organization.getUuid()) .setLanguage(xoo2.getKey()) .setName("My Sonar way") .setParentKee(parentProfile.getKee()); - RulesProfileDto profileOnUnknownLang = RulesProfileDto.createFor("sonar-way-other-666") + QProfileDto profileOnUnknownLang = QProfileDto.createFor("sonar-way-other-666") .setOrganizationUuid(organization.getUuid()) .setLanguage("other") .setName("Sonar way"); qualityProfileDao.insert(dbSession, defaultProfile, parentProfile, childProfile, profileOnUnknownLang); - db.qualityProfiles().markAsDefault(defaultProfile, profileOnUnknownLang); + db.qualityProfiles().setAsDefault(defaultProfile, profileOnUnknownLang); ComponentDto project1 = db.components().insertPrivateProject(organization); ComponentDto project2 = db.components().insertPrivateProject(organization); - db.qualityProfiles().associateProjectWithQualityProfile(project1, parentProfile); - db.qualityProfiles().associateProjectWithQualityProfile(project2, parentProfile); + db.qualityProfiles().associateWithProject(project1, parentProfile); + db.qualityProfiles().associateWithProject(project2, parentProfile); SearchWsResponse result = ws.newRequest().executeProtobuf(SearchWsResponse.class); @@ -188,7 +187,7 @@ public class SearchActionTest { @Test public void response_contains_statistics_on_active_rules() { - RulesProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(xoo1.getKey())); + QProfileDto profile = db.qualityProfiles().insert(db.getDefaultOrganization(), p -> p.setLanguage(xoo1.getKey())); RuleDefinitionDto rule = db.rules().insertRule(r -> r.setLanguage(xoo1.getKey())).getDefinition(); RuleDefinitionDto deprecatedRule1 = db.rules().insertRule(r -> r.setStatus(RuleStatus.DEPRECATED)).getDefinition(); RuleDefinitionDto deprecatedRule2 = db.rules().insertRule(r -> r.setStatus(RuleStatus.DEPRECATED)).getDefinition(); @@ -210,7 +209,7 @@ public class SearchActionTest { @Test public void search_map_dates() { long time = DateUtils.parseDateTime("2016-12-22T19:10:03+0100").getTime(); - qualityProfileDb.insertQualityProfiles(newQualityProfileDto() + qualityProfileDb.insert(newQualityProfileDto() .setOrganizationUuid(defaultOrganizationProvider.get().getUuid()) .setLanguage(xoo1.getKey()) .setRulesUpdatedAt("2016-12-21T19:10:03+0100") @@ -228,8 +227,8 @@ public class SearchActionTest { @Test public void search_for_language() throws Exception { - qualityProfileDb.insertQualityProfiles( - RulesProfileDto.createFor("sonar-way-xoo1-12345") + qualityProfileDb.insert( + QProfileDto.createFor("sonar-way-xoo1-12345") .setOrganizationUuid(defaultOrganizationProvider.get().getUuid()) .setLanguage(xoo1.getKey()) .setName("Sonar way")); @@ -243,12 +242,12 @@ public class SearchActionTest { public void search_for_project_qp() { OrganizationDto org = db.organizations().insert(); ComponentDto project = db.components().insertPrivateProject(org); - RulesProfileDto qualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey())); - db.qualityProfiles().associateProjectWithQualityProfile(project, qualityProfileOnXoo1); - RulesProfileDto defaultProfileOnXoo2 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo2.getKey())); - db.qualityProfiles().associateProjectWithQualityProfile(project, defaultProfileOnXoo2); - RulesProfileDto defaultProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey())); - db.qualityProfiles().markAsDefault(defaultProfileOnXoo2, defaultProfileOnXoo1); + QProfileDto qualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey())); + db.qualityProfiles().associateWithProject(project, qualityProfileOnXoo1); + QProfileDto defaultProfileOnXoo2 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo2.getKey())); + db.qualityProfiles().associateWithProject(project, defaultProfileOnXoo2); + QProfileDto defaultProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey())); + db.qualityProfiles().setAsDefault(defaultProfileOnXoo2, defaultProfileOnXoo1); SearchWsResponse result = ws.newRequest() .setParam(PARAM_PROJECT_KEY, project.key()) @@ -279,20 +278,20 @@ public class SearchActionTest { @Test public void search_for_default_qp_with_profile_name() { String orgUuid = defaultOrganizationProvider.get().getUuid(); - RulesProfileDto qualityProfileOnXoo1 = RulesProfileDto.createFor("sonar-way-xoo1-12345") + QProfileDto qualityProfileOnXoo1 = QProfileDto.createFor("sonar-way-xoo1-12345") .setOrganizationUuid(orgUuid) .setLanguage(xoo1.getKey()) .setName("Sonar way"); - RulesProfileDto qualityProfileOnXoo2 = RulesProfileDto.createFor("sonar-way-xoo2-12345") + QProfileDto qualityProfileOnXoo2 = QProfileDto.createFor("sonar-way-xoo2-12345") .setOrganizationUuid(orgUuid) .setLanguage(xoo2.getKey()) .setName("Sonar way"); - RulesProfileDto anotherQualityProfileOnXoo1 = RulesProfileDto.createFor("sonar-way-xoo1-45678") + QProfileDto anotherQualityProfileOnXoo1 = QProfileDto.createFor("sonar-way-xoo1-45678") .setOrganizationUuid(orgUuid) .setLanguage(xoo1.getKey()) .setName("Another way"); - qualityProfileDb.insertQualityProfiles(qualityProfileOnXoo1, qualityProfileOnXoo2, anotherQualityProfileOnXoo1); - db.qualityProfiles().markAsDefault(qualityProfileOnXoo2, anotherQualityProfileOnXoo1); + qualityProfileDb.insert(qualityProfileOnXoo1, qualityProfileOnXoo2, anotherQualityProfileOnXoo1); + db.qualityProfiles().setAsDefault(qualityProfileOnXoo2, anotherQualityProfileOnXoo1); String result = ws.newRequest() .setParam(PARAM_DEFAULTS, Boolean.TRUE.toString()) @@ -307,10 +306,10 @@ public class SearchActionTest { @Test public void search_by_profile_name() { OrganizationDto org = db.organizations().insert(); - RulesProfileDto qualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey()).setName("Sonar way")); - RulesProfileDto qualityProfileOnXoo2 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo2.getKey()).setName("Sonar way")); - RulesProfileDto anotherQualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey()).setName("Another way")); - db.qualityProfiles().markAsDefault(qualityProfileOnXoo2, anotherQualityProfileOnXoo1); + QProfileDto qualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey()).setName("Sonar way")); + QProfileDto qualityProfileOnXoo2 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo2.getKey()).setName("Sonar way")); + QProfileDto anotherQualityProfileOnXoo1 = db.qualityProfiles().insert(org, q -> q.setLanguage(xoo1.getKey()).setName("Another way")); + db.qualityProfiles().setAsDefault(qualityProfileOnXoo2, anotherQualityProfileOnXoo1); ComponentDto project = componentDb.insertPrivateProject(org); SearchWsResponse result = ws.newRequest() @@ -331,11 +330,11 @@ public class SearchActionTest { OrganizationDto org = db.organizations().insert(OrganizationTesting.newOrganizationDto().setKey(orgKey)); dbClient.qualityProfileDao().insert(dbSession, createProfile("A", xoo1, org, "MATCH")); dbClient.qualityProfileDao().insert(dbSession, createProfile("B", xoo2, org, "NOMATCH")); - RulesProfileDto defaultProfileC = createProfile("C", xoo1, org, "NOMATCH"); + QProfileDto defaultProfileC = createProfile("C", xoo1, org, "NOMATCH"); dbClient.qualityProfileDao().insert(dbSession, defaultProfileC); - RulesProfileDto defaultProfileD = createProfile("D", xoo2, org, "NOMATCH"); + QProfileDto defaultProfileD = createProfile("D", xoo2, org, "NOMATCH"); dbClient.qualityProfileDao().insert(dbSession, defaultProfileD); - db.qualityProfiles().markAsDefault(defaultProfileC, defaultProfileD); + db.qualityProfiles().setAsDefault(defaultProfileC, defaultProfileD); } SearchWsRequest request = new SearchWsRequest() @@ -427,16 +426,13 @@ public class SearchActionTest { private void minimalValidSetup() { for (Language language : Arrays.asList(xoo1, xoo2)) { - RulesProfileDto profile = db.qualityProfiles().insertQualityProfile( - QualityProfileTesting.newQualityProfileDto() - .setOrganizationUuid(getDefaultOrganization().getUuid()) - .setLanguage(language.getKey())); - db.qualityProfiles().markAsDefault(profile); + QProfileDto profile = db.qualityProfiles().insert(getDefaultOrganization(), p -> p.setLanguage(language.getKey())); + db.qualityProfiles().setAsDefault(profile); } } - private RulesProfileDto createProfile(String keySuffix, Language language, OrganizationDto org, String name) { - return RulesProfileDto.createFor(org.getKey() + "-" + keySuffix) + private QProfileDto createProfile(String keySuffix, Language language, OrganizationDto org, String name) { + return QProfileDto.createFor(org.getKey() + "-" + keySuffix) .setOrganizationUuid(org.getUuid()) .setLanguage(language.getKey()) .setName(name); diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchDataLoaderTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchDataLoaderTest.java index 29e5ceae6cb..1b7535f5874 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchDataLoaderTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SearchDataLoaderTest.java @@ -33,8 +33,7 @@ import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.component.ComponentDto; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; -import org.sonar.db.qualityprofile.QualityProfileTesting; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.component.ComponentFinder; import org.sonar.server.language.LanguageTesting; import org.sonar.server.qualityprofile.QProfileLookup; @@ -87,8 +86,8 @@ public class SearchDataLoaderTest { @Test public void findDefaults() throws Exception { - RulesProfileDto profile = insertQualityProfile(organization); - dbTester.qualityProfiles().markAsDefault(profile); + QProfileDto profile = insertQualityProfile(organization); + dbTester.qualityProfiles().setAsDefault(profile); assertThat(findProfiles( new SearchWsRequest() .setOrganizationKey(organization.getKey()) @@ -98,8 +97,8 @@ public class SearchDataLoaderTest { @Test public void findForProject() throws Exception { - RulesProfileDto profile = insertQualityProfile(organization); - dbTester.qualityProfiles().markAsDefault(profile); + QProfileDto profile = insertQualityProfile(organization); + dbTester.qualityProfiles().setAsDefault(profile); ComponentDto project1 = insertProject(); assertThat(findProfiles( new SearchWsRequest() @@ -109,8 +108,8 @@ public class SearchDataLoaderTest { @Test public void findAllForLanguage() throws Exception { - RulesProfileDto profile = insertQualityProfile(organization); - dbTester.qualityProfiles().markAsDefault(profile); + QProfileDto profile = insertQualityProfile(organization); + dbTester.qualityProfiles().setAsDefault(profile); assertThat(findProfiles( new SearchWsRequest() .setOrganizationKey(organization.getKey()) @@ -123,18 +122,14 @@ public class SearchDataLoaderTest { null)).hasSize(0); } - private List<RulesProfileDto> findProfiles(SearchWsRequest request, @Nullable ComponentDto project) { + private List<QProfileDto> findProfiles(SearchWsRequest request, @Nullable ComponentDto project) { return new SearchDataLoader(languages, profileLookup, dbTester.getDbClient()) .findProfiles(dbTester.getSession(), request, organization, project); } - private RulesProfileDto insertQualityProfile(OrganizationDto organization) { + private QProfileDto insertQualityProfile(OrganizationDto organization) { Language language = insertLanguage(); - RulesProfileDto qualityProfile = QualityProfileTesting.newQualityProfileDto() - .setOrganizationUuid(organization.getUuid()) - .setLanguage(language.getKey()); - dbTester.qualityProfiles().insertQualityProfile(qualityProfile); - return qualityProfile; + return dbTester.qualityProfiles().insert(organization, p -> p.setLanguage(language.getKey())); } private Language insertLanguage() { diff --git a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SetDefaultActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SetDefaultActionTest.java index 895ce8d3fab..9603116e128 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SetDefaultActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/qualityprofile/ws/SetDefaultActionTest.java @@ -28,7 +28,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.organization.OrganizationTesting; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.qualityprofile.QualityProfileTesting; import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.exceptions.NotFoundException; @@ -62,11 +62,11 @@ public class SetDefaultActionTest { private SetDefaultAction underTest; /** Single, default quality profile for language xoo1 */ - private RulesProfileDto xoo1Profile; + private QProfileDto xoo1Profile; /** Parent quality profile for language xoo2 (not a default) */ - private RulesProfileDto xoo2Profile; + private QProfileDto xoo2Profile; /** Child quality profile for language xoo2, set as default */ - private RulesProfileDto xoo2Profile2; + private QProfileDto xoo2Profile2; @Before public void setUp() { @@ -90,7 +90,7 @@ public class SetDefaultActionTest { .setParentKee(xoo2Profile.getKee()); dbClient.qualityProfileDao().insert(db.getSession(), xoo1Profile, xoo2Profile, xoo2Profile2); db.commit(); - db.qualityProfiles().markAsDefault(xoo1Profile, xoo2Profile2); + db.qualityProfiles().setAsDefault(xoo1Profile, xoo2Profile2); tester = new WsActionTester(underTest); } @@ -149,17 +149,17 @@ public class SetDefaultActionTest { .logIn() .addPermission(ADMINISTER_QUALITY_PROFILES, organization1.getUuid()); - RulesProfileDto profileOrg1Old = QualityProfileTesting.newQualityProfileDto() + QProfileDto profileOrg1Old = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization1.getUuid()) .setLanguage(xoo1Key); - RulesProfileDto profileOrg1New = QualityProfileTesting.newQualityProfileDto() + QProfileDto profileOrg1New = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization1.getUuid()) .setLanguage(xoo1Key); - RulesProfileDto profileOrg2 = QualityProfileTesting.newQualityProfileDto() + QProfileDto profileOrg2 = QualityProfileTesting.newQualityProfileDto() .setOrganizationUuid(organization2.getUuid()) .setLanguage(xoo1Key); - db.qualityProfiles().insertQualityProfiles(profileOrg1Old, profileOrg1New, profileOrg2); - db.qualityProfiles().markAsDefault(profileOrg1Old, profileOrg2); + db.qualityProfiles().insert(profileOrg1Old, profileOrg1New, profileOrg2); + db.qualityProfiles().setAsDefault(profileOrg1Old, profileOrg2); checkDefaultProfile(organization1, xoo1Key, profileOrg1Old.getKee()); checkDefaultProfile(organization2, xoo1Key, profileOrg2.getKee()); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/RuleUpdaterTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/RuleUpdaterTest.java index 1c8a24ffe89..5f4cbea4f09 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/RuleUpdaterTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/RuleUpdaterTest.java @@ -42,7 +42,7 @@ import org.sonar.db.DbTester; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleKey; import org.sonar.db.qualityprofile.ActiveRuleParamDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; import org.sonar.db.rule.RuleParamDto; @@ -446,7 +446,7 @@ public class RuleUpdaterTest { db.rules().insertRuleParam(customRule, param -> param.setName("message").setType("STRING").setDescription("message")); // Create a quality profile - RulesProfileDto profileDto = QProfileTesting.newXooP1(db.getDefaultOrganization()); + QProfileDto profileDto = QProfileTesting.newXooP1(db.getDefaultOrganization()); db.getDbClient().qualityProfileDao().insert(dbSession, profileDto); dbSession.commit(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ActiveRuleCompleterTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ActiveRuleCompleterTest.java index 23be755b07f..4a9f39c50cf 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ActiveRuleCompleterTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ActiveRuleCompleterTest.java @@ -27,7 +27,7 @@ import org.sonar.api.resources.Languages; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.qualityprofile.ActiveRuleDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonarqube.ws.Rules; @@ -43,7 +43,7 @@ public class ActiveRuleCompleterTest { OrganizationDto organization = dbTester.organizations().insert(); ActiveRuleCompleter activeRuleCompleter = new ActiveRuleCompleter(dbTester.getDbClient(), new Languages()); RuleDefinitionDto rule = dbTester.rules().insert(); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); ActiveRuleDto activeRule = dbTester.qualityProfiles().activateRule(qualityProfile, rule); List<Rules.Active> result = activeRuleCompleter.completeShow(dbTester.getSession(), organization, rule); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/AppActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/AppActionTest.java index 59fe1de4516..7cfeed6dcd5 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/AppActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/AppActionTest.java @@ -29,7 +29,7 @@ import org.sonar.api.utils.System2; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; import org.sonar.db.permission.OrganizationPermission; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleRepositoryDto; import org.sonar.server.exceptions.NotFoundException; import org.sonar.server.language.LanguageTesting; @@ -219,8 +219,8 @@ public class AppActionTest { } private void insertQualityProfiles(OrganizationDto organization) { - RulesProfileDto profile1 = QProfileTesting.newXooP1(organization).setIsBuiltIn(true); - RulesProfileDto profile2 = QProfileTesting.newXooP2(organization).setParentKee(QProfileTesting.XOO_P1_KEY); + QProfileDto profile1 = QProfileTesting.newXooP1(organization).setIsBuiltIn(true); + QProfileDto profile2 = QProfileTesting.newXooP2(organization).setParentKee(QProfileTesting.XOO_P1_KEY); db.getDbClient().qualityProfileDao().insert(db.getSession(), profile1); db.getDbClient().qualityProfileDao().insert(db.getSession(), profile2); db.commit(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/RuleQueryFactoryTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/RuleQueryFactoryTest.java index 01b970acd04..7849f2a50ab 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/RuleQueryFactoryTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/RuleQueryFactoryTest.java @@ -31,7 +31,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.server.organization.TestDefaultOrganizationProvider; import org.sonar.server.rule.index.RuleQuery; import org.sonar.server.ws.TestRequest; @@ -117,7 +117,7 @@ public class RuleQueryFactoryTest { @Test public void create_query() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); RuleQuery result = execute( PARAM_RULE_KEY, "ruleKey", @@ -166,7 +166,7 @@ public class RuleQueryFactoryTest { @Test public void use_quality_profiles_language_if_available() throws Exception { - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization); String qualityProfileKey = qualityProfile.getKee(); RuleQuery result = execute( @@ -188,7 +188,7 @@ public class RuleQueryFactoryTest { @Test public void create_query_add_language_from_profile() throws Exception { String profileKey = "sonar-way"; - dbClient.qualityProfileDao().insert(dbSession, RulesProfileDto.createFor(profileKey) + dbClient.qualityProfileDao().insert(dbSession, QProfileDto.createFor(profileKey) .setOrganizationUuid(organization.getUuid()) .setName("Sonar Way") .setLanguage("xoo")); @@ -205,7 +205,7 @@ public class RuleQueryFactoryTest { @Test public void filter_on_quality_profiles_organization_if_searching_for_actives_with_no_organization_specified() throws Exception { String profileKey = "sonar-way"; - dbClient.qualityProfileDao().insert(dbSession, RulesProfileDto.createFor(profileKey) + dbClient.qualityProfileDao().insert(dbSession, QProfileDto.createFor(profileKey) .setOrganizationUuid(organization.getUuid()) .setName("Sonar Way") .setLanguage("xoo")); @@ -223,7 +223,7 @@ public class RuleQueryFactoryTest { OrganizationDto organization1 = dbTester.organizations().insert(); OrganizationDto organization2 = dbTester.organizations().insert(); - RulesProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization1); + QProfileDto qualityProfile = dbTester.qualityProfiles().insert(organization1); String qualityProfileKey = qualityProfile.getKee(); String organization2Key = organization2.getKey(); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/SearchActionMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/SearchActionMediumTest.java index c35db2aea05..5c37e47913e 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/SearchActionMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/SearchActionMediumTest.java @@ -41,7 +41,7 @@ import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; import org.sonar.db.qualityprofile.QualityProfileDao; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDao; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; @@ -311,7 +311,7 @@ public class SearchActionMediumTest { @Test public void search_all_active_rules() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); + QProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); tester.get(QualityProfileDao.class).insert(dbSession, profile); RuleDefinitionDto rule = RuleTesting.newXooX1().getDefinition(); @@ -336,10 +336,10 @@ public class SearchActionMediumTest { @Test public void search_profile_active_rules() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); + QProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); tester.get(QualityProfileDao.class).insert(dbSession, profile); - RulesProfileDto profile2 = QProfileTesting.newXooP2(defaultOrganizationDto); + QProfileDto profile2 = QProfileTesting.newXooP2(defaultOrganizationDto); tester.get(QualityProfileDao.class).insert(dbSession, profile2); dbSession.commit(); @@ -411,10 +411,10 @@ public class SearchActionMediumTest { @Test public void search_profile_active_rules_with_inheritance() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); + QProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); tester.get(QualityProfileDao.class).insert(dbSession, profile); - RulesProfileDto profile2 = QProfileTesting.newXooP2(defaultOrganizationDto).setParentKee(profile.getKee()); + QProfileDto profile2 = QProfileTesting.newXooP2(defaultOrganizationDto).setParentKee(profile.getKee()); tester.get(QualityProfileDao.class).insert(dbSession, profile2); dbSession.commit(); @@ -442,7 +442,7 @@ public class SearchActionMediumTest { @Test public void search_all_active_rules_params() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); + QProfileDto profile = QProfileTesting.newXooP1(defaultOrganizationDto); tester.get(QualityProfileDao.class).insert(dbSession, profile); RuleDefinitionDto rule = RuleTesting.newXooX1().getDefinition(); insertRule(rule); @@ -488,7 +488,7 @@ public class SearchActionMediumTest { @Test public void get_note_as_markdown_and_html() throws Exception { - RulesProfileDto profile = QProfileTesting.newXooP1("org-123"); + QProfileDto profile = QProfileTesting.newXooP1("org-123"); tester.get(QualityProfileDao.class).insert(dbSession, profile); RuleDto rule = RuleTesting.newXooX1(defaultOrganizationDto).setNoteData("this is *bold*"); insertRule(rule.getDefinition()); @@ -636,7 +636,7 @@ public class SearchActionMediumTest { result.assertJson(getClass(), "search_rules_with_deprecated_fields.json"); } - private ActiveRuleDto newActiveRule(RulesProfileDto profile, RuleDefinitionDto rule) { + private ActiveRuleDto newActiveRule(QProfileDto profile, RuleDefinitionDto rule) { return ActiveRuleDto.createFor(profile, rule) .setInheritance(null) .setSeverity("BLOCKER"); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionMediumTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionMediumTest.java index bf86040dce5..53f17b276dd 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionMediumTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionMediumTest.java @@ -35,7 +35,7 @@ import org.sonar.db.qualityprofile.ActiveRuleDao; import org.sonar.db.qualityprofile.ActiveRuleDto; import org.sonar.db.qualityprofile.ActiveRuleParamDto; import org.sonar.db.qualityprofile.QualityProfileDao; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDao; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleDto; @@ -275,7 +275,7 @@ public class ShowActionMediumTest { RuleParamDto regexParam = RuleParamDto.createFor(ruleDto).setName("regex").setType("STRING").setDescription("Reg *exp*").setDefaultValue(".*"); ruleDao.insertRuleParam(session, ruleDto, regexParam); - RulesProfileDto profile = RulesProfileDto.createFor("profile") + QProfileDto profile = QProfileDto.createFor("profile") .setOrganizationUuid(defaultOrganizationProvider.get().getUuid()) .setName("Profile") .setLanguage("xoo"); diff --git a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionTest.java index d33f2a9a809..5cbafcf0a59 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/rule/ws/ShowActionTest.java @@ -35,7 +35,7 @@ import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; -import org.sonar.db.qualityprofile.RulesProfileDto; +import org.sonar.db.qualityprofile.QProfileDto; import org.sonar.db.rule.RuleDefinitionDto; import org.sonar.db.rule.RuleMetadataDto; import org.sonar.server.es.EsClient; @@ -134,7 +134,7 @@ public class ShowActionTest { public void show_rule_with_activation() throws Exception { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = QProfileTesting.newXooP1(organization); + QProfileDto profile = QProfileTesting.newXooP1(organization); dbClient.qualityProfileDao().insert(dbTester.getSession(), profile); dbTester.commit(); @@ -176,7 +176,7 @@ public class ShowActionTest { public void show_rule_without_activation() throws Exception { OrganizationDto organization = dbTester.organizations().insert(); - RulesProfileDto profile = QProfileTesting.newXooP1(organization); + QProfileDto profile = QProfileTesting.newXooP1(organization); dbClient.qualityProfileDao().insert(dbTester.getSession(), profile); dbTester.commit(); |