1 /*******************************************************************************
2 * Copyright (c) 2014 École Polytechnique de Montréal
4 * All rights reserved. This program and the accompanying materials are
5 * made available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * Geneviève Bastien - Initial API and implementation
11 *******************************************************************************/
13 package org
.eclipse
.tracecompass
.tmf
.analysis
.xml
.core
.tests
.common
;
15 import static org
.junit
.Assert
.fail
;
18 import java
.io
.IOException
;
20 import javax
.xml
.parsers
.DocumentBuilder
;
21 import javax
.xml
.parsers
.DocumentBuilderFactory
;
22 import javax
.xml
.parsers
.ParserConfigurationException
;
24 import org
.eclipse
.core
.runtime
.IPath
;
25 import org
.eclipse
.core
.runtime
.Path
;
26 import org
.eclipse
.tracecompass
.tmf
.analysis
.xml
.core
.tests
.Activator
;
27 import org
.w3c
.dom
.Document
;
28 import org
.xml
.sax
.SAXException
;
31 * Provides some test XML files to use
33 * @author Geneviève Bastien
35 public enum TmfXmlTestFiles
{
36 /** A valid XML test file */
37 VALID_FILE("test_xml_files/test_valid/test_valid.xml"),
38 /** An invalid test file */
39 INVALID_FILE("test_xml_files/test_invalid/test_invalid.xml"),
40 /** A valid file for state attribute tests */
41 ATTRIBUTE_FILE("test_xml_files/test_valid/test_attributes.xml");
43 private final String fPath
;
45 private TmfXmlTestFiles(String file
) {
50 * Get the absolute path of this test file
52 * @return The absolute path of this test file
54 public IPath
getPath() {
55 IPath absPath
= Activator
.getAbsolutePath(new Path(fPath
));
56 if (absPath
== null) {
57 fail("Cannot find file path for '" + fPath
+ "'");
63 * Returns the file object corresponding to the test XML file
65 * @return The file object for this test file
67 public File
getFile() {
68 return getPath().toFile();
72 * Get the XML {@link Document} for this test xml file
74 * @return The XML {@link Document}
76 public Document
getXmlDocument() {
77 /* Initialize the state provider module */
80 DocumentBuilderFactory dbFactory
= DocumentBuilderFactory
.newInstance();
81 DocumentBuilder dBuilder
= dbFactory
.newDocumentBuilder();
82 doc
= dBuilder
.parse(getFile());
83 doc
.getDocumentElement().normalize();
84 } catch (ParserConfigurationException e
) {
85 fail("Xml document parse exception");
86 } catch (SAXException e
) {
87 fail("Exception parsing xml file");
88 } catch (IOException e
) {
89 fail("File io exception");