Package org.fusesource.hawtdb.internal.index

Source Code of org.fusesource.hawtdb.internal.index.RecoveryTest

/**
* 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.fusesource.hawtdb.internal.index;

import org.fusesource.hawtbuf.codec.LongCodec;
import org.fusesource.hawtbuf.codec.StringCodec;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;

import java.io.File;
import java.io.IOException;
import java.util.Random;

import org.fusesource.hawtdb.api.BTreeIndexFactory;
import org.fusesource.hawtdb.api.SortedIndex;
import org.fusesource.hawtdb.api.Transaction;
import org.fusesource.hawtdb.api.TxPageFile;
import org.fusesource.hawtdb.api.TxPageFileFactory;
import static org.junit.Assert.assertEquals;

/**
* @author <a href="http://hiramchirino.com">Hiram Chirino</a>
*/
public class RecoveryTest {

    private TxPageFileFactory pff;
    private TxPageFile pf;


    protected TxPageFileFactory createConcurrentPageFileFactory() {
        TxPageFileFactory rc = new TxPageFileFactory();
        rc.setPageSize((short) 512);
        rc.setFile(new File("target/test-data/" + getClass().getName() + ".db"));
        return rc;
    }

    @Before
    public void setUp() throws Exception {
        pff = createConcurrentPageFileFactory();
        pff.getFile().delete();
        pff.open();
        pf = pff.getTxPageFile();
    }

    @After
    public void tearDown() throws Exception {
        pff.close();
    }

    protected void reload() throws IOException {
        pff.close();
        pff.open();
        pf = pff.getTxPageFile();
    }

    private static final BTreeIndexFactory<Long,String> ROOT_FACTORY = new BTreeIndexFactory<Long,String>();
    static {
        ROOT_FACTORY.setKeyCodec(LongCodec.INSTANCE);
        ROOT_FACTORY.setValueCodec(StringCodec.INSTANCE);
        ROOT_FACTORY.setDeferredEncoding(true);
    }

    @Test
    public void testAddRollback() throws IOException, ClassNotFoundException {

        // Create the root index at the root page.
        Transaction tx = pf.tx();
        SortedIndex<Long, String> root = ROOT_FACTORY.create(tx);
        assertEquals(0, root.getIndexLocation());
        tx.commit();
        pf.flush();

        int MAX_KEY=1000;
        long putCounter=0;
        long removeCounter=0;

        final Random random = new Random(7777);

        for(int recoveryLoop=0; recoveryLoop < 100; recoveryLoop ++) {
            if( recoveryLoop%10 == 0 ) {
                System.out.println("at recovery loop: "+recoveryLoop+", puts: "+putCounter+", removes: "+removeCounter);
            }

            // validate that the number of keys in the map is what is expected.
            {
                tx = pf.tx();
                root = ROOT_FACTORY.open(tx, 0);
                assertEquals(putCounter-removeCounter, root.size());
                tx.commit();
            }


            // Do a bunch of transactions before reloading the page file.
            for(int txLoop=0; txLoop < 1000; txLoop ++) {

                tx = pf.tx();
                root = ROOT_FACTORY.open(tx, 0);

                // do a couple of random inserts and deletes.
                for(int keyLoop=0; keyLoop < 10; keyLoop ++) {

                    Long key = (long)random.nextInt(MAX_KEY);
                    String value = root.get(key);
                    if( value == null ) {
                        root.put(key, "value");
                        putCounter++;
                    } else {
                        root.remove(key);
                        removeCounter++;
                    }

                }
                tx.commit();

                // flush every 100 commits..
                if( txLoop%100 == 0 ) {
                    pf.flush();
                }
            }

            reload();
        }

        int mapSize = 0;


    }
}
TOP

Related Classes of org.fusesource.hawtdb.internal.index.RecoveryTest

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.