-
Notifications
You must be signed in to change notification settings - Fork 96
/
Copy pathSerdeConfigurationTest.java
81 lines (65 loc) · 2.77 KB
/
SerdeConfigurationTest.java
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
package serde;
import com.arangodb.ArangoDB;
import com.arangodb.config.ArangoConfigProperties;
import com.arangodb.serde.ArangoSerde;
import com.arangodb.serde.jackson.internal.JacksonSerdeImpl;
import com.arangodb.serde.jackson.json.JacksonJsonSerdeProvider;
import com.arangodb.serde.jackson.vpack.JacksonVPackSerdeProvider;
import com.arangodb.serde.jsonb.JsonbSerde;
import com.arangodb.serde.jsonb.JsonbSerdeProvider;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.junit.jupiter.api.Test;
import java.lang.invoke.MethodHandles;
import java.lang.invoke.VarHandle;
import static org.assertj.core.api.Assertions.assertThat;
public class SerdeConfigurationTest {
private final VarHandle JACKSON_SERDE_IMPL_MAPPER;
{
try {
JACKSON_SERDE_IMPL_MAPPER = MethodHandles
.privateLookupIn(JacksonSerdeImpl.class, MethodHandles.lookup())
.findVarHandle(JacksonSerdeImpl.class, "mapper", ObjectMapper.class);
} catch (NoSuchFieldException | IllegalAccessException e) {
throw new RuntimeException(e);
}
}
@Test
void vpackSerdeProvider() {
ArangoDB adb = new ArangoDB.Builder()
.host("foo", 1111)
.serdeProviderClass(JacksonVPackSerdeProvider.class)
.build();
ArangoSerde serde = adb.getSerde().getUserSerde();
assertThat(serde).isInstanceOf(JacksonSerdeImpl.class);
ObjectMapper mapper = (ObjectMapper) JACKSON_SERDE_IMPL_MAPPER.get(serde);
assertThat(mapper.getFactory().getFormatName()).isEqualTo("Velocypack");
}
@Test
void jsonSerdeProvider() {
ArangoDB adb = new ArangoDB.Builder()
.host("foo", 1111)
.serdeProviderClass(JacksonJsonSerdeProvider.class)
.build();
ArangoSerde serde = adb.getSerde().getUserSerde();
assertThat(serde).isInstanceOf(JacksonSerdeImpl.class);
ObjectMapper mapper = (ObjectMapper) JACKSON_SERDE_IMPL_MAPPER.get(serde);
assertThat(mapper.getFactory().getFormatName()).isEqualTo("JSON");
}
@Test
void jsonBSerdeProvider() {
ArangoDB adb = new ArangoDB.Builder()
.host("foo", 1111)
.serdeProviderClass(JsonbSerdeProvider.class)
.build();
ArangoSerde serde = adb.getSerde().getUserSerde();
assertThat(serde).isInstanceOf(JsonbSerde.class);
}
@Test
void jsonBSerdeProviderFromConfigFile() {
ArangoDB adb = new ArangoDB.Builder()
.loadProperties(ArangoConfigProperties.fromFile("arangodb-serde-provider.properties"))
.build();
ArangoSerde serde = adb.getSerde().getUserSerde();
assertThat(serde).isInstanceOf(JsonbSerde.class);
}
}