blob: 773d17c8e7f87367efcd7e5694f1725e11c5f6be [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
*
* 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.
*/
package org.apache.openjpa.persistence.jdbc.maps.m2mmapex4;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.persistence.EntityManager;
import javax.persistence.EntityTransaction;
import javax.persistence.Query;
import org.apache.openjpa.kernel.QueryImpl;
import org.apache.openjpa.persistence.test.AllowFailure;
import org.apache.openjpa.persistence.test.SQLListenerTestCase;
import junit.framework.Assert;
public class TestMany2ManyMapEx4 extends SQLListenerTestCase {
public int numEmployees = 2;
public int numPhoneNumbers = numEmployees + 1;
public int numEmployeesPerPhoneNumber = 2;
public int numPhoneNumbersPerEmployee = 2;
public Map<Integer, PhoneNumber> phones =
new HashMap<>();
public List<String> namedQueries = new ArrayList<>();
public Map<Integer, Employee> empMap = new HashMap<>();
public Map<Integer, PhoneNumber> phoneMap =
new HashMap<>();
public int empId = 1;
public int phoneId = 1;
public int divId = 1;
public int deptId = 1;
public int officeId = 1;
public int numOfficesPerDivision = 2;
public List rsAllPhones = null;
public List rsAllEmps = null;
@Override
public void setUp() {
super.setUp(CLEAR_TABLES,
Division.class,
Employee.class,
PhoneNumber.class,
Office.class,
Address.class
);
createObj();
rsAllPhones = getAll(PhoneNumber.class);
rsAllEmps = getAll(Employee.class);
}
@AllowFailure
public void testQueryInMemoryQualifiedId() throws Exception {
queryQualifiedId(true);
}
public void testQueryQualifiedId() throws Exception {
queryQualifiedId(false);
}
public void setCandidate(Query q, Class clz)
throws Exception {
org.apache.openjpa.persistence.QueryImpl q1 =
(org.apache.openjpa.persistence.QueryImpl) q;
org.apache.openjpa.kernel.Query q2 = q1.getDelegate();
org.apache.openjpa.kernel.QueryImpl qi = (QueryImpl) q2;
if (clz == PhoneNumber.class)
qi.setCandidateCollection(rsAllPhones);
else if (clz == Employee.class)
qi.setCandidateCollection(rsAllEmps);
}
public void queryQualifiedId(boolean inMemory) throws Exception {
EntityManager em = emf.createEntityManager();
// a collection valued path thru KEY in FROM clause
String query = "select o.address.city from PhoneNumber p, " +
" in (p.emps) e, in(KEY(e).offices) o order by o.address.city";
Query q = em.createQuery(query);
if (inMemory)
setCandidate(q, PhoneNumber.class);
List rs = q.getResultList();
// a path thru KEY nagivation apprear in ORDER BY
query = "select o.address.city as city from PhoneNumber p, " +
" in (p.emps) e, in(KEY(e).offices) o order by city";
q = em.createQuery(query);
if (inMemory)
setCandidate(q, PhoneNumber.class);
rs = q.getResultList();
// a path thru KEY nagivation apprear in WHERE clause
query = "select o.address.city as city from PhoneNumber p, " +
" in (p.emps) e, in(KEY(e).offices) o " +
" where o.address.city like '%1' order by p.number, e.empId";
q = em.createQuery(query);
if (inMemory)
setCandidate(q, PhoneNumber.class);
rs = q.getResultList();
query = "select KEY(e) from PhoneNumber p, " +
" in (p.emps) e order by p.number, e.empId";
q = em.createQuery(query);
if (inMemory)
setCandidate(q, PhoneNumber.class);
rs = q.getResultList();
Division d = (Division) rs.get(0);
query = "select KEY(p) from Employee e, " +
" in (e.phones) p order by p.number, e.empId";
q = em.createQuery(query);
if (inMemory)
setCandidate(q, Employee.class);
rs = q.getResultList();
String k = (String) rs.get(0);
em.clear();
query = "select ENTRY(e) from PhoneNumber p, " +
" in (p.emps) e order by p.number, e.empId";
q = em.createQuery(query);
if (inMemory)
setCandidate(q, PhoneNumber.class);
rs = q.getResultList();
Map.Entry me = (Map.Entry) rs.get(0);
assertEquals(d, me.getKey());
em.close();
}
public void testQueryObject() throws Exception {
queryObj();
findObj();
}
protected List<String> sql = new ArrayList<>();
protected int sqlCount;
public List<String> getSql() {
return sql;
}
public int getSqlCount() {
return sqlCount;
}
public void createObj() {
EntityManager em = emf.createEntityManager();
EntityTransaction tran = em.getTransaction();
for (int i = 0; i < numEmployees; i++) {
Employee e = createEmployee(em, empId++);
empMap.put(e.getEmpId(), e);
}
tran.begin();
em.flush();
tran.commit();
em.close();
}
public Employee createEmployee(EntityManager em, int id) {
Employee e = new Employee();
e.setEmpId(id);
for (int i = 0; i < numPhoneNumbersPerEmployee; i++) {
PhoneNumber phoneNumber = new PhoneNumber();
phoneNumber.setNumber(phoneId++);
Division div = createDivision(em, divId++);
phoneNumber.addEmployees(div, e);
e.addPhoneNumber("String" + phoneNumber.getNumber(), phoneNumber);
phoneMap.put(phoneNumber.getNumber(), phoneNumber);
em.persist(phoneNumber);
em.persist(div);
}
em.persist(e);
return e;
}
public Division createDivision(EntityManager em, int id) {
Division d = new Division();
d.setId(id);
d.setName("d" + id);
for (int i = 0; i < numOfficesPerDivision; i++) {
Office office = new Office(officeId++);
Address address = new Address("street"+i,
"city"+i,
"state"+i,
"zip"+i);
office.setAddress(address);
em.persist(office);
d.addOffice(office);
}
return d;
}
public void findObj() throws Exception {
EntityManager em = emf.createEntityManager();
Employee e = em.find(Employee.class, 1);
assertEmployee(e);
PhoneNumber p = em.find(PhoneNumber.class, 1);
assertPhoneNumber(p);
em.close();
}
public void queryObj() throws Exception {
queryEmployee();
queryPhoneNumber();
}
public void queryPhoneNumber() throws Exception {
EntityManager em = emf.createEntityManager();
EntityTransaction tran = em.getTransaction();
tran.begin();
Query q = em.createQuery("select p from PhoneNumber p");
List<PhoneNumber> ps = q.getResultList();
for (PhoneNumber p : ps) {
assertPhoneNumber(p);
}
tran.commit();
em.close();
}
public void queryEmployee() throws Exception {
EntityManager em = emf.createEntityManager();
EntityTransaction tran = em.getTransaction();
tran.begin();
Query q = em.createQuery("select e from Employee e");
List<Employee> es = q.getResultList();
for (Employee e : es) {
assertEmployee(e);
}
tran.commit();
em.close();
}
public void assertEmployee(Employee e) throws Exception {
int id = e.getEmpId();
Employee e0 = empMap.get(id);
Map<String, PhoneNumber> phones = e.getPhoneNumbers();
Map<String, PhoneNumber> phones0 = e0.getPhoneNumbers();
Assert.assertEquals(phones0.size(), phones.size());
checkPhoneMap(phones0, phones);
}
public void assertPhoneNumber(PhoneNumber p) throws Exception {
int number = p.getNumber();
PhoneNumber p0 = phoneMap.get(number);
Map<Division, Employee> es = p.getEmployees();
Map<Division, Employee> es0 = p0.getEmployees();
Assert.assertEquals(es0.size(), es.size());
checkEmpMap(es0, es);
}
public void checkPhoneMap(Map<String, PhoneNumber> es0,
Map<String, PhoneNumber> es) throws Exception {
Collection<Map.Entry<String, PhoneNumber>> entrySets0 = es0.entrySet();
for (Map.Entry<String, PhoneNumber> entry0 : entrySets0) {
String key0 = entry0.getKey();
PhoneNumber p0 = entry0.getValue();
PhoneNumber p = es.get(key0);
if (!p0.equals(p))
throw new Exception("Assertion Failure");
}
}
public void checkEmpMap(Map<Division, Employee> es0,
Map<Division, Employee> es) throws Exception {
Collection<Map.Entry<Division, Employee>> entrySets0 = es0.entrySet();
for (Map.Entry<Division, Employee> entry0 : entrySets0) {
Division key0 = entry0.getKey();
Employee e0 = entry0.getValue();
Employee e = es.get(key0);
if (!e0.equals(e))
throw new Exception("Assertion failure");
}
}
}