blob: bf2f66bee38727c53864d6f56f21235b5996ed78 [file] [log] [blame]
/*
* Copyright (c) 1998, 2021 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0,
* or the Eclipse Distribution License v. 1.0 which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause
*/
// Contributors:
// Oracle - initial API and implementation from Oracle TopLink
package org.eclipse.persistence.testing.tests.jpa.advanced;
import java.util.List;
import jakarta.persistence.EntityManager;
import junit.framework.Test;
import junit.framework.TestSuite;
import org.eclipse.persistence.testing.framework.junit.JUnitTestCase;
import org.eclipse.persistence.testing.models.jpa.advanced.Address;
import org.eclipse.persistence.testing.models.jpa.advanced.AdvancedTableCreator;
import org.junit.Assert;
public class NamedNativeQueryJUnitTest extends JUnitTestCase {
protected String PUName;
public NamedNativeQueryJUnitTest() {
super();
if (isOnServer()) {
PUName = "MulitPU-1";
} else {
PUName = "default";
}
}
public NamedNativeQueryJUnitTest(String name) {
super(name);
if (isOnServer()) {
PUName = "MulitPU-1";
} else {
PUName = "default";
}
}
public static Test suite() {
TestSuite suite = new TestSuite();
suite.addTest(new NamedNativeQueryJUnitTest("testSetup"));
return addNamedNativeQueryTests(suite);
}
/**
* Adds test, similar to suite() but without adding a setup. used from JUnitNativeQueryTestSuite
*/
public static Test addNamedNativeQueryTests(TestSuite suite){
suite.setName("NamedNativeQueryJUnitTest");
suite.addTest(new NamedNativeQueryJUnitTest("testNamedNativeQuery"));
suite.addTest(new NamedNativeQueryJUnitTest("selectNamedNativeQueryWithPositionalParameterTest"));
suite.addTest(new NamedNativeQueryJUnitTest("selectNativeQueryWithPositionalParameterTest"));
return suite;
}
/**
* The setup is done as a test, both to record its failure, and to allow execution in the server.
*/
public void testSetup() {
new AdvancedTableCreator().replaceTables(getServerSession(PUName));
clearCache(PUName);
}
public void testNamedNativeQuery() {
EntityManager em = createEntityManager(PUName);
try {
em.createNamedQuery("findAllSQLAddresses").getResultList();
//if there is an exception, let it go through so we can see what it was
} finally {
if (isTransactionActive(em)) {
closeEntityManager(em);
}
}
}
public void selectNamedNativeQueryWithPositionalParameterTest() {
EntityManager em = createEntityManager(PUName);
List results_QuestionMark_Number = null;
List results_QuestionMark = null;
jakarta.persistence.Query query;
String errorMsg = "";
boolean shouldCompareResults = true;
try {
query = em.createNamedQuery("findAllSQLAddressesByCity_QuestionMark_Number");
query.setParameter(1, "Ottawa");
results_QuestionMark_Number = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCity_QuestionMark_Number: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
try {
query = em.createNamedQuery("findAllSQLAddressesByCity_QuestionMark");
query.setParameter(1, "Ottawa");
results_QuestionMark = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCity_QuestionMark: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
if (shouldCompareResults) {
if (results_QuestionMark_Number.size() != results_QuestionMark.size()) {
errorMsg = errorMsg + ("findAllSQLAddressesByCity_QuestionMark_Number and findAllSQLAddressesByCity_QuestionMark produced non-equal results");
}
}
shouldCompareResults = true;
try {
query = em.createNamedQuery("findAllSQLAddressesByCityAndCountry_QuestionMark_Number");
query.setParameter(1, "Ottawa");
query.setParameter(2, "Canada");
results_QuestionMark_Number = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCityAndCountry_QuestionMark_Number: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
try {
query = em.createNamedQuery("findAllSQLAddressesByCityAndCountry_QuestionMark");
query.setParameter(1, "Ottawa");
query.setParameter(2, "Canada");
results_QuestionMark = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCityAndCountry_QuestionMark: " + e.getMessage();
shouldCompareResults = false;
}
if (shouldCompareResults) {
if (results_QuestionMark_Number.size() != results_QuestionMark.size()) {
errorMsg = errorMsg + ("findAllSQLAddressesByCityAndCountry_QuestionMark_Number and findAllSQLAddressesByCityAndCountry_QuestionMark produced non-equal results");
}
}
if (errorMsg.length() > 0) {
Assert.fail(errorMsg);
}
closeEntityManager(em);
}
public void selectNativeQueryWithPositionalParameterTest() {
EntityManager em = createEntityManager(PUName);
List results_QuestionMark_Number = null;
List results_QuestionMark = null;
jakarta.persistence.Query query;
String errorMsg = "";
boolean shouldCompareResults = true;
try {
query = em.createNativeQuery("select * from CMP3_ADDRESS where CITY=?1", Address.class);
query.setParameter(1, "Ottawa");
results_QuestionMark_Number = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCity_QuestionMark_Number: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
try {
query = em.createNativeQuery("select * from CMP3_ADDRESS where CITY=?", Address.class);
query.setParameter(1, "Ottawa");
results_QuestionMark = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCity_QuestionMark: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
if (shouldCompareResults) {
if (results_QuestionMark_Number.size() != results_QuestionMark.size()) {
errorMsg = errorMsg + ("findAllSQLAddressesByCity_QuestionMark_Number and findAllSQLAddressesByCity_QuestionMark produced non-equal results");
}
}
shouldCompareResults = true;
try {
query = em.createNativeQuery("select * from CMP3_ADDRESS where CITY=?1 and COUNTRY=?2", Address.class);
query.setParameter(1, "Ottawa");
query.setParameter(2, "Canada");
results_QuestionMark_Number = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCityAndCountry_QuestionMark_Number: " + e.getMessage() + "\n";
shouldCompareResults = false;
}
try {
query = em.createNativeQuery("select * from CMP3_ADDRESS where CITY=? and COUNTRY=?", Address.class);
query.setParameter(1, "Ottawa");
query.setParameter(2, "Canada");
results_QuestionMark = query.getResultList();
} catch (Exception e) {
errorMsg = errorMsg + "findAllSQLAddressesByCityAndCountry_QuestionMark: " + e.getMessage();
shouldCompareResults = false;
}
if (shouldCompareResults) {
if (results_QuestionMark_Number.size() != results_QuestionMark.size()) {
errorMsg = errorMsg + ("findAllSQLAddressesByCityAndCountry_QuestionMark_Number and findAllSQLAddressesByCityAndCountry_QuestionMark produced non-equal results");
}
}
if (errorMsg.length() > 0) {
Assert.fail(errorMsg);
}
closeEntityManager(em);
}
}