| package org.apache.maven.plugins.enforcer; |
| |
| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| import static org.mockito.Mockito.mock; |
| import static org.mockito.Mockito.when; |
| |
| import org.apache.maven.enforcer.rule.api.EnforcerRuleException; |
| import org.apache.maven.enforcer.rule.api.EnforcerRuleHelper; |
| import org.apache.maven.model.DeploymentRepository; |
| import org.apache.maven.model.DistributionManagement; |
| import org.apache.maven.model.Model; |
| import org.apache.maven.model.Site; |
| import org.apache.maven.plugin.logging.Log; |
| import org.apache.maven.project.MavenProject; |
| import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluationException; |
| import org.junit.Test; |
| |
| /** |
| * This class is intended to test the {@link BanDistributionManagement} rule. |
| * |
| * @author <a href="mailto:khmarbaise@apache.org">Karl Heinz Marbaise</a> |
| */ |
| public class BanDistributionManagementTest |
| { |
| private MavenProject project; |
| |
| private EnforcerRuleHelper helper; |
| |
| @Test |
| public void shouldNotFailWithoutDistributionManagement() |
| throws Exception |
| { |
| BanDistributionManagement rule = setupProjectWithoutDistributionManagement(); |
| rule.execute( helper ); |
| // intentionally no assert cause in case of an exception the test will be red. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test( expected = EnforcerRuleException.class ) |
| public void shouldThrowExceptionIfDistributionManagementIsDefinedWithRepository() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), null, null ); |
| rule.execute( helper ); |
| // intentionally no assert cause we expect an exception. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * <snapshotRepository> |
| * ... |
| * </snapshotRepository> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test( expected = EnforcerRuleException.class ) |
| public void shouldThrowExceptionIfDistributionManagementIsDefinedWithRepositorySnapshotRepository() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), new DeploymentRepository(), null ); |
| rule.execute( helper ); |
| // intentionally no assert cause we expect an exception. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * <snapshotRepository> |
| * ... |
| * </snapshotRepository> |
| * <site> |
| * ... |
| * </site> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test( expected = EnforcerRuleException.class ) |
| public void shouldThrowExceptionIfDistributionManagementIsDefinedWithRepositorySnapshotRepositorySite() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), new DeploymentRepository(), |
| new Site() ); |
| rule.execute( helper ); |
| // intentionally no assert cause we expect an exception. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test |
| public void shouldAllowDistributionManagementHavingRepository() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), null, null ); |
| rule.setAllowRepository( true ); |
| rule.execute( helper ); |
| // intentionally no assert cause in case of an exception the test will be red. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * <snapshotRepository> |
| * ... |
| * </snapshotRepository> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test |
| public void shouldAllowDistributionManagementHavingRepositorySnapshotRepository() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), new DeploymentRepository(), null ); |
| rule.setAllowRepository( true ); |
| rule.setAllowSnapshotRepository( true ); |
| rule.execute( helper ); |
| // intentionally no assert cause in case of an exception the test will be red. |
| } |
| |
| /** |
| * <pre> |
| * <distributionManagement> |
| * <repository> |
| * ... |
| * </repository> |
| * <snapshotRepository> |
| * ... |
| * </snapshotRepository> |
| * <site> |
| * ... |
| * </site> |
| * </distributionManagement> |
| * </pre> |
| * |
| * @throws Exception if any occurs |
| */ |
| @Test |
| public void shouldAllowDistributionManagementHavingRepositorySnapshotRepositorySite() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithDistributionManagement( new DeploymentRepository(), new DeploymentRepository(), |
| new Site() ); |
| rule.setAllowRepository( true ); |
| rule.setAllowSnapshotRepository( true ); |
| rule.setAllowSite( true ); |
| rule.execute( helper ); |
| // intentionally no assert cause in case of an exception the test will be red. |
| } |
| |
| @Test |
| public void shouldThrowExceptionCauseParentProjectHasDistributionManagementSnapshotRepository() |
| throws Exception |
| { |
| BanDistributionManagement rule = |
| setupProjectWithParentDistributionManagement( null, new DeploymentRepository(), null ); |
| |
| rule.setAllowSnapshotRepository( true ); |
| |
| rule.execute( helper ); |
| } |
| |
| private BanDistributionManagement setupProjectWithParentDistributionManagement( DeploymentRepository repository, |
| DeploymentRepository snapshotRepository, |
| Site site ) |
| throws ExpressionEvaluationException |
| { |
| project = setupProject( null ); |
| |
| DistributionManagement dmParent = mock( DistributionManagement.class ); |
| when( dmParent.getRepository() ).thenReturn( repository ); |
| when( dmParent.getSnapshotRepository() ).thenReturn( snapshotRepository ); |
| when( dmParent.getSite() ).thenReturn( site ); |
| |
| MavenProject parentProject = mock( MavenProject.class ); |
| Model model = mock( Model.class ); |
| when( model.getDistributionManagement() ).thenReturn( dmParent ); |
| when( parentProject.getOriginalModel() ).thenReturn( model ); |
| when( project.getParent() ).thenReturn( parentProject ); |
| |
| BanDistributionManagement rule = setupEnforcerRule(); |
| |
| return rule; |
| } |
| |
| private BanDistributionManagement setupProjectWithoutDistributionManagement() |
| throws ExpressionEvaluationException |
| { |
| project = setupProject( null ); |
| |
| BanDistributionManagement rule = setupEnforcerRule(); |
| |
| return rule; |
| } |
| |
| private BanDistributionManagement setupProjectWithDistributionManagement( DeploymentRepository repository, |
| DeploymentRepository snapshotRepository, |
| Site site ) |
| throws ExpressionEvaluationException |
| { |
| DistributionManagement dm = mock( DistributionManagement.class ); |
| when( dm.getRepository() ).thenReturn( repository ); |
| when( dm.getSnapshotRepository() ).thenReturn( snapshotRepository ); |
| when( dm.getSite() ).thenReturn( site ); |
| |
| project = setupProject( dm ); |
| |
| when( project.getParent() ).thenReturn( mock( MavenProject.class ) ); |
| when( project.isExecutionRoot() ).thenReturn( true ); |
| |
| BanDistributionManagement rule = setupEnforcerRule(); |
| |
| return rule; |
| } |
| |
| private MavenProject setupProject( DistributionManagement distributionManagement ) |
| { |
| MavenProject project = mock( MavenProject.class ); |
| when( project.getPackaging() ).thenReturn( "jar" ); |
| Model mavenModel = mock( Model.class ); |
| when( project.getOriginalModel() ).thenReturn( mavenModel ); |
| when( mavenModel.getDistributionManagement() ).thenReturn( distributionManagement ); |
| return project; |
| } |
| |
| private BanDistributionManagement setupEnforcerRule() |
| throws ExpressionEvaluationException |
| { |
| helper = mock( EnforcerRuleHelper.class ); |
| when( helper.evaluate( "${project}" ) ).thenReturn( project ); |
| BanDistributionManagement rule = new BanDistributionManagement(); |
| |
| when( helper.getLog() ).thenReturn( mock( Log.class ) ); |
| return rule; |
| } |
| |
| } |