Project

General

Profile

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
}