Project

General

Profile

1 46537 alessia.ba
package eu.dnetlib.openaire.exporter;
2
3
import java.io.IOException;
4
5
import org.antlr.stringtemplate.StringTemplate;
6
import org.apache.commons.io.IOUtils;
7 46540 alessia.ba
import org.apache.commons.logging.Log;
8
import org.apache.commons.logging.LogFactory;
9 46537 alessia.ba
import org.junit.Before;
10
import org.junit.Test;
11 46546 alessia.ba
import org.junit.runner.RunWith;
12
import org.springframework.boot.test.context.SpringBootTest;
13 46537 alessia.ba
import org.springframework.core.io.ClassPathResource;
14
import org.springframework.core.io.Resource;
15 46546 alessia.ba
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
16 46537 alessia.ba
17
import static org.junit.Assert.assertEquals;
18 46546 alessia.ba
@RunWith(SpringJUnit4ClassRunner.class)
19
//@ContextConfiguration(classes={TestConfiguration.class})
20
@SpringBootTest
21 46537 alessia.ba
public class ProjectsControllerTest {
22
23 46540 alessia.ba
	private static final Log log = LogFactory.getLog(ProjectsControllerTest.class);
24 46537 alessia.ba
	private String queryTemplate = "/eu/dnetlib/openaire/exporter/sql/projects_fundings.sql.st";
25
26
	private Resource expectedQueryTemplate = new ClassPathResource("/eu/dnetlib/openaire/exporter/sql/expected_projects_fundings.sql.st");
27
28
	private ProjectsController controller;
29
	private ProjectQueryParams params;
30
31
	@Before
32
	public void setup() {
33
		controller = new ProjectsController();
34
		Resource template = new ClassPathResource(queryTemplate);
35
36
		controller.setProjectsFundingQueryTemplate(template);
37
		params = new ProjectQueryParams();
38
	}
39
40
	@Test
41
	public void testObtainFP7Query() throws IllegalArgumentException, IOException {
42
		params.setFundingProgramme("FP7");
43
		params.setFundingPath(null);
44
		String res = controller.obtainQuery(params);
45
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
46
		st.setAttribute("fundingprefix", "ec__________::EC::FP7");
47 46540 alessia.ba
		log.debug(res);
48
		log.debug(st);
49 46537 alessia.ba
		assertEquals(st.toString(), res);
50
	}
51
52
	@Test
53
	public void testObtainFP7QuerySP1() throws IllegalArgumentException, IOException {
54
		params.setFundingProgramme("FP7");
55
		params.setFundingPath("SP1");
56
		String res = controller.obtainQuery(params);
57
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
58
		st.setAttribute("fundingprefix", "ec__________::EC::FP7::SP1");
59 46540 alessia.ba
		log.debug(res);
60 46537 alessia.ba
		assertEquals(st.toString(), res);
61
	}
62
63
	@Test
64
	public void testObtainFP7QueryHealth() throws IllegalArgumentException, IOException {
65
		params.setFundingProgramme("FP7");
66
		params.setFundingPath("SP1::HEALTH");
67
		String res = controller.obtainQuery(params);
68
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
69
		st.setAttribute("fundingprefix", "ec__________::EC::FP7::SP1::HEALTH");
70 46540 alessia.ba
		log.debug(res);
71 46537 alessia.ba
		assertEquals(st.toString(), res);
72
	}
73
74
	@Test
75
	public void testObtainFP7QueryHealth2() throws IllegalArgumentException, IOException {
76
		params.setFundingProgramme("FP7");
77
		params.setFundingPath("%::HEALTH");
78
		String res = controller.obtainQuery(params);
79
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
80
		st.setAttribute("fundingprefix", "ec__________::EC::FP7::%::HEALTH");
81 46540 alessia.ba
		log.debug(res);
82 46537 alessia.ba
		assertEquals(st.toString(), res);
83
	}
84
85
	@Test
86
	public void testObtainWellcomeTrustQuery() throws IllegalArgumentException, IOException {
87
		params.setFundingProgramme("WT");
88
		params.setFundingPath(null);
89
		String res = controller.obtainQuery(params);
90
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
91
		st.setAttribute("fundingprefix", "wt__________::WT");
92 46540 alessia.ba
		log.debug(res);
93 46537 alessia.ba
		assertEquals(st.toString(), res);
94
	}
95
96
	@Test
97
	public void testObtainFCTQuery() throws IllegalArgumentException, IOException {
98
		params.setFundingProgramme("FCT");
99
		params.setFundingPath(null);
100
		String res = controller.obtainQuery(params);
101
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
102
		st.setAttribute("fundingprefix", "fct_________::FCT");
103 46540 alessia.ba
		log.debug(res);
104 46537 alessia.ba
		assertEquals(st.toString(), res);
105
	}
106
107
	@Test
108
	public void testQueryWithDateParams() throws IllegalArgumentException, IOException {
109
		params.setFundingProgramme("WT");
110
		params.setFundingPath(null);
111
		params.setStartFrom("2015-05-04");
112
		String res = controller.obtainQuery(params);
113 46540 alessia.ba
		log.debug(res);
114 46537 alessia.ba
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
115
		st.setAttribute("fundingprefix", "wt__________::WT");
116
		String q = st.toString() + " AND startdate >= '2015-05-04'";
117
		assertEquals(q, res);
118
	}
119
120
	@Test
121
	public void testObtainSNSFQuery() throws IllegalArgumentException, IOException {
122
		params.setFundingProgramme("SNSF");
123
		params.setFundingPath(null);
124
		String res = controller.obtainQuery(params);
125
		final StringTemplate st = new StringTemplate(IOUtils.toString(expectedQueryTemplate.getInputStream(),  ProjectsController.UTF8));
126
		st.setAttribute("fundingprefix", "snsf________::SNSF");
127 46540 alessia.ba
		log.debug(res);
128 46537 alessia.ba
		assertEquals(st.toString(), res);
129
	}
130
131
}