/
CassandraServiceTests.groovy
93 lines (74 loc) · 3.25 KB
/
CassandraServiceTests.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package codehead;
import java.nio.ByteBuffer;
import grails.test.*
import me.prettyprint.hector.api.beans.HColumn;
import me.prettyprint.hector.api.factory.HFactory;
import me.prettyprint.hector.api.mutation.MutationResult;
import me.prettyprint.hector.api.mutation.Mutator;
import me.prettyprint.hector.api.query.ColumnQuery;
import me.prettyprint.hector.api.query.QueryResult;
import org.apache.cassandra.thrift.NotFoundException;
class CassandraServiceTests extends GrailsUnitTestCase {
def cassandraService
protected void setUp() {
super.setUp()
mockLogging(CassandraService,true)
cassandraService = new CassandraService()
}
protected void tearDown() {
super.tearDown()
}
void testExceptionBlocker(){
def result = cassandraService.exceptionCatcher {
throw new NotFoundException()
}
assertNull(result) // and if you got not error, its all good.
}
/**
* The standard hector test, before the service refactoring...
*/
void testSetGetDeleteOldStyle(){
String cf = "Standard1"
String method = "testSetGetDeleteOldStyle"
String key = "${method}_Key"
String name = "${method}_Name"
String value = "${method}_Value"
Mutator<String> m = HFactory.createMutator(cassandraService.keyspace(),cassandraService.serializer(String.class));
MutationResult mr = m.insert(key, cf, HFactory.createColumn(name, value, cassandraService.serializer(String.class), cassandraService.serializer(String.class)));
ColumnQuery<String, String, String> q = HFactory.createColumnQuery(cassandraService.keyspace(), cassandraService.serializer(String.class), cassandraService.serializer(String.class), cassandraService.serializer(String.class))
q.setName(name).setColumnFamily(cf)
QueryResult<HColumn<String, String>> r = q.setKey(key).execute();
assertNotNull(r);
HColumn<String, String> c = r.get();
assertNotNull(c);
String foundvalue = c.getValue();
assertEquals(value, foundvalue);
String foundname = c.getName();
assertEquals(name, foundname);
assertEquals(q, r.getQuery());
m = HFactory.createMutator(cassandraService.keyspace(), cassandraService.serializer(String.class));
MutationResult mr2 = m.delete(key, cf, name, cassandraService.serializer(String.class));
// get already removed value
ColumnQuery<String, String, String> q2 = HFactory.createColumnQuery(cassandraService.keyspace(), cassandraService.serializer(String.class), cassandraService.serializer(String.class), cassandraService.serializer(String.class));
q2.setName(name).setColumnFamily(cf);
QueryResult<HColumn<String, String>> r2 = q2.setKey(key).execute();
assertNotNull(r2);
assertNull("Value should have been deleted", r2.get())
}
/**
* The standard hector test, before the service refactoring...
*/
void testSetGetDeleteGroovyStyle(){
String cf = "Standard1"
String method = "testSetGetDeleteGroovyStyle"
String key = "${method}_Key"
String name = "${method}_Name"
String value = "${method}_Value"
cassandraService.setValue(key,cf,name,value)
def result = cassandraService.getValue(key,cf,name,String.class)
assertNotNull(result);
assertEquals(value,result)
cassandraService.deleteValue(key,cf,name)
assertNull("Value should have been deleted", cassandraService.getValue(key,cf,name,String.class))
}
}