blob: 8cec7806f9b73abe3240eb0bb5ad98466d5e1e7c [file] [log] [blame]
/****************************************************************
* 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.apache.james.mailrepository.cassandra;
import static org.assertj.core.api.Assertions.assertThat;
import java.util.Optional;
import org.apache.james.backends.cassandra.CassandraCluster;
import org.apache.james.backends.cassandra.CassandraClusterExtension;
import org.apache.james.backends.cassandra.components.CassandraModule;
import org.apache.james.backends.cassandra.init.configuration.CassandraConfiguration;
import org.apache.james.backends.cassandra.versions.CassandraSchemaVersionModule;
import org.apache.james.mailrepository.api.MailKey;
import org.apache.james.mailrepository.api.MailRepositoryUrl;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Nested;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.RegisterExtension;
class CassandraMailRepositoryKeysDAOTest {
static final MailRepositoryUrl URL = MailRepositoryUrl.from("proto://url");
static final MailRepositoryUrl URL2 = MailRepositoryUrl.from("proto://url2");
static final MailKey KEY_1 = new MailKey("key1");
static final MailKey KEY_2 = new MailKey("key2");
static final MailKey KEY_3 = new MailKey("key3");
static final CassandraModule MODULE = CassandraModule.aggregateModules(CassandraMailRepositoryModule.MODULE,
CassandraSchemaVersionModule.MODULE);
@RegisterExtension
static CassandraClusterExtension cassandraCluster = new CassandraClusterExtension(MODULE);
CassandraMailRepositoryKeysDAO testee;
@BeforeEach
void setUp(CassandraCluster cassandra) {
testee = new CassandraMailRepositoryKeysDAO(cassandra.getConf(), CassandraConfiguration.DEFAULT_CONFIGURATION);
}
@Test
void listShouldBeEmptyByDefault() {
assertThat(testee.list(URL).collectList().block())
.isEmpty();
}
@Test
void listShouldReturnEmptyByDefault() {
testee.store(URL, KEY_1).block();
assertThat(testee.list(URL).collectList().block())
.containsOnly(KEY_1);
}
@Test
void listShouldNotReturnElementsOfOtherRepositories() {
testee.store(URL, KEY_1).block();
assertThat(testee.list(URL2).collectList().block())
.isEmpty();
}
@Test
void listShouldReturnSeveralElements() {
testee.store(URL, KEY_1).block();
testee.store(URL, KEY_2).block();
testee.store(URL, KEY_3).block();
assertThat(testee.list(URL).collectList().block())
.containsOnly(KEY_1, KEY_2, KEY_3);
}
@Test
void listShouldNotReturnRemovedElements() {
testee.store(URL, KEY_1).block();
testee.store(URL, KEY_2).block();
testee.store(URL, KEY_3).block();
testee.remove(URL, KEY_2).block();
assertThat(testee.list(URL).collectList().block())
.containsOnly(KEY_1, KEY_3);
}
@Test
void removeShouldBeIdempotent() {
testee.remove(URL, KEY_2).block();
}
@Test
void removeShouldNotAffectOtherRepositories() {
testee.store(URL, KEY_1).block();
testee.remove(URL2, KEY_2).block();
assertThat(testee.list(URL).collectList().block())
.containsOnly(KEY_1);
}
@Test
void removeShouldReturnTrueWhenKeyDeleted() {
testee.store(URL, KEY_1).block();
boolean isDeleted = testee.remove(URL, KEY_1).block();
assertThat(isDeleted).isTrue();
}
@Test
void storeShouldReturnTrueWhenNotPreviouslyStored() {
boolean isStored = testee.store(URL, KEY_1).block();
assertThat(isStored).isTrue();
}
@Nested
class WhenStrongConsistencyIsFalse {
CassandraMailRepositoryKeysDAO testee;
@BeforeEach
void setUp(CassandraCluster cassandra) {
testee = new CassandraMailRepositoryKeysDAO(cassandra.getConf(), CassandraConfiguration.builder()
.mailRepositoryStrongConsistency(Optional.of(false))
.build());
}
@Test
void storeShouldReturnTrueWhenPreviouslyStored() {
testee.store(URL, KEY_1).block();
assertThat(testee.store(URL, KEY_1).block()).isTrue();
}
@Test
void removeShouldReturnTrueWhenKeyNotDeleted() {
assertThat(testee.remove(URL2, KEY_2).block()).isTrue();
}
}
@Nested
class WhenStrongConsistencyIsTrue {
CassandraMailRepositoryKeysDAO testee;
@BeforeEach
void setUp(CassandraCluster cassandra) {
testee = new CassandraMailRepositoryKeysDAO(cassandra.getConf(), CassandraConfiguration.builder()
.mailRepositoryStrongConsistency(Optional.of(true))
.build());
}
@Test
void storeShouldReturnFalseWhenPreviouslyStored() {
testee.store(URL, KEY_1).block();
assertThat(testee.store(URL, KEY_1).block()).isFalse();
}
@Test
void removeShouldReturnFalseWhenKeyNotDeleted() {
assertThat(testee.remove(URL2, KEY_2).block()).isFalse();
}
}
}