001package org.apache.maven.lifecycle.internal;
002
003/*
004 * Licensed to the Apache Software Foundation (ASF) under one or more contributor license
005 * agreements. See the NOTICE file distributed with this work for additional information regarding
006 * copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance with the License. You may obtain a
008 * copy of the License at
009 *
010 * http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing, software distributed under the License
013 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
014 * or implied. See the License for the specific language governing permissions and limitations under
015 * the License.
016 */
017
018import junit.framework.TestCase;
019
020import org.apache.maven.lifecycle.MavenExecutionPlan;
021import org.apache.maven.lifecycle.internal.stub.LifecycleExecutionPlanCalculatorStub;
022import org.apache.maven.lifecycle.internal.stub.ProjectDependencyGraphStub;
023import org.apache.maven.plugin.MojoExecution;
024
025import java.util.List;
026
027/**
028 * @author Kristian Rosenvold
029 */
030public class PhaseRecorderTest extends TestCase
031{
032    public void testObserveExecution() throws Exception {
033        PhaseRecorder phaseRecorder = new PhaseRecorder( ProjectDependencyGraphStub.A);
034        MavenExecutionPlan plan = LifecycleExecutionPlanCalculatorStub.getProjectAExceutionPlan();
035        final List<MojoExecution> executions = plan.getMojoExecutions();
036
037        final MojoExecution mojoExecution1 = executions.get( 0 );
038        final MojoExecution mojoExecution2 = executions.get( 1 );
039        phaseRecorder.observeExecution( mojoExecution1 );
040
041        assertTrue( ProjectDependencyGraphStub.A.hasLifecyclePhase( mojoExecution1.getLifecyclePhase() ));
042        assertFalse( ProjectDependencyGraphStub.A.hasLifecyclePhase( mojoExecution2.getLifecyclePhase() ));
043
044        assertFalse( phaseRecorder.isDifferentPhase( mojoExecution1));
045        assertTrue( phaseRecorder.isDifferentPhase( mojoExecution2));
046
047    }
048
049}