All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.icodegarden.nutrient.redis.test.concurrent.lock.RedisReentrantReadWriteLockTests Maven / Gradle / Ivy

The newest version!
package io.github.icodegarden.nutrient.redis.test.concurrent.lock;

import java.io.IOException;
import java.util.Set;

import org.junit.jupiter.api.AfterEach;
import org.junit.jupiter.api.BeforeEach;

import io.github.icodegarden.nutrient.lang.concurrent.lock.DistributedReentrantReadWriteLock;
import io.github.icodegarden.nutrient.redis.RedisExecutor;
import io.github.icodegarden.nutrient.redis.concurrent.lock.RedisReentrantReadWriteLock;
import io.github.icodegarden.nutrient.test.concurrent.lock.DistributedReentrantReadWriteLockTests;

/**
 * 
 * @author Fangfang.Xu
 *
 */
public abstract class RedisReentrantReadWriteLockTests extends DistributedReentrantReadWriteLockTests {

	protected abstract RedisExecutor newClearKeysRedisExecutor();
	
	protected abstract RedisExecutor newRedisExecutor();

	@BeforeEach
	void initClient() throws IOException {
//		RedisExecutor redisExecutor = new JedisPoolRedisExecutor(JedisPoolRedisExecutorTests.newJedisPool());
		RedisExecutor redisExecutor = newClearKeysRedisExecutor();
		
		Set keys = redisExecutor.keys("*".getBytes());
		keys.forEach(key -> {
			redisExecutor.del(key);
		});

		redisExecutor.close();
	}

	@AfterEach
	void closeClient() {
	}

	@Override
	protected DistributedReentrantReadWriteLock newLock(String name) {
		RedisExecutor redisExecutor = newRedisExecutor();
		return new RedisReentrantReadWriteLock(redisExecutor, name, 5L);
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy