/** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ package org.apache.tuscany.sdo.test; import java.io.IOException; import java.io.InputStream; import java.net.URL; import org.apache.tuscany.sdo.util.SDOUtil; import junit.framework.TestCase; import commonj.sdo.DataObject; import commonj.sdo.helper.TypeHelper; import commonj.sdo.helper.XMLDocument; import commonj.sdo.helper.XMLHelper; import commonj.sdo.helper.XSDHelper; public class XPathTestCase extends TestCase { private final String TEST_MODEL = "/xpath.xsd"; private final String XPATH_XML = "/xpath.xml"; /** * The presence or absence of the @ sign in a path has no meaning. * Properties are always matched by name independent of their XML representation. * @throws IOException */ public void testAtSignProperty() throws IOException { TypeHelper typeHelper = SDOUtil.createTypeHelper(); XSDHelper xsdHelper = SDOUtil.createXSDHelper(typeHelper); XMLHelper xmlHelper = SDOUtil.createXMLHelper(typeHelper); URL url = getClass().getResource(TEST_MODEL); InputStream inputStream = url.openStream(); xsdHelper.define(inputStream, url.toString()); inputStream.close(); XMLDocument doc = xmlHelper.load(getClass().getResourceAsStream(XPATH_XML)); DataObject drive = doc.getRootObject(); DataObject folder1 = (DataObject) drive.get("Folder.1"); String value = folder1.getString("@creation_date"); assertEquals(value, "2000-03-23"); } public void testListIndexing() throws Exception { TypeHelper typeHelper = SDOUtil.createTypeHelper(); XSDHelper xsdHelper = SDOUtil.createXSDHelper(typeHelper); XMLHelper xmlHelper = SDOUtil.createXMLHelper(typeHelper); URL url = getClass().getResource(TEST_MODEL); InputStream inputStream = url.openStream(); xsdHelper.define(inputStream, url.toString()); inputStream.close(); XMLDocument doc = xmlHelper.load(getClass().getResourceAsStream(XPATH_XML)); DataObject root = doc.getRootObject(); DataObject folder1 = root.getDataObject("Folder[1]"); assertNotNull(folder1); DataObject folder1a = root.getDataObject("Folder.0"); assertEquals(folder1, folder1a); folder1a = root.getDataObject("Folder[FolderName=Folder00000000000]"); assertEquals(folder1, folder1a); DataObject noFolder = null; try { noFolder = root.getDataObject("Folder[3]"); assertFalse("bad indexing passed", true); } catch (IndexOutOfBoundsException iobe) { // as expected } catch (Exception e) { assertFalse("bad indexing generated wrong exception" + e, true); } try { noFolder = root.getDataObject("Folder[0]"); assertFalse("bad indexing passed", true); } catch (IndexOutOfBoundsException iobe) { // as expected } catch (Exception e) { assertFalse("bad indexing generated wrong exception" + e, true); } try { noFolder = root.getDataObject("Folder.2"); assertFalse("bad indexing passed", true); } catch (IndexOutOfBoundsException iobe) { // as expected } catch (Exception e) { assertFalse("bad indexing generated wrong exception" + e, true); } try { noFolder = root.getDataObject("Folder.-1"); assertFalse("bad indexing passed", true); } catch (IndexOutOfBoundsException iobe) { // as expected } catch (Exception e) { assertFalse("bad indexing generated wrong exception" + e, true); } noFolder = root.getDataObject("Folder[FolderName=foo]"); assertNull(noFolder); } }