Package org.exist.storage

Source Code of org.exist.storage.ConcurrentStoreTest$StoreThread2

/*
*  eXist Open Source Native XML Database
*  Copyright (C) 2001-04 The eXist Project
*  http://exist-db.org
*  This program is free software; you can redistribute it and/or
*  modify it under the terms of the GNU Lesser General Public License
*  as published by the Free Software Foundation; either version 2
*  of the License, or (at your option) any later version.
*  This program is distributed in the hope that it will be useful,
*  but WITHOUT ANY WARRANTY; without even the implied warranty of
*  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
*  GNU Lesser General Public License for more details.
*  You should have received a copy of the GNU Lesser General Public License
*  along with this program; if not, write to the Free Software
*  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*  $Id$
*/
package org.exist.storage;

import java.io.File;
import java.util.Iterator;

import junit.framework.TestCase;
import junit.textui.TestRunner;

import org.exist.collections.Collection;
import org.exist.collections.IndexInfo;
import org.exist.dom.DocumentImpl;
import org.exist.storage.txn.TransactionManager;
import org.exist.storage.txn.Txn;
import org.exist.util.Configuration;
import org.exist.util.XMLFilenameFilter;
import org.exist.xmldb.XmldbURI;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

public class ConcurrentStoreTest extends TestCase {
 
    public static void main(String[] args) {
        TestRunner.run(ConcurrentStoreTest.class);
    }
   
    //TODO : revisit !
    private static String directory = "/home/wolf/xml/shakespeare";
    private static XmldbURI TEST_COLLECTION_URI = XmldbURI.ROOT_COLLECTION_URI.append("test");
   
    private static File dir = new File(directory);
   
    private BrokerPool pool;
    private Collection test, test2;
   
    public synchronized void testStore() {
      try {
          BrokerPool.FORCE_CORRUPTION = true;
          pool = startDB();
          setupCollections();
         
          Thread t1 = new StoreThread1();
          t1.start();
         
          wait(8000);
         
          Thread t2 = new StoreThread2();
          t2.start();
         
          t1.join();
          t2.join();
      } catch (Exception e) {           
          fail(e.getMessage())
      }
    }
   
    public void testRead() {
        BrokerPool.FORCE_CORRUPTION = false;
        pool = startDB();
       
        DBBroker broker = null;
        try {
            broker = pool.get(pool.getSecurityManager().getSystemSubject());
            test = broker.getCollection(TEST_COLLECTION_URI.append("test1"));
            assertNotNull(test);
            test2 = broker.getCollection(TEST_COLLECTION_URI.append("test2"));
            assertNotNull(test2);
            System.out.println("Contents of collection " + test.getURI() + ":");
            for (Iterator<DocumentImpl> i = test.iterator(broker); i.hasNext(); ) {
                DocumentImpl next = i.next();
                System.out.println("- " + next.getURI());
            }
      } catch (Exception e) {           
          fail(e.getMessage());             
        } finally {
            pool.release(broker);
        }
    }
   
    protected void setupCollections() {
        DBBroker broker = null;
        TransactionManager transact = pool.getTransactionManager();
        Txn transaction = transact.beginTransaction();
        try {
            broker = pool.get(pool.getSecurityManager().getSystemSubject());
           
            System.out.println("Transaction started ...");
           
            Collection root = broker.getOrCreateCollection(transaction, TEST_COLLECTION_URI);
            broker.saveCollection(transaction, root);
           
            test = broker.getOrCreateCollection(transaction, TEST_COLLECTION_URI.append("test1"));
            broker.saveCollection(transaction, test);
           
            test2 = broker.getOrCreateCollection(transaction, TEST_COLLECTION_URI.append("test2"));
            broker.saveCollection(transaction, test2);
           
            transact.commit(transaction);
        } catch (Exception e) {
            transact.abort(transaction);           
            fail(e.getMessage());
        } finally {
            pool.release(broker);
        }
    }
   
    protected BrokerPool startDB() {
        try {
            Configuration config = new Configuration();
            BrokerPool.configure(1, 5, config);
            return BrokerPool.getInstance();
        } catch (Exception e) {           
            fail(e.getMessage());
        }
        return null;
    }

    protected void tearDown() {
        BrokerPool.stopAll(false);
    }
   
    class StoreThread1 extends Thread {
       
        public void run() {
            DBBroker broker = null;
            try {
                broker = pool.get(pool.getSecurityManager().getSystemSubject());
               
                TransactionManager transact = pool.getTransactionManager();
                Txn transaction = transact.beginTransaction();
               
                System.out.println("Transaction started ...");
                XMLFilenameFilter filter = new XMLFilenameFilter();
                File files[] = dir.listFiles(filter);
               
                File f;
                IndexInfo info;
                // store some documents into the test collection
                for (int i = 0; i < files.length; i++) {
                    f = files[i];
                    try {
                        info = test.validateXMLResource(transaction, broker, XmldbURI.create(f.getName()), new InputSource(f.toURI().toASCIIString()));
                        test.store(transaction, broker, info, new InputSource(f.toURI().toASCIIString()), false);
                    } catch (SAXException e) {
                        System.err.println("Error found while parsing document: " + f.getName() + ": " + e.getMessage());
                    }
//                    if (i % 5 == 0) {
//                        transact.commit(transaction);
//                        transaction = transact.beginTransaction();
//                    }
                }
               
                transact.commit(transaction);
               
//              Don't commit...
                transact.getJournal().flushToLog(true);
                System.out.println("Transaction interrupted ...");
          } catch (Exception e) {           
              fail(e.getMessage());
            } finally {
                pool.release(broker);
            }
        }
    }
   
    class StoreThread2 extends Thread {
        public void run() {
            DBBroker broker = null;
            try {
                broker = pool.get(pool.getSecurityManager().getSystemSubject());
               
                TransactionManager transact = pool.getTransactionManager();
                Txn transaction = transact.beginTransaction();
               
                System.out.println("Transaction started ...");
               
                Iterator<DocumentImpl> i = test.iterator(broker);
                DocumentImpl doc = i.next();
               
                System.out.println("\nREMOVING DOCUMENT\n");
                test.removeXMLResource(transaction, broker, doc.getFileURI());
               
                File f = new File(dir + File.separator + "hamlet.xml");
                try {
                    IndexInfo info = test.validateXMLResource(transaction, broker, XmldbURI.create("test.xml"), new InputSource(f.toURI().toASCIIString()));
                    test.store(transaction, broker, info, new InputSource(f.toURI().toASCIIString()), false);
                } catch (SAXException e) {
                    System.err.println("Error found while parsing document: " + f.getName() + ": " + e.getMessage());
                }
               
                transact.commit(transaction);
            } catch (Exception e) {
                e.printStackTrace();
                fail(e.getMessage());
            } finally {
                pool.release(broker);
            }
        }
    }
}
TOP

Related Classes of org.exist.storage.ConcurrentStoreTest$StoreThread2

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.