diff --git a/rados/pom.xml b/rados/pom.xml
index c25bccef..5a79ae64 100644
--- a/rados/pom.xml
+++ b/rados/pom.xml
@@ -1,61 +1,67 @@
4.0.0
com.yahoo.ycsb
binding-parent
0.9.0-SNAPSHOT
../binding-parent
rados-binding
rados of Ceph FS binding
jar
com.ceph
rados
${rados.version}
com.yahoo.ycsb
core
${project.version}
provided
org.json
json
${json.version}
- org.testng
- testng
- 6.1.1
- test
+ org.testng
+ testng
+ 6.1.1
+ test
+
+
+ junit
+ junit
+ 4.12
+ test
0.2.0
20160212
diff --git a/rados/src/test/java/com/yahoo/ycsb/db/RadosClientTest.java b/rados/src/test/java/com/yahoo/ycsb/db/RadosClientTest.java
index f6dadd96..52b86c5d 100644
--- a/rados/src/test/java/com/yahoo/ycsb/db/RadosClientTest.java
+++ b/rados/src/test/java/com/yahoo/ycsb/db/RadosClientTest.java
@@ -1,144 +1,151 @@
/**
* Copyright (c) 2016 YCSB contributors. All rights reserved.
*
* 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. See accompanying
* LICENSE file.
*/
package com.yahoo.ycsb.db;
import static org.testng.AssertJUnit.assertEquals;
+import static org.junit.Assume.assumeNoException;
+
import com.yahoo.ycsb.ByteIterator;
import com.yahoo.ycsb.DBException;
import com.yahoo.ycsb.Status;
import com.yahoo.ycsb.StringByteIterator;
import org.testng.annotations.AfterClass;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.UUID;
/**
* Test for the binding of RADOS of Ceph.
*
* See {@code rados/README.md} for details.
*/
public class RadosClientTest {
private static RadosClient radosclient;
public static final String POOL_PROPERTY = "rados.pool";
public static final String POOL_TEST = "rbd";
private static final String TABLE_NAME = "table0";
private static final String KEY0 = "key0";
private static final String KEY1 = "key1";
private static final String KEY2 = "key2";
private static final HashMap DATA;
private static final HashMap DATA_UPDATED;
static {
DATA = new HashMap(10);
DATA_UPDATED = new HashMap(10);
for (int i = 0; i < 10; i++) {
String key = "key" + UUID.randomUUID();
DATA.put(key, new StringByteIterator("data" + UUID.randomUUID()));
DATA_UPDATED.put(key, new StringByteIterator("data" + UUID.randomUUID()));
}
}
@BeforeClass
public void setupClass() throws DBException {
radosclient = new RadosClient();
Properties p = new Properties();
p.setProperty(POOL_PROPERTY, POOL_TEST);
- radosclient.setProperties(p);
- radosclient.init();
+ try {
+ radosclient.setProperties(p);
+ radosclient.init();
+ }
+ catch (DBException e) {
+ assumeNoException("Ceph cluster is not running. Skipping tests.", e);
+ }
}
@AfterClass
public void teardownClass() throws DBException {
if (radosclient != null) {
radosclient.cleanup();
}
}
@BeforeMethod
public void setUp() {
radosclient.insert(TABLE_NAME, KEY0, DATA);
}
@AfterMethod
public void tearDown() {
radosclient.delete(TABLE_NAME, KEY0);
}
@Test
public void insertTest() {
Status result = radosclient.insert(TABLE_NAME, KEY1, DATA);
assertEquals(Status.OK, result);
}
@Test
public void updateTest() {
radosclient.insert(TABLE_NAME, KEY2, DATA);
Status result = radosclient.update(TABLE_NAME, KEY2, DATA_UPDATED);
assertEquals(Status.OK, result);
HashMap ret = new HashMap(10);
radosclient.read(TABLE_NAME, KEY2, DATA.keySet(), ret);
compareMap(DATA_UPDATED, ret);
radosclient.delete(TABLE_NAME, KEY2);
}
@Test
public void readTest() {
HashMap ret = new HashMap(10);
Status result = radosclient.read(TABLE_NAME, KEY0, DATA.keySet(), ret);
assertEquals(Status.OK, result);
compareMap(DATA, ret);
}
private void compareMap(HashMap src, HashMap dest) {
assertEquals(src.size(), dest.size());
Set setSrc = src.entrySet();
Iterator itSrc = setSrc.iterator();
for (int i = 0; i < 10; i++) {
Map.Entry entrySrc = itSrc.next();
assertEquals(entrySrc.getValue().toString(), dest.get(entrySrc.getKey()).toString());
}
}
@Test
public void deleteTest() {
Status result = radosclient.delete(TABLE_NAME, KEY0);
assertEquals(Status.OK, result);
}
}