View Javadoc
1   /*
2    * This file is part of dependency-check-maven.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *     http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   *
16   * Copyright (c) 2014 Jeremy Long. All Rights Reserved.
17   */
18  package org.owasp.dependencycheck.maven;
19  
20  import java.io.File;
21  import java.net.URISyntaxException;
22  import java.util.HashSet;
23  import java.util.Locale;
24  import java.util.Set;
25  import java.util.logging.Level;
26  import java.util.logging.Logger;
27  import mockit.Mock;
28  import mockit.MockUp;
29  import org.apache.maven.artifact.Artifact;
30  import org.apache.maven.plugin.MojoExecutionException;
31  import org.apache.maven.plugin.MojoFailureException;
32  import org.apache.maven.plugin.testing.stubs.ArtifactStub;
33  import org.apache.maven.project.MavenProject;
34  import static org.junit.Assert.assertFalse;
35  import static org.junit.Assert.assertTrue;
36  import org.junit.Test;
37  import org.owasp.dependencycheck.data.nvdcve.DatabaseException;
38  import org.owasp.dependencycheck.utils.InvalidSettingException;
39  import org.owasp.dependencycheck.utils.Settings;
40  
41  /**
42   *
43   * @author Jeremy Long <jeremy.long@owasp.org>
44   */
45  public class BaseDependencyCheckMojoTest extends BaseTest {
46  
47      /**
48       * Test of scanArtifacts method, of class BaseDependencyCheckMojo.
49       */
50      @Test
51      public void testScanArtifacts() throws DatabaseException, InvalidSettingException {
52          MavenProject project = new MockUp<MavenProject>() {
53              @Mock
54              public Set<Artifact> getArtifacts() {
55                  Set<Artifact> artifacts = new HashSet<Artifact>();
56                  Artifact a = new ArtifactStub();
57                  try {
58                      File file = new File(Test.class.getProtectionDomain().getCodeSource().getLocation().toURI());
59                      a.setFile(file);
60                      artifacts.add(a);
61                  } catch (URISyntaxException ex) {
62                      Logger.getLogger(BaseDependencyCheckMojoTest.class.getName()).log(Level.SEVERE, null, ex);
63                  }
64                  //File file = new File(this.getClass().getClassLoader().getResource("daytrader-ear-2.1.7.ear").getPath());
65  
66                  return artifacts;
67              }
68          }.getMockInstance();
69  
70          boolean autoUpdate = Settings.getBoolean(Settings.KEYS.AUTO_UPDATE);
71          Settings.setBoolean(Settings.KEYS.AUTO_UPDATE, false);
72          Engine engine = new Engine(null, null);
73          Settings.setBoolean(Settings.KEYS.AUTO_UPDATE, autoUpdate);
74  
75          assertTrue(engine.getDependencies().isEmpty());
76          BaseDependencyCheckMojoImpl instance = new BaseDependencyCheckMojoImpl();
77          instance.scanArtifacts(project, engine);
78          assertFalse(engine.getDependencies().isEmpty());
79          engine.cleanup();
80      }
81  
82      public class BaseDependencyCheckMojoImpl extends BaseDependencyCheckMojo {
83  
84          @Override
85          public void runCheck() throws MojoExecutionException, MojoFailureException {
86              throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
87          }
88  
89          @Override
90          public String getName(Locale locale) {
91              return "test implementation";
92          }
93  
94          @Override
95          public String getDescription(Locale locale) {
96              return "test implementation";
97          }
98  
99          @Override
100         public boolean canGenerateReport() {
101             throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
102         }
103 
104     }
105 
106 }