1 |
43394
|
claudio.at
|
package eu.dnetlib.data.mapreduce.hbase.broker;
|
2 |
|
|
|
3 |
|
|
import java.util.UUID;
|
4 |
|
|
|
5 |
50985
|
claudio.at
|
import eu.dnetlib.data.mapreduce.hbase.broker.model.EventWrapper;
|
6 |
44085
|
michele.ar
|
import org.apache.commons.lang.math.RandomUtils;
|
7 |
|
|
import org.apache.commons.logging.Log;
|
8 |
|
|
import org.apache.commons.logging.LogFactory;
|
9 |
|
|
import org.dom4j.DocumentException;
|
10 |
|
|
import org.junit.Test;
|
11 |
|
|
|
12 |
43394
|
claudio.at
|
import com.googlecode.protobuf.format.JsonFormat;
|
13 |
44085
|
michele.ar
|
|
14 |
43558
|
claudio.at
|
import eu.dnetlib.broker.objects.OpenAireEventPayload;
|
15 |
43394
|
claudio.at
|
import eu.dnetlib.data.mapreduce.hbase.broker.mapping.EventFactory;
|
16 |
|
|
import eu.dnetlib.data.mapreduce.hbase.broker.mapping.HighlightFactory;
|
17 |
|
|
import eu.dnetlib.data.mapreduce.hbase.broker.mapping.OpenAireEventPayloadFactory;
|
18 |
43425
|
claudio.at
|
import eu.dnetlib.data.mapreduce.hbase.broker.model.EventMessage;
|
19 |
43394
|
claudio.at
|
import eu.dnetlib.data.mapreduce.util.OafTest;
|
20 |
43443
|
claudio.at
|
import eu.dnetlib.data.proto.FieldTypeProtos.KeyValue;
|
21 |
|
|
import eu.dnetlib.data.proto.FieldTypeProtos.Qualifier;
|
22 |
|
|
import eu.dnetlib.data.proto.FieldTypeProtos.StructuredProperty;
|
23 |
43394
|
claudio.at
|
import eu.dnetlib.data.proto.OafProtos.OafEntity;
|
24 |
|
|
import eu.dnetlib.data.proto.OafProtos.OafEntity.Builder;
|
25 |
|
|
import eu.dnetlib.data.proto.ResultProtos.Result;
|
26 |
43443
|
claudio.at
|
import eu.dnetlib.data.proto.ResultProtos.Result.Instance;
|
27 |
43394
|
claudio.at
|
import eu.dnetlib.data.proto.TypeProtos.Type;
|
28 |
|
|
|
29 |
|
|
/**
|
30 |
|
|
* Created by claudio on 22/07/16.
|
31 |
|
|
*/
|
32 |
|
|
public class EventFactoryTest {
|
33 |
|
|
|
34 |
|
|
private static final Log log = LogFactory.getLog(EventFactoryTest.class);
|
35 |
|
|
|
36 |
|
|
@Test
|
37 |
44085
|
michele.ar
|
public void testEventFactory() throws DocumentException {
|
38 |
43394
|
claudio.at
|
|
39 |
44085
|
michele.ar
|
final OafEntity source = getEntity("id_1", null, "pid_1").setResult(
|
40 |
|
|
Result.newBuilder().setMetadata(
|
41 |
|
|
Result.Metadata.newBuilder().setDateofacceptance(OafTest.sf("2012-01-01"))
|
42 |
|
|
.addTitle(sp("vvvv Title", "main title", "dnet:dataCite_title"))
|
43 |
|
|
.setResulttype(q("publication", "dnet:result_typologies")))
|
44 |
|
|
.addInstance(Instance.newBuilder()
|
45 |
|
|
.setHostedby(kv("456", "PubMed"))
|
46 |
49096
|
claudio.at
|
.setAccessright(q("OPEN", "dnet:licenses"))
|
47 |
44085
|
michele.ar
|
.addUrl("http://456")))
|
48 |
|
|
.build();
|
49 |
43394
|
claudio.at
|
|
50 |
44085
|
michele.ar
|
final OafEntity oaf = getEntity("id_2", "originalId_2", "pid_2").setResult(
|
51 |
|
|
Result.newBuilder().setMetadata(
|
52 |
|
|
Result.Metadata.newBuilder().setDateofacceptance(OafTest.sf(""))
|
53 |
|
|
.addTitle(sp("aaaa Title", "main title", "dnet:dataCite_title"))
|
54 |
|
|
.setResulttype(q("publication", "dnet:result_typologies")))
|
55 |
|
|
.addInstance(
|
56 |
|
|
Instance.newBuilder()
|
57 |
|
|
.setHostedby(kv("123", "Puma"))
|
58 |
49096
|
claudio.at
|
.setAccessright(q("CLOSED", "dnet:licenses"))
|
59 |
44085
|
michele.ar
|
.addUrl("http://123")))
|
60 |
|
|
.build();
|
61 |
43394
|
claudio.at
|
|
62 |
|
|
log.info("oaf: " + JsonFormat.printToString(oaf));
|
63 |
|
|
|
64 |
43612
|
claudio.at
|
final float trust = RandomUtils.nextFloat();
|
65 |
44085
|
michele.ar
|
final EventMessage event = EventFactory.asEvent(oaf, Topic.ENRICH_MISSING_PUBLICATION_DATE, new OpenAireEventPayload(), source, trust);
|
66 |
43394
|
claudio.at
|
|
67 |
43612
|
claudio.at
|
final OpenAireEventPayload p = OpenAireEventPayloadFactory.fromOAF(oaf, source, trust);
|
68 |
43394
|
claudio.at
|
final OpenAireEventPayload payload = HighlightFactory.highlightEnrichPublicationDate(p, OafTest.sf("2012-01-01"));
|
69 |
|
|
|
70 |
43400
|
claudio.at
|
final String payloadJson = payload.toJSON();
|
71 |
43394
|
claudio.at
|
|
72 |
43400
|
claudio.at
|
log.info("payload: " + payloadJson);
|
73 |
|
|
log.info("payload: " + OpenAireEventPayload.fromJSON(payloadJson).toJSON());
|
74 |
|
|
|
75 |
43394
|
claudio.at
|
event.setPayload(payload.toJSON());
|
76 |
|
|
|
77 |
50985
|
claudio.at
|
log.info("event message: " + event.toString());
|
78 |
43394
|
claudio.at
|
|
79 |
50985
|
claudio.at
|
final EventWrapper wrapper = new EventWrapper(event, "test");
|
80 |
|
|
|
81 |
|
|
log.info("broker event: " + wrapper.asBrokerEvent().toJson());
|
82 |
|
|
|
83 |
43394
|
claudio.at
|
}
|
84 |
|
|
|
85 |
43443
|
claudio.at
|
private Qualifier.Builder q(final String classid, final String scheme) {
|
86 |
|
|
return OafTest.getQualifier(classid, scheme);
|
87 |
|
|
}
|
88 |
|
|
|
89 |
|
|
private KeyValue.Builder kv(final String k, final String v) {
|
90 |
|
|
return KeyValue.newBuilder().setKey(k).setValue(v);
|
91 |
|
|
}
|
92 |
|
|
|
93 |
|
|
private StructuredProperty.Builder sp(final String v, final String classid, final String scheme) {
|
94 |
|
|
return OafTest.getStructuredproperty(v, classid, scheme);
|
95 |
|
|
}
|
96 |
|
|
|
97 |
43394
|
claudio.at
|
private OafEntity.Builder getEntity(final String id, final String originalId, final String pid) {
|
98 |
|
|
final Builder entity =
|
99 |
|
|
OafEntity.newBuilder().setType(Type.result).setId(id).addOriginalId(originalId != null ? originalId : UUID.randomUUID().toString());
|
100 |
|
|
|
101 |
|
|
if (pid != null) {
|
102 |
|
|
entity.addPid(OafTest.getStructuredproperty(pid, "doi", "scheme"));
|
103 |
|
|
}
|
104 |
|
|
|
105 |
|
|
return entity;
|
106 |
|
|
}
|
107 |
|
|
|
108 |
|
|
}
|