aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-db-dao
diff options
context:
space:
mode:
authorSteve Marion <steve.marion@sonarsource.com>2024-08-29 16:56:07 +0200
committersonartech <sonartech@sonarsource.com>2024-09-09 20:02:50 +0000
commitce766aabfdd89cdb4ff48a0b79d46663f36ddbf1 (patch)
treec1bddbb59ee1a51d702848cfb042791b9d058cb3 /server/sonar-db-dao
parent7c792fd39a2e67f2688e9f5b9aa8fce5488efb61 (diff)
downloadsonarqube-ce766aabfdd89cdb4ff48a0b79d46663f36ddbf1.tar.gz
sonarqube-ce766aabfdd89cdb4ff48a0b79d46663f36ddbf1.zip
SONAR-22891 add webhook_delivery to the database populator
Diffstat (limited to 'server/sonar-db-dao')
-rw-r--r--server/sonar-db-dao/src/test/java/org/sonar/db/createdb/PopulateDb.java66
-rw-r--r--server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDbTester.java9
-rw-r--r--server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDeliveryDbTester.java6
3 files changed, 45 insertions, 36 deletions
diff --git a/server/sonar-db-dao/src/test/java/org/sonar/db/createdb/PopulateDb.java b/server/sonar-db-dao/src/test/java/org/sonar/db/createdb/PopulateDb.java
index 6730b2862fc..8a21671c33c 100644
--- a/server/sonar-db-dao/src/test/java/org/sonar/db/createdb/PopulateDb.java
+++ b/server/sonar-db-dao/src/test/java/org/sonar/db/createdb/PopulateDb.java
@@ -56,6 +56,7 @@ import org.sonar.db.rule.RuleDto;
import org.sonar.db.user.GroupDto;
import org.sonar.db.user.TokenType;
import org.sonar.db.user.UserDto;
+import org.sonar.db.webhook.WebhookDto;
import static org.sonar.db.component.BranchType.BRANCH;
@@ -85,7 +86,7 @@ public class PopulateDb {
IntStream.rangeClosed(1, 1)
.map(i -> i + allProjects.size())
- .mapToObj(i -> new ProjectStructure("project " + i, 10, 100, 10, 2, 5))
+ .mapToObj(i -> new ProjectStructure("project " + i, 10, 100, 10, 2, 5, 1))
.forEach(projectStructure -> {
executorService.submit(() -> {
sqContext.dbTester.getSession(true);
@@ -189,7 +190,7 @@ public class PopulateDb {
}
private record ProjectStructure(String projectName, int branchPerProject, int filePerBranch, int issuePerFile, int issueChangePerIssue,
- int snapshotPerBranch) {
+ int snapshotPerBranch, int webhookDeliveriesPerComponent) {
}
private record PortfolioGenerationSettings(int currentPortfoliosSize, int numberOfPortolios, int maxProjectPerPortfolio) {
@@ -199,10 +200,10 @@ public class PopulateDb {
}
private static ProjectDto generateProject(SqContext sqContext, ProjectStructure pj) {
- ComponentDto projectCompoDto = sqContext.dbTester.components().insertPublicProject(p -> p.setName(pj.projectName));
+ final ComponentDto projectCompoDto = sqContext.dbTester.components().insertPublicProject(p -> p.setName(pj.projectName));
sqContext.dbTester.forceCommit();
- ProjectDto projectDto = sqContext.dbTester.components().getProjectDto(projectCompoDto);
-
+ final ProjectDto projectDto = sqContext.dbTester.components().getProjectDto(projectCompoDto);
+ final WebhookDto projectWebHook = sqContext.dbTester.webhooks().insertWebhook(projectDto);
Streams.concat(
// main branch
Stream.of(new BranchAndComponentDto(
@@ -217,38 +218,19 @@ public class PopulateDb {
}))
// until there are enough branches generated
.limit(pj.branchPerProject)
- // for every branche (main included)
+ // for every branch (main included)
.forEach(branchAndComponentDto -> {
- // for every file in branch
- for (int file = 0; file < pj.filePerBranch; file++) {
- ComponentDto fileComponentDto = sqContext.dbTester.components().insertFile(branchAndComponentDto.compo);
- sqContext.dbTester.fileSources().insertFileSource(fileComponentDto, pj.issuePerFile,
- fs -> fs.setSourceData(fs.getSourceData()));
- // for every issue in file
- for (int issue = 0; issue < pj.issuePerFile; issue++) {
- final int issueLine = issue + 1;
- IssueDto issueDto = sqContext.dbTester.issues().insertIssue(sqContext.findNotSecurityHotspotRule(), branchAndComponentDto.compo, fileComponentDto,
- iDto -> iDto.setLine(issueLine));
- // for every issue change in issue
- for (int issueChange = 0; issueChange < pj.issueChangePerIssue; issueChange++) {
- sqContext.dbTester.issues().insertChange(issueDto);
- }
- }
- // create live measure for this file
- fileLiveMeasureMetrics.stream()
- .map(sqContext.metricDtosByKey::get)
- .forEach(metricDto -> sqContext.dbTester().measures().insertLiveMeasureWithSensibleValues(fileComponentDto, metricDto));
- }
// create live measure for the branch
projectLiveMeasureMetrics.stream()
.map(sqContext.metricDtosByKey::get)
.forEach(metricDto -> sqContext.dbTester().measures().insertLiveMeasureWithSensibleValues(branchAndComponentDto.compo, metricDto));
+ // create snapshots for the current branch
long time = System2.INSTANCE.now();
List<SnapshotDto> snapshots = new ArrayList<>();
// for every snapshot on the current branch
- for (int snapshot = 0; snapshot < pj.snapshotPerBranch; snapshot++) {
+ for (int snapshotNum = 0; snapshotNum < pj.snapshotPerBranch; snapshotNum++) {
SnapshotDto snapshotDto = SnapshotTesting.newAnalysis(branchAndComponentDto.branch);
snapshotDto.setLast(false);
snapshotDto.setCreatedAt(time);
@@ -262,6 +244,36 @@ public class PopulateDb {
SnapshotDto lastSnapshotDto = snapshots.get(0);
lastSnapshotDto.setLast(true);
sqContext.dbTester.components().insertSnapshots(snapshots.toArray(new SnapshotDto[0]));
+
+ // for every file in branch
+ for (int fileNum = 0; fileNum < pj.filePerBranch; fileNum++) {
+ ComponentDto fileComponentDto = sqContext.dbTester.components().insertFile(branchAndComponentDto.compo);
+ sqContext.dbTester.fileSources().insertFileSource(fileComponentDto, pj.issuePerFile,
+ fs -> fs.setSourceData(fs.getSourceData()));
+ // for every issue in file
+ for (int issueNum = 0; issueNum < pj.issuePerFile; issueNum++) {
+ IssueDto issueDto = sqContext.dbTester.issues().insertIssue(sqContext.findNotSecurityHotspotRule(), branchAndComponentDto.compo, fileComponentDto);
+ // for every issue change in issue
+ for (int issueChangeNum = 0; issueChangeNum < pj.issueChangePerIssue; issueChangeNum++) {
+ sqContext.dbTester.issues().insertChange(issueDto);
+ }
+ }
+ // create live measure for this file
+ fileLiveMeasureMetrics.stream()
+ .map(sqContext.metricDtosByKey::get)
+ .forEach(metricDto -> sqContext.dbTester().measures().insertLiveMeasureWithSensibleValues(fileComponentDto, metricDto));
+
+ // create webhook deliveries for every file and snapshot
+ for (SnapshotDto snapshotDto : snapshots) {
+ for (int whdNum = 0; whdNum < pj.webhookDeliveriesPerComponent; whdNum++) {
+ sqContext.dbTester.webhookDelivery().insert(whd -> whd
+ .setAnalysisUuid(snapshotDto.getUuid())
+ .setComponentUuid(fileComponentDto.uuid())
+ .setWebhookUuid(projectWebHook.getUuid()));
+ }
+ }
+ }
+
sqContext.dbTester.forceCommit();
});
diff --git a/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDbTester.java b/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDbTester.java
index c1545beb2e1..79dd5e2bced 100644
--- a/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDbTester.java
+++ b/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDbTester.java
@@ -21,7 +21,6 @@ package org.sonar.db.webhook;
import java.util.Optional;
import javax.annotation.Nullable;
-import org.sonar.db.DbSession;
import org.sonar.db.DbTester;
import org.sonar.db.project.ProjectDto;
@@ -45,14 +44,12 @@ public class WebhookDbTester {
}
public WebhookDto insert(WebhookDto dto, @Nullable String projectKey, @Nullable String projectName) {
- DbSession dbSession = dbTester.getSession();
- dbTester.getDbClient().webhookDao().insert(dbSession, dto, projectKey, projectName);
- dbSession.commit();
+ dbTester.getDbClient().webhookDao().insert(dbTester.getSession(), dto, projectKey, projectName);
+ dbTester.commit();
return dto;
}
public Optional<WebhookDto> selectWebhook(String uuid) {
- DbSession dbSession = dbTester.getSession();
- return dbTester.getDbClient().webhookDao().selectByUuid(dbSession, uuid);
+ return dbTester.getDbClient().webhookDao().selectByUuid(dbTester.getSession(), uuid);
}
}
diff --git a/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDeliveryDbTester.java b/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDeliveryDbTester.java
index ac51649841d..767dca81c38 100644
--- a/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDeliveryDbTester.java
+++ b/server/sonar-db-dao/src/testFixtures/java/org/sonar/db/webhook/WebhookDeliveryDbTester.java
@@ -36,7 +36,7 @@ public class WebhookDeliveryDbTester {
public WebhookDeliveryLiteDto insert(WebhookDeliveryDto dto) {
dbTester.getDbClient().webhookDeliveryDao().insert(dbTester.getSession(), dto);
- dbTester.getSession().commit();
+ dbTester.commit();
return dto;
}
@@ -45,7 +45,7 @@ public class WebhookDeliveryDbTester {
WebhookDeliveryDto dto = newDto();
stream(dtoPopulators).forEach(dtoPopulator -> dtoPopulator.accept(dto));
dbTester.getDbClient().webhookDeliveryDao().insert(dbTester.getSession(), dto);
- dbTester.getSession().commit();
+ dbTester.commit();
return dto;
}
@@ -57,7 +57,7 @@ public class WebhookDeliveryDbTester {
dto.setComponentUuid(Objects.requireNonNull(projectUuid, "Project uuid of webhook cannot be null"));
dto.setWebhookUuid(webhook.getUuid());
dbTester.getDbClient().webhookDeliveryDao().insert(dbTester.getSession(), dto);
- dbTester.getSession().commit();
+ dbTester.commit();
return dto;
}