/* Copyright (c) 2005 Ricebridge. All Rights Reserved.
 *
 * This file is available under the terms and conditions of the
 * Ricebridge "Open Source API" policy; Ricebridge grants use of this
 * copyrighted work under the terms of a BSD-style license only. See
 * http://www.opensource.org/licenses/bsd-license.php for more
 * information.
 * 
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 
 *  - Redistributions of source code must retain the above copyright
 *  notice, this list of conditions and the following disclaimer.
 *
 *  - Redistributions in binary form must reproduce the above
 *  copyright notice, this list of conditions and the following
 *  disclaimer in the documentation and/or other materials provided
 *  with the distribution.
 *
 *  - Neither the name of the Ricebridge nor the names of its
 *  contributors may be used to endorse or promote products derived
 *  from this software without specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 * OF THE POSSIBILITY OF SUCH DAMAGE.  
 */

package com.ricebridge.xmlman.in.test;


import com.ricebridge.xmlman.*;
import com.ricebridge.xmlman.in.*;

import org.jostraca.util.*;

import junit.framework.*;
import junit.textui.*;

import javax.xml.parsers.SAXParserFactory;
import javax.xml.parsers.SAXParser;

import java.util.*;
import java.io.*;


/** Test cases for field paths. 
 *    <p>Test file is <a href="fieldpath.xml">fieldpath.xml</a>.</p> 
 *    <p>The <b><a href="FieldPathTest.java.html">Source Code</a></b> of this Java class 
 *    is available under a <a href="http://www.opensource.org/licenses/bsd-license.php">BSD-style license</a>.</p>
 */
public class FieldPathTest extends TestCase {

  // test framework
  
  public FieldPathTest( String pName ) {
    super( pName );
  }

  public static TestSuite suite() {
    return new TestSuite( FieldPathTest.class );
  }

  public static void main( String[] pArgs ) {
    TestRunner.run( suite() );
  }



  private static ArrayList sRecordSpecList = new ArrayList();
  private static ArrayList sRecordDataList = new ArrayList();


  static {
    sRecordSpecList.add( new RecordSpec( "/root/record1", 
                                         new String[] { "sub/sub[@a='s1f1']" } ) );
    sRecordDataList.add( ListUtil.make( new String[] {"s1t1"} ) );




    // //@v is empty because the // matches all elements, including record1, which has no @v
    sRecordSpecList.add( new RecordSpec( "/root/record1", 
                                         new String[] { "//@v", ".//@v", "fa//@v", "fa//@*" } ) ); 
    sRecordDataList.add( ListUtil.make( new String[] { "", "subv", "subv", "subv" } ) );


    sRecordSpecList.add( new RecordSpec( "/root/record1", 
                                         new String[] { "@a1", "fa/@v", "f1", "f[@n='fa1']", 
                                                        "sub/sub1", "sub/sub[@a='s1f1']", 
                                                        "rb:trim(translate(sub/text(),'\n',' '))", 
                                                        "rb:trim(translate(.,'\n',' '))",
                                                        "rb:trim(sub)", "rb:trim(sub/text())",  } ) );
    sRecordDataList.add( ListUtil.make( new String[] {"av1","fav1","ft1","fat1","s1v1","s1t1","st1",
                                                      "ft1   fat1        s1v1     s1t1     st1      t1",
                                                      "s1v1\n    s1t1\n    st1", "st1" } ) );

    sRecordSpecList.add( new RecordSpec( "/root/record1", 
                                         new String[] { "f1", "concat(@a1,fa/@v)", 
                                                        "rb:trim(sub//sub1)", "rb:trim(concat(@a1,sub//sub1))",
                                                        "rb:trim(sub[sub/@a='s1f1']/text())", 
                                                        "rb:trim(concat(@a1,rb:trim(sub[sub/@a='s1f1']/text())))" } ) ); 
    sRecordDataList.add( ListUtil.make( new String[] { "ft1", "av1fav1", "s1v1", "av1s1v1", "st1", "av1st1" } ) );

  } 
  


  // test methods
  
  public void testFieldPaths() throws Exception {
    TestUtil.testRecords( "com/ricebridge/xmlman/in/test/fieldpath.xml", sRecordSpecList, sRecordDataList, this );
  }


}





Syntax Highlighting created using the com.Ostermiller.Syntax package.
Thursday, February 23 2006 at 16:47