/** * Copyright 2014 Sunny Gleason and original author or authors * * Licensed 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 io.kazuki.v0.store.index; import io.kazuki.v0.internal.helper.TestSupport; import io.kazuki.v0.store.Foo; import io.kazuki.v0.store.KazukiException; import io.kazuki.v0.store.Key; import io.kazuki.v0.store.index.query.QueryBuilder; import io.kazuki.v0.store.index.query.QueryOperator; import io.kazuki.v0.store.index.query.ValueHolder; import io.kazuki.v0.store.index.query.ValueType; import io.kazuki.v0.store.keyvalue.KeyValueIterator; import io.kazuki.v0.store.keyvalue.KeyValuePair; import io.kazuki.v0.store.keyvalue.KeyValueStore; import io.kazuki.v0.store.keyvalue.KeyValueStoreIteration.SortDirection; import io.kazuki.v0.store.lifecycle.Lifecycle; import io.kazuki.v0.store.schema.SchemaStore; import io.kazuki.v0.store.schema.TypeValidation; import io.kazuki.v0.store.schema.model.Schema; import java.util.Collection; import java.util.Iterator; import java.util.Map; import org.junit.Assert; import org.testng.annotations.Test; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; import com.google.inject.Injector; import com.google.inject.name.Names; public abstract class SecondaryIndexStoreTestBase extends TestSupport { protected abstract Injector getInjector(); @Test public void testDemo() throws Exception { Injector inject = getInjector(); final Lifecycle lifecycle = inject.getInstance(com.google.inject.Key.get(Lifecycle.class, Names.named("foo"))); KeyValueStore store = inject.getInstance(com.google.inject.Key.get(KeyValueStore.class, Names.named("foo"))); SecondaryIndexStore index = inject .getInstance(com.google.inject.Key.get(SecondaryIndexStore.class, Names.named("foo"))); SchemaStore manager = inject.getInstance(com.google.inject.Key.get(SchemaStore.class, Names.named("foo"))); lifecycle.init(); lifecycle.start(); Assert.assertFalse(store.iterators().iterator("$schema", Schema.class, SortDirection.ASCENDING) .hasNext()); manager.createSchema("foo", Foo.FOO_SCHEMA); KeyValuePair<Foo> kvp0 = store.create("foo", Foo.class, new Foo("k00", "v99"), TypeValidation.STRICT); Key k0 = kvp0.getKey(); Key k1 = store.create("foo", Foo.class, new Foo("k11", "v88"), TypeValidation.STRICT).getKey(); Key k2 = store.create("foo", Foo.class, new Foo("k22", "v77"), TypeValidation.STRICT).getKey(); Key k3 = store.create("foo", Foo.class, new Foo("k33", "v66"), TypeValidation.STRICT).getKey(); Key k4 = store.create("foo", Foo.class, new Foo("k44", "v55"), TypeValidation.STRICT).getKey(); Key k5 = store.create("foo", Foo.class, new Foo("k00", "v55"), TypeValidation.STRICT).getKey(); try { store.create("foo", Foo.class, new Foo("k00", "v55"), TypeValidation.STRICT).getKey(); Assert.fail("should be uniqueness failure"); } catch (KazukiException expected) { // awesome - we got it } try { store.update(k0, Foo.class, new Foo("k00", "v55")); Assert.fail("should be uniqueness failure"); } catch (KazukiException expected) { // awesome - we got it } try { store.updateVersioned(k0, kvp0.getVersion(), Foo.class, new Foo("k00", "v55")); Assert.fail("should be uniqueness failure"); } catch (KazukiException expected) { // awesome - we got it } try (KeyValueIterator<Key> iter = index.queryWithoutPagination( "foo", Foo.class, "fooKey", new QueryBuilder() .andMatchesSingle("fooKey", QueryOperator.EQ, ValueType.STRING, "k00").build(), SortDirection.ASCENDING, null, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k0, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k5, iter.next()); Assert.assertFalse(iter.hasNext()); } try (KeyValueIterator<Key> iter = index.queryWithoutPagination( "foo", Foo.class, "fooKey", new QueryBuilder() .andMatchesSingle("fooKey", QueryOperator.EQ, ValueType.STRING, "k00").build(), SortDirection.ASCENDING, 1L, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k5, iter.next()); Assert.assertFalse(iter.hasNext()); } try (KeyValueIterator<Key> iter = index.queryWithoutPagination( "foo", Foo.class, "fooKey", new QueryBuilder() .andMatchesSingle("fooKey", QueryOperator.EQ, ValueType.STRING, "k00").build(), SortDirection.DESCENDING, null, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k5, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k0, iter.next()); Assert.assertFalse(iter.hasNext()); } try (KeyValueIterator<Key> iter = index.queryWithoutPagination( "foo", Foo.class, "fooKey", new QueryBuilder() .andMatchesSingle("fooKey", QueryOperator.EQ, ValueType.STRING, "k00").build(), SortDirection.DESCENDING, 1L, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k0, iter.next()); Assert.assertFalse(iter.hasNext()); } for (QueryOperator op : ImmutableList.of(QueryOperator.NE, QueryOperator.GT)) { try (KeyValueIterator<Key> iter = index.queryWithoutPagination("foo", Foo.class, "fooKey", new QueryBuilder().andMatchesSingle("fooKey", op, ValueType.STRING, "k00").build(), SortDirection.ASCENDING, null, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k1, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k2, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k3, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k4, iter.next()); Assert.assertFalse(iter.hasNext()); } } for (QueryOperator op : ImmutableList.of(QueryOperator.NE, QueryOperator.GT)) { try (KeyValueIterator<Key> iter = index.queryWithoutPagination("foo", Foo.class, "fooKey", new QueryBuilder().andMatchesSingle("fooKey", op, ValueType.STRING, "k00").build(), SortDirection.DESCENDING, null, null).iterator()) { Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k4, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k3, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k2, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k1, iter.next()); Assert.assertFalse(iter.hasNext()); } } Map<UniqueEntityDescription, Key> map = index.multiRetrieveUniqueKeys((Collection<UniqueEntityDescription>) ImmutableList.of( new UniqueEntityDescription("foo", Foo.class, "uniqueFooKeyValue", Foo.FOO_SCHEMA, ImmutableMap.of("fooKey", new ValueHolder(ValueType.STRING, "k00"), "fooValue", new ValueHolder(ValueType.STRING, "v99"))), new UniqueEntityDescription("foo", Foo.class, "uniqueFooKeyValue", Foo.FOO_SCHEMA, ImmutableMap.of("fooKey", new ValueHolder(ValueType.STRING, "k33"), "fooValue", new ValueHolder(ValueType.STRING, "v66"))), new UniqueEntityDescription("foo", Foo.class, "uniqueFooKeyValue", Foo.FOO_SCHEMA, ImmutableMap.of("fooKey", new ValueHolder(ValueType.STRING, "k00"), "fooValue", new ValueHolder(ValueType.STRING, "v55"))), new UniqueEntityDescription("foo", Foo.class, "uniqueFooKeyValue", Foo.FOO_SCHEMA, ImmutableMap.of("fooKey", new ValueHolder(ValueType.STRING, "k00"), "fooValue", new ValueHolder(ValueType.STRING, "v59"))))); Iterator<Key> iter = map.values().iterator(); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k0, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k3, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(k5, iter.next()); Assert.assertTrue(iter.hasNext()); Assert.assertEquals(null, iter.next()); Assert.assertFalse(iter.hasNext()); store.clear(false, false); } }