/*
* Copyright 2013 ENERKO Informatik GmbH
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package de.enerko.reports2.engine;
import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.notNullValue;
import static org.hamcrest.CoreMatchers.nullValue;
import static org.junit.Assert.assertThat;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.junit.Test;
import de.enerko.reports2.AbstractDatabaseTest;
import de.enerko.reports2.engine.ReportSource.MissingReportColumn;
/**
* @author Michael J. Simons, 2013-06-18
*/
public class StatementBasedReportSourceTest extends AbstractDatabaseTest {
@Test(expected=MissingReportColumn.class)
public void shouldHandleMissingColumns() throws SQLException {
final StatementBasedReportSource reportSource = new StatementBasedReportSource(connection, "Select 1 as test from dual");
for(CellDefinition cellDefinition : reportSource)
System.out.println(cellDefinition);
}
@Test(expected=SQLException.class)
public void shouldHandleSQLErrors() throws SQLException {
final StatementBasedReportSource reportSource = new StatementBasedReportSource(connection, "Select 1");
for(CellDefinition cellDefinition : reportSource)
System.out.println(cellDefinition);
}
@Test
public void shouldHandleValidSelect() throws SQLException {
final StatementBasedReportSource reportSource =
new StatementBasedReportSource(connection,
"Select 's1' as sheetname, 1 as cell_column, 1 as cell_row, 'c1' as cell_name, 'ct' as cell_type, 'cv' as cell_value from dual");
final List<CellDefinition> cellDefinitions = new ArrayList<CellDefinition>();
for(CellDefinition cellDefinition : reportSource)
cellDefinitions.add(cellDefinition);
assertThat(cellDefinitions.size(), is(1));
}
@Test
public void shouldHandleValidSelectWithComment() throws SQLException {
final StatementBasedReportSource reportSource =
new StatementBasedReportSource(connection,
"Select 's1' as sheetname, 1 as cell_column, 1 as cell_row, 'c1' as cell_name, 'ct' as cell_type, 'cv' as cell_value, t_er_comment_definition('test') as cell_comment from dual");
final List<CellDefinition> cellDefinitions = new ArrayList<CellDefinition>();
for(CellDefinition cellDefinition : reportSource)
cellDefinitions.add(cellDefinition);
assertThat(cellDefinitions.size(), is(1));
final CommentDefinition commentDefinition = cellDefinitions.get(0).comment;
assertThat(commentDefinition, notNullValue());
assertThat(commentDefinition.author, is("HRE"));
assertThat(commentDefinition.column, nullValue());
assertThat(commentDefinition.row, nullValue());
assertThat(commentDefinition.width, is(1));
assertThat(commentDefinition.height, is(1));
assertThat(commentDefinition.visible, is(false));
}
@Test
public void shouldCreateValidCommentDefinition() throws SQLException {
final StatementBasedReportSource reportSource =
new StatementBasedReportSource(connection,
"Select 's1' as sheetname, 1 as cell_column, 1 as cell_row, 'c1' as cell_name, 'ct' as cell_type, 'cv' as cell_value, " +
" t_er_comment_definition('test', p_column => 23, p_row => 42, p_width => 3, p_height => 4, p_visible => 'true') as cell_comment " +
"from dual");
final List<CellDefinition> cellDefinitions = new ArrayList<CellDefinition>();
for(CellDefinition cellDefinition : reportSource)
cellDefinitions.add(cellDefinition);
assertThat(cellDefinitions.size(), is(1));
final CommentDefinition commentDefinition = cellDefinitions.get(0).comment;
assertThat(commentDefinition, notNullValue());
assertThat(commentDefinition.author, is("HRE"));
assertThat(commentDefinition.column, is(23));
assertThat(commentDefinition.row, is(42));
assertThat(commentDefinition.width, is(3));
assertThat(commentDefinition.height, is(4));
assertThat(commentDefinition.visible, is(true));
}
}