View Javadoc
1   /*
2    * The MIT License (MIT)
3    *
4    * Copyright (c) 2013-2026 The Coveralls Maven Plugin Project Contributors:
5    *     https://github.com/hazendaz/coveralls-maven-plugin/graphs/contributors
6    *
7    * Permission is hereby granted, free of charge, to any person obtaining a copy
8    * of this software and associated documentation files (the "Software"), to deal
9    * in the Software without restriction, including without limitation the rights
10   * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11   * copies of the Software, and to permit persons to whom the Software is
12   * furnished to do so, subject to the following conditions:
13   *
14   * The above copyright notice and this permission notice shall be included in
15   * all copies or substantial portions of the Software.
16   *
17   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18   * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19   * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20   * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21   * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22   * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23   * THE SOFTWARE.
24   */
25  package org.eluder.coveralls.maven.plugin.parser;
26  
27  import java.io.IOException;
28  import java.nio.file.Path;
29  
30  import javax.xml.stream.XMLStreamException;
31  import javax.xml.stream.XMLStreamReader;
32  
33  import org.eluder.coveralls.maven.plugin.ProcessingException;
34  import org.eluder.coveralls.maven.plugin.source.SourceCallback;
35  import org.eluder.coveralls.maven.plugin.source.SourceLoader;
36  import org.eluder.coveralls.maven.plugin.util.TestIoUtil;
37  import org.junit.jupiter.api.Assertions;
38  import org.junit.jupiter.api.Test;
39  import org.mockito.Mockito;
40  
41  /**
42   * Tests for AbstractXmlEventParser error paths.
43   */
44  class AbstractXmlEventParserTest {
45  
46      /**
47       * Parse malformed XML should throw ProcessingException wrapping XMLStreamException.
48       *
49       * @throws IOException
50       *             Signals that an I/O exception has occurred.
51       */
52      @Test
53      void parseMalformedXmlThrowsProcessingException() throws IOException {
54          final var sourceLoader = Mockito.mock(SourceLoader.class);
55          final var callback = Mockito.mock(SourceCallback.class);
56  
57          final var parser = new JaCoCoParser(TestIoUtil.getFile("malformed.xml"), sourceLoader);
58  
59          Assertions.assertThrows(ProcessingException.class, () -> parser.parse(callback));
60      }
61  
62      /**
63       * Parser that throws XMLStreamException from onEvent covers the XMLStreamException catch in parse().
64       */
65      @Test
66      void parseThrowsProcessingExceptionOnXmlStreamError() throws IOException {
67          final var sourceLoader = Mockito.mock(SourceLoader.class);
68          final var callback = Mockito.mock(SourceCallback.class);
69  
70          final var parser = new AbstractXmlEventParser(TestIoUtil.getFile("jacoco1.xml"), sourceLoader) {
71              @Override
72              protected void onEvent(final XMLStreamReader xml, final SourceCallback cb)
73                      throws XMLStreamException, ProcessingException, IOException {
74                  throw new XMLStreamException("Simulated XMLStreamException");
75              }
76          };
77  
78          Assertions.assertThrows(ProcessingException.class, () -> parser.parse(callback));
79      }
80  
81      /**
82       * Parse with non-existent file throws IOException (xml remains null, close(null) is called).
83       */
84      @Test
85      void parseNonExistentFileThrowsIoException() {
86          final var sourceLoader = Mockito.mock(SourceLoader.class);
87          final var callback = Mockito.mock(SourceCallback.class);
88  
89          final var nonExistentFile = Path.of("/non/existent/path/coverage.xml").toFile();
90          final var parser = new AbstractXmlEventParser(nonExistentFile, sourceLoader) {
91              @Override
92              protected void onEvent(final XMLStreamReader xml, final SourceCallback cb)
93                      throws XMLStreamException, ProcessingException, IOException {
94                  // never called
95              }
96          };
97  
98          Assertions.assertThrows(IOException.class, () -> parser.parse(callback));
99      }
100 
101 }