tests: SelfHoster: Test SqlUtils too.
[online-glom:gwt-glom.git] / src / test / java / org / glom / web / server / SelfHostExampleTest.java
1 /*
2  * Copyright (C) 2012 Openismus GmbH
3  *
4  * This file is part of GWT-Glom.
5  *
6  * GWT-Glom is free software: you can redistribute it and/or modify it
7  * under the terms of the GNU Lesser General Public License as published by the
8  * Free Software Foundation, either version 3 of the License, or (at your
9  * option) any later version.
10  *
11  * GWT-Glom is distributed in the hope that it will be useful, but WITHOUT
12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
14  * for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public License
17  * along with GWT-Glom.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 package org.glom.web.server;
21
22 import static org.junit.Assert.assertTrue;
23
24 import java.net.URL;
25 import java.sql.Connection;
26 import java.sql.ResultSet;
27 import java.sql.ResultSetMetaData;
28 import java.sql.SQLException;
29 import java.sql.Statement;
30 import java.util.ArrayList;
31 import java.util.List;
32
33 import org.glom.web.server.libglom.Document;
34 import org.glom.web.server.libglom.Document.HostingMode;
35 import org.glom.web.shared.TypedDataItem;
36 import org.glom.web.shared.libglom.Field;
37 import org.glom.web.shared.libglom.layout.LayoutItemField;
38 import org.jooq.Condition;
39 import org.junit.Assert;
40 import org.junit.Test;
41
42 /**
43  * @author Murray Cumming <murrayc@openismus.com>
44  * 
45  */
46 public class SelfHostExampleTest {
47
48         private SelfHoster selfHoster = null;
49
50         @Test
51         public void test() throws SQLException {
52                 final URL url = SelfHostExampleTest.class.getResource("example_music_collection.glom");
53                 assertTrue(url != null);
54                 final String strUri = url.toString();
55
56                 final Document document = new Document();
57                 document.setFileURI(strUri);
58                 assertTrue(document.load());
59
60                 selfHoster = new SelfHoster(document);
61                 final boolean hosted = selfHoster.createAndSelfHostFromExample(HostingMode.HOSTING_MODE_POSTGRES_SELF);
62                 assertTrue(hosted);
63                 
64                 testExampleMusiccollectionData(document);
65         }
66         
67         private void testExampleMusiccollectionData(final Document document) throws SQLException
68         {
69           assertTrue(document != null);
70           
71           //Check that some data is as expected:
72           final TypedDataItem quickFindValue = new TypedDataItem();
73           quickFindValue.setText("Born To Run");
74           final Condition whereClause = SqlUtils.getFindWhereClauseQuick(document, "albums", quickFindValue);
75           assertTrue(whereClause != null);
76
77           final List<LayoutItemField> fieldsToGet = new ArrayList<LayoutItemField>();
78           Field field = document.getField("albums", "album_id");
79           LayoutItemField layoutItemField = new LayoutItemField();
80           layoutItemField.setFullFieldDetails(field);
81           fieldsToGet.add(layoutItemField);
82           field = document.getField("albums", "name");
83           layoutItemField = new LayoutItemField();
84           layoutItemField.setFullFieldDetails(field);
85           fieldsToGet.add(layoutItemField);
86           
87           final String sqlQuery = SqlUtils.buildSqlSelectWithWhereClause("albums", fieldsToGet, whereClause, null);
88           
89           final Connection conn = selfHoster.createConnection(false);
90           assertTrue(conn != null);
91           
92           final Statement st = conn.createStatement(ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
93       //st.setFetchSize(length);
94           final ResultSet rs = st.executeQuery(sqlQuery);
95           assertTrue(rs != null);
96           
97           final ResultSetMetaData rsMetaData = rs.getMetaData();
98           Assert.assertEquals(2, rsMetaData.getColumnCount());
99           
100           rs.last();
101           final int rsRowsCount = rs.getRow();
102           Assert.assertEquals(1, rsRowsCount);
103         }
104
105         public void tearDown() {
106                 if (selfHoster != null) {
107                         selfHoster.cleanup();
108                 }
109         }
110 }