View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one   *
3    * or more contributor license agreements.  See the NOTICE file *
4    * distributed with this work for additional information        *
5    * regarding copyright ownership.  The ASF licenses this file   *
6    * to you under the Apache License, Version 2.0 (the            *
7    * "License"); you may not use this file except in compliance   *
8    * with the License.  You may obtain a copy of the License at   *
9    *                                                              *
10   *   http://www.apache.org/licenses/LICENSE-2.0                 *
11   *                                                              *
12   * Unless required by applicable law or agreed to in writing,   *
13   * software distributed under the License is distributed on an  *
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY       *
15   * KIND, either express or implied.  See the License for the    *
16   * specific language governing permissions and limitations      *
17   * under the License.                                           *
18   */
19  package org.apache.rat.analysis.matchers;
20  
21  import static org.junit.jupiter.api.Assertions.assertEquals;
22  import static org.junit.jupiter.api.Assertions.assertFalse;
23  import static org.junit.jupiter.api.Assertions.assertTrue;
24  
25  import java.util.ArrayList;
26  import java.util.Arrays;
27  import java.util.HashSet;
28  import java.util.List;
29  import java.util.Set;
30  import java.util.stream.Stream;
31  
32  import org.apache.rat.analysis.IHeaders;
33  import org.junit.jupiter.params.ParameterizedTest;
34  import org.junit.jupiter.params.provider.Arguments;
35  import org.junit.jupiter.params.provider.MethodSource;
36  
37  public class CopyrightMatcherTest {
38      private final static int NAME = 0;
39      private final static int TEXT = 1;
40      // to be added
41      private static final String[] prefix = { "Copyright", "©", "(C)", "(c)", "©" };
42  
43      private final static String[] D = { "-d", " 1990-1991" };
44      private final static String[] DO = { "-d-o", " 1990-1991 an owner" };
45      private final static String[] OD = { "-o-d", " an owner 1990-1991" };
46      private final static String[] DOS = { "-d-o-s", " 1990 - 1991 an owner" };
47      private final static String[] ODS = { "-o-d-s", " an owner 1990 - 1991" };
48      private final static String[] S = { "-s", " 1990" };
49      private final static String[] O = { "-o", " an owner" };
50      private final static String[] OS = { "-o-s", " an owner 1990" };
51      private final static String[] SO = { "-s-o", " 1990 an owner" };
52  
53      private static final int TOTAL_TESTS = prefix.length * 9;
54  
55      /* patterns are name, start, end, owner, pass results, fail results */
56      static final Arguments startStopOwner = Arguments.of("start-stop-owner", "1990", "1991", "an owner",
57              expandResults(DO, OD, DOS, ODS), expandResults(D, S, O, OS, SO));
58      static final Arguments startOwner = Arguments.of("start-owner", "1990", null, "an owner", expandResults(OS, SO, OD, ODS),
59              expandResults(D, DO, DOS, S, O));
60      static final Arguments start = Arguments.of("start", "1990", null, null, expandResults(D, DO, DOS, S, SO),
61              expandResults(OD, ODS, O, OS));
62      static final Arguments owner = Arguments.of("owner", null, null, "an owner", expandResults(DO, DOS, O, OD, ODS, OS, SO),
63              expandResults(S, D));
64      static final Arguments nada = Arguments.of("nada", null, null, null, expandResults(D, DO, DOS, S, SO),
65              expandResults(OD, ODS, O, OS));
66  
67      public static Stream<Arguments> parameterProvider() {
68          return Stream.of(startStopOwner, startOwner, start, owner, nada);
69      }
70  
71      private static String[][] expandResults(String[]... args) {
72          List<String[]> arry = new ArrayList<>();
73          for (String pfx : prefix) {
74              Arrays.stream(args).map(origin -> new String[] { pfx + origin[0], pfx + origin[1] }).forEach(arry::add);
75          }
76          return arry.toArray(new String[arry.size()][2]);
77      }
78  
79      private static void verify(String testName, String[][] pass, String[][] fail) {
80          assertEquals(TOTAL_TESTS, pass.length + fail.length, "Wrong number of pass/fail tests");
81          Set<String> passSet = new HashSet<>();
82          Arrays.stream(pass).forEach(s -> passSet.add(s[0]));
83          Set<String> failSet = new HashSet<>();
84          Arrays.stream(fail).forEach(s -> failSet.add(s[0]));
85          for (String s : passSet) {
86              assertFalse(failSet.contains(s),
87                      () -> String.format("%s is in both pass and fail sets for %s", s, testName));
88          }
89      }
90  
91      @ParameterizedTest
92      @MethodSource("parameterProvider")
93      public void testPass(String testName, String start, String stop, String owner, String[][] pass, String[][] fail) {
94          verify(testName, pass, fail);
95          CopyrightMatcher matcher = new CopyrightMatcher(start, stop, owner);
96          for (String[] target : pass) {
97              IHeaders headers = AbstractMatcherTest.makeHeaders(target[TEXT], null);
98              assertTrue(matcher.matches(headers), () -> String.format("%s:%s on '%s' failed", testName, target[TEXT], target[TEXT]));
99              matcher.reset();
100         }
101     }
102 
103     @ParameterizedTest
104     @MethodSource("parameterProvider")
105     public void testFail(String testName, String start, String stop, String owner, String[][] pass, String[][] fail) {
106         verify(testName, pass, fail);
107         CopyrightMatcher matcher = new CopyrightMatcher(start, stop, owner);
108         for (String[] target : fail) {
109             IHeaders headers = AbstractMatcherTest.makeHeaders(target[TEXT], null);
110             assertFalse(matcher.matches(headers), String.format("%s:%s on '%s' passed", testName, target[NAME], target[TEXT]));
111             matcher.reset();
112         }
113     }
114 }