Project

General

Profile

1
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
import org.apache.commons.logging.Log;
8
import org.apache.commons.logging.LogFactory;
9
import org.junit.Before;
10
import org.junit.Test;
11
import org.junit.runner.RunWith;
12
import org.springframework.boot.test.context.SpringBootTest;
13
import org.springframework.core.io.ClassPathResource;
14
import org.springframework.core.io.Resource;
15
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
16

    
17
import static org.junit.Assert.assertEquals;
18
@RunWith(SpringJUnit4ClassRunner.class)
19
//@ContextConfiguration(classes={TestConfiguration.class})
20
@SpringBootTest
21
public class ProjectsControllerTest {
22

    
23
	private static final Log log = LogFactory.getLog(ProjectsControllerTest.class);
24
	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
		log.debug(res);
48
		log.debug(st);
49
		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
		log.debug(res);
60
		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
		log.debug(res);
71
		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
		log.debug(res);
82
		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
		log.debug(res);
93
		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
		log.debug(res);
104
		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
		log.debug(res);
114
		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
		log.debug(res);
128
		assertEquals(st.toString(), res);
129
	}
130

    
131
}
(2-2/2)