view bindings/java/test/TestQuery.java @ 767:6d0d41604aba

Fix analogous signed/unsigned mistake in command-line binary Now that I've made this mistake somewhat catastrophically, it's fairly easy to spot.
author mas01cr
date Thu, 02 Jun 2011 16:31:44 +0000
parents a9978a6d0bb3
children
line wrap: on
line source
import junit.framework.*;
import java.io.File;
import java.util.Vector;
import org.omras2.*;

public class TestQuery extends TestCase
{
	File testDBFile;
	File testFeatureFile;
	protected void setUp()
	{
		testDBFile = new File("testfiles/test.adb");
		testFeatureFile = new File("testfiles/testfeature");
		if(testDBFile.exists())
			testDBFile.delete();
	}

	public void testQuery()
	{
		// Insert the same feature twice
		AudioDB testDB = new AudioDB(testDBFile);
		assertTrue("DB created", testDB.create(1, 2, 1));
		testDB.open(AudioDB.Mode.O_RDWR);
		assertTrue("Insert feature file", testDB.insert("feat1", testFeatureFile));
		assertTrue("Insert feature file again", testDB.insert("feat2", testFeatureFile));
		testDB.close();

		testDB.open(AudioDB.Mode.O_RDONLY);
		Status status = testDB.getStatus();
		assertEquals("Two features", 2, status.getNumFiles());

		Query query = new Query();
		query.setSeqLength(1);
		query.setSeqStart(0);
		query.setIncludeKeys(new String[]{"feat1"});
		query.setExcludeKeys(new String[]{"feat2"});
		Vector<Result> results = testDB.query("feat1", query);
	}
	
	public void testDataQuery()
	{
		// Insert the same feature twice
		AudioDB testDB = new AudioDB(testDBFile);
		assertTrue("DB created", testDB.create(1, 2, 1));
		testDB.open(AudioDB.Mode.O_RDWR);
		assertTrue("Insert feature file", testDB.insert("feat1", testFeatureFile));
		assertTrue("Insert feature file again", testDB.insert("feat2", testFeatureFile));
		testDB.close();

		testDB.open(AudioDB.Mode.O_RDONLY);
		Status status = testDB.getStatus();
		assertEquals("Two features", 2, status.getNumFiles());

		Query query = new Query();
		query.setSeqLength(1);
		query.setSeqStart(0);
		query.setIncludeKeys(new String[]{"feat1"});
		query.setExcludeKeys(new String[]{"feat2"});

		Datum datum = new Datum();
		datum.setData(new double[]{0.0, 2.2, 1.1});
		datum.setNvectors(3);
		datum.setDim(1);
		query.setDatum(datum);

		Vector<Result> results = testDB.query(query);
		if(results != null)
		{
			System.out.println("Here with "+results);
		}
	}

/*
	public void testAdvanced()
	{
		AudioDB testDB = new AudioDB(new File("testfiles/9.adb"));
		testDB.open(AudioDB.Mode.O_RDONLY);
		Status status = testDB.getStatus();
		System.out.println(status.getNumFiles());
		Query query = new Query();
		query.setSeqLength(1);
		query.setSeqStart(0);
		query.setExcludeKeys(new String[]{"KSA_CHARM_27", "KSA_CHARM_300"});

		Datum datum = new Datum();
		datum.setData(new double[]{0.0, 2.2, 1.1, 4, 2, 6, 3, 8, 2, 4, 5, 8});
		datum.setDim(12);
		datum.setNvectors(1);
		query.setDatum(datum);

		Vector<Result> results = testDB.query(query);

		System.out.println(results.size());
		for(Result result: results)
		{
			System.out.print(result.getKey());
			System.out.print(" "+result.getDistance());
			System.out.print(" "+result.getQpos());
			System.out.println(" "+result.getIpos());
		}

	}
*/
}