blob: 9700a4686a4c7ff12e742ae04fb7422d50f505f0 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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
<<<<<<< Updated upstream
*
* 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
=======
*
* https://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
>>>>>>> Stashed changes
* limitations under the License.
*/
package org.apache.jdo.tck.query.sql;
import java.text.MessageFormat;
import java.util.Arrays;
import javax.jdo.Query;
import org.apache.jdo.tck.pc.company.CompanyModelReader;
import org.apache.jdo.tck.pc.mylib.MylibReader;
import org.apache.jdo.tck.pc.mylib.PrimitiveTypes;
import org.apache.jdo.tck.query.QueryTest;
import org.apache.jdo.tck.query.result.classes.FullName;
import org.apache.jdo.tck.util.BatchTestRunner;
/**
* <B>Title:</B> Shape of Result. <br>
* <B>Keywords:</B> query <br>
* <B>Assertion ID:</B> A14.7-4. <br>
* <B>Assertion Description: </B> Table 7: Shape of Result of SQL Query
*/
public class ShapeOfResult extends QueryTest {
/** */
private static final String ASSERTION_FAILED = "Assertion A14.7-4 (ShapeOfResult) failed: ";
/**
* The <code>main</code> is called when the class is directly executed from the command line.
*
* @param args The arguments passed to the program.
*/
public static void main(String[] args) {
BatchTestRunner.run(ShapeOfResult.class);
}
/** The array of valid SQL queries. */
private static final String[] VALID_SQL_QUERIES = {
// candidate class
"SELECT * FROM {0}.PrimitiveTypes",
// candidate class, unique
"SELECT * FROM {0}.PrimitiveTypes where id = 1",
// single column
"SELECT firstname FROM {0}.persons",
// single column, unique
"SELECT firstname FROM {0}.persons WHERE personid = 1",
// mutiple columns
"SELECT firstname, lastname FROM {0}.persons",
// mutiple columns, unique
"SELECT firstname, lastname FROM {0}.persons WHERE personid = 1",
// result class
"SELECT firstname, lastname FROM {0}.persons",
// result class, unique
"SELECT firstname, lastname FROM {0}.persons WHERE personid = 1"
};
/** The expected results of valid SQL queries. */
private final Object[] expectedResult = {
// candidate class
getTransientMylibInstancesAsList(
"primitiveTypesPositive",
"primitiveTypesNegative",
"primitiveTypesCharacterStringLiterals"),
// candidate class, unique
getTransientMylibInstance("primitiveTypesPositive"),
// single column
Arrays.asList("emp1First", "emp2First", "emp3First", "emp4First", "emp5First"),
// single column, unique
"emp1First",
// mutiple columns
Arrays.asList(
new Object[] {
new Object[] {"emp1First", "emp1Last"},
new Object[] {"emp2First", "emp2Last"},
new Object[] {"emp3First", "emp3Last"},
new Object[] {"emp4First", "emp4Last"},
new Object[] {"emp5First", "emp5Last"}
}),
// mutiple columns, unique
new Object[] {"emp1First", "emp1Last"},
// result class
Arrays.asList(
new Object[] {
new FullName("emp1First", "emp1Last"),
new FullName("emp2First", "emp2Last"),
new FullName("emp3First", "emp3Last"),
new FullName("emp4First", "emp4Last"),
new FullName("emp5First", "emp5Last")
}),
// result class, unique
new FullName("emp1First", "emp1Last")
};
/** */
public void testCanidateClass() {
if (isSQLSupported()) {
int index = 0;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
PrimitiveTypes.class,
null,
true,
null,
expectedResult[index],
false);
index++;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
PrimitiveTypes.class,
null,
true,
null,
expectedResult[index],
true);
}
}
/** */
public void testSingleColumn() {
if (isSQLSupported()) {
int index = 2;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
null,
true,
null,
expectedResult[index],
false);
index++;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
null,
true,
null,
expectedResult[index],
true);
}
}
/** */
public void testMultipleColumn() {
if (isSQLSupported()) {
int index = 4;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
null,
true,
null,
expectedResult[index],
false);
index++;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
null,
true,
null,
expectedResult[index],
true);
}
}
/** */
public void testResultClass() {
if (isSQLSupported()) {
int index = 6;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
FullName.class,
true,
null,
expectedResult[index],
false);
index++;
executeSQLQuery(
ASSERTION_FAILED,
VALID_SQL_QUERIES[index],
null,
FullName.class,
true,
null,
expectedResult[index],
true);
}
}
/** */
@SuppressWarnings("unchecked")
public void testNegative() {
if (isSQLSupported()) {
String schema = getPMFProperty("javax.jdo.mapping.Schema");
String sql = MessageFormat.format("SELECT stringNull FROM {0}.PrimitiveTypes", schema);
Query<PrimitiveTypes> query = getPM().newQuery("javax.jdo.query.SQL", sql);
query.setClass(PrimitiveTypes.class);
compile(ASSERTION_FAILED, query, sql, false);
}
}
/**
* @see org.apache.jdo.tck.JDO_Test#localSetUp()
*/
@Override
protected void localSetUp() {
addTearDownClass(CompanyModelReader.getTearDownClasses());
addTearDownClass(MylibReader.getTearDownClasses());
loadAndPersistCompanyModel(getPM());
loadAndPersistMylib(getPM());
}
}