123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- /*
- * SonarQube
- * Copyright (C) 2009-2021 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.ce.task.projectanalysis.period;
-
- import org.junit.Before;
- import org.junit.Rule;
- import org.junit.Test;
- import org.sonar.ce.task.projectanalysis.analysis.AnalysisMetadataHolderRule;
- import org.sonar.db.DbTester;
- import org.sonar.db.component.BranchType;
- import org.sonar.db.component.ComponentDto;
- import org.sonar.db.component.ComponentTesting;
- import org.sonar.db.newcodeperiod.NewCodePeriodType;
- import org.sonar.server.project.Project;
-
- import static org.assertj.core.api.Assertions.assertThat;
- import static org.assertj.core.api.Assertions.assertThatThrownBy;
- import static org.mockito.Mockito.mock;
- import static org.mockito.Mockito.when;
- import static org.sonar.db.component.SnapshotTesting.newAnalysis;
-
- public class NewCodeReferenceBranchComponentUuidsTest {
- @Rule
- public AnalysisMetadataHolderRule analysisMetadataHolder = new AnalysisMetadataHolderRule();
-
- @Rule
- public PeriodHolderRule periodHolder = new PeriodHolderRule();
- @Rule
- public DbTester db = DbTester.create();
-
- private NewCodeReferenceBranchComponentUuids underTest = new NewCodeReferenceBranchComponentUuids(analysisMetadataHolder, periodHolder, db.getDbClient());
-
- private ComponentDto branch1;
- private ComponentDto branch1File;
- private ComponentDto pr1File;
- private ComponentDto pr2File;
- private Project project = mock(Project.class);
- private ComponentDto pr1;
- private ComponentDto pr2;
- private ComponentDto branch2;
- private ComponentDto branch2File;
-
- @Before
- public void setUp() {
- analysisMetadataHolder.setProject(project);
-
- ComponentDto projectDto = db.components().insertPublicProject();
- when(project.getUuid()).thenReturn(projectDto.uuid());
- branch1 = db.components().insertProjectBranch(projectDto, b -> b.setKey("branch1"));
- branch2 = db.components().insertProjectBranch(projectDto, b -> b.setKey("branch2"));
- pr1 = db.components().insertProjectBranch(projectDto, b -> b.setKey("pr1").setBranchType(BranchType.PULL_REQUEST).setMergeBranchUuid(branch1.uuid()));
- pr2 = db.components().insertProjectBranch(projectDto, b -> b.setKey("pr2").setBranchType(BranchType.PULL_REQUEST).setMergeBranchUuid(branch1.uuid()));
- branch1File = ComponentTesting.newFileDto(branch1, null, "file").setUuid("branch1File");
- branch2File = ComponentTesting.newFileDto(branch2, null, "file").setUuid("branch2File");
- pr1File = ComponentTesting.newFileDto(pr1, null, "file").setUuid("file1");
- pr2File = ComponentTesting.newFileDto(pr2, null, "file").setUuid("file2");
- db.components().insertComponents(branch1File, pr1File, pr2File, branch2File);
- }
-
- @Test
- public void should_support_db_key_when_looking_for_reference_component() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.REFERENCE_BRANCH.name(), "branch1", null));
- db.components().insertSnapshot(newAnalysis(branch1));
- assertThat(underTest.getComponentUuid(pr1File.getDbKey())).isEqualTo(branch1File.uuid());
- }
-
- @Test
- public void should_support_key_when_looking_for_reference_component() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.REFERENCE_BRANCH.name(), "branch1", null));
- db.components().insertSnapshot(newAnalysis(branch1));
- assertThat(underTest.getComponentUuid(pr1File.getKey())).isEqualTo(branch1File.uuid());
- }
-
- @Test
- public void return_null_if_file_doesnt_exist() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.REFERENCE_BRANCH.name(), "branch1", null));
- db.components().insertSnapshot(newAnalysis(branch1));
- assertThat(underTest.getComponentUuid("doesnt exist")).isNull();
- }
-
- @Test
- public void skip_init_if_no_reference_branch_analysis() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.REFERENCE_BRANCH.name(), "branch1", null));
- assertThat(underTest.getComponentUuid(pr1File.getDbKey())).isNull();
- }
-
- @Test
- public void skip_init_if_branch_not_found() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.REFERENCE_BRANCH.name(), "unknown", null));
- assertThat(underTest.getComponentUuid(pr1File.getDbKey())).isNull();
- }
-
- @Test
- public void throw_ise_if_mode_is_not_reference_branch() {
- periodHolder.setPeriod(new Period(NewCodePeriodType.NUMBER_OF_DAYS.name(), "10", 1000L));
- assertThatThrownBy(() -> underTest.getComponentUuid(pr1File.getDbKey()))
- .isInstanceOf(IllegalStateException.class);
- }
- }
|