⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dynamicfiltertest.java

📁 hibernate 开源框架的代码 jar包希望大家能喜欢
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
// $Id: DynamicFilterTest.java 11398 2007-04-10 14:54:07Z steve.ebersole@jboss.com $package org.hibernate.test.filter;import java.util.ArrayList;import java.util.Calendar;import java.util.Date;import java.util.GregorianCalendar;import java.util.Iterator;import java.util.List;import java.util.Set;import junit.framework.Test;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.hibernate.EntityMode;import org.hibernate.FetchMode;import org.hibernate.Hibernate;import org.hibernate.Session;import org.hibernate.Transaction;import org.hibernate.cache.CacheKey;import org.hibernate.cache.entry.CollectionCacheEntry;import org.hibernate.cfg.Configuration;import org.hibernate.cfg.Environment;import org.hibernate.criterion.Restrictions;import org.hibernate.engine.SessionImplementor;import org.hibernate.impl.SessionFactoryImpl;import org.hibernate.junit.functional.FunctionalTestCase;import org.hibernate.junit.functional.FunctionalTestClassTestSuite;import org.hibernate.persister.collection.CollectionPersister;import org.hibernate.transform.DistinctRootEntityResultTransformer;/** * Implementation of DynamicFilterTest. * * @author Steve */public class DynamicFilterTest extends FunctionalTestCase {	private Logger log = LoggerFactory.getLogger( DynamicFilterTest.class );	public DynamicFilterTest(String testName) {		super( testName );	}	public String[] getMappings() {		return new String[]{			"filter/defs.hbm.xml",			"filter/LineItem.hbm.xml",			"filter/Order.hbm.xml",			"filter/Product.hbm.xml",			"filter/Salesperson.hbm.xml",			"filter/Department.hbm.xml",			"filter/Category.hbm.xml"		};	}	public void configure(Configuration cfg) {		cfg.setProperty( Environment.MAX_FETCH_DEPTH, "1" );		cfg.setProperty( Environment.GENERATE_STATISTICS, "true" );		cfg.setProperty( Environment.USE_QUERY_CACHE, "true" );	}	public static Test suite() {		return new FunctionalTestClassTestSuite( DynamicFilterTest.class );	}	public void testSqlSyntaxOfFiltersWithUnions() {		Session session = openSession();		session.enableFilter( "unioned" );		session.createQuery( "from Category" ).list();		session.close();	}	public void testSecondLevelCachedCollectionsFiltering() {		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		long ts = ( ( SessionImplementor ) session ).getTimestamp();		// Force a collection into the second level cache, with its non-filtered elements		Salesperson sp = ( Salesperson ) session.load( Salesperson.class, testData.steveId );		Hibernate.initialize( sp.getOrders() );		CollectionPersister persister = ( ( SessionFactoryImpl ) getSessions() )		        .getCollectionPersister( Salesperson.class.getName() + ".orders" );		assertTrue( "No cache for collection", persister.hasCache() );		CollectionCacheEntry cachedData = ( CollectionCacheEntry ) persister.getCacheAccessStrategy()		        .get( new CacheKey( testData.steveId, persister.getKeyType(), persister.getRole(), EntityMode.POJO, sfi() ), ts );		assertNotNull( "collection was not in cache", cachedData );		session.close();		session = openSession();		ts = ( ( SessionImplementor ) session ).getTimestamp();		session.enableFilter( "fulfilledOrders" ).setParameter( "asOfDate", testData.lastMonth.getTime() );		sp = ( Salesperson ) session.createQuery( "from Salesperson as s where s.id = :id" )		        .setLong( "id", testData.steveId.longValue() )		        .uniqueResult();		assertEquals( "Filtered-collection not bypassing 2L-cache", 1, sp.getOrders().size() );		CollectionCacheEntry cachedData2 = ( CollectionCacheEntry ) persister.getCacheAccessStrategy()		        .get( new CacheKey( testData.steveId, persister.getKeyType(), persister.getRole(), EntityMode.POJO, sfi() ), ts );		assertNotNull( "collection no longer in cache!", cachedData2 );		assertSame( "Different cache values!", cachedData, cachedData2 );		session.close();		session = openSession();		session.enableFilter( "fulfilledOrders" ).setParameter( "asOfDate", testData.lastMonth.getTime() );		sp = ( Salesperson ) session.load( Salesperson.class, testData.steveId );		assertEquals( "Filtered-collection not bypassing 2L-cache", 1, sp.getOrders().size() );		session.close();		// Finally, make sure that the original cached version did not get over-written		session = openSession();		sp = ( Salesperson ) session.load( Salesperson.class, testData.steveId );		assertEquals( "Actual cached version got over-written", 2, sp.getOrders().size() );		session.close();		testData.release();	}	public void testCombinedClassAndCollectionFiltersEnabled() {		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "regionlist" ).setParameterList( "regions", new String[]{"LA", "APAC"} );		session.enableFilter( "fulfilledOrders" ).setParameter( "asOfDate", testData.lastMonth.getTime() );		// test retreival through hql with the collection as non-eager		List salespersons = session.createQuery( "select s from Salesperson as s" ).list();		assertEquals( "Incorrect salesperson count", 1, salespersons.size() );		Salesperson sp = ( Salesperson ) salespersons.get( 0 );		assertEquals( "Incorrect order count", 1, sp.getOrders().size() );		session.clear();		// test retreival through hql with the collection join fetched		salespersons = session.createQuery( "select s from Salesperson as s left join fetch s.orders" ).list();		assertEquals( "Incorrect salesperson count", 1, salespersons.size() );		sp = ( Salesperson ) salespersons.get( 0 );		assertEquals( "Incorrect order count", 1, sp.getOrders().size() );		session.close();		testData.release();	}	public void testHqlFilters() {		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		// HQL test		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		log.info( "Starting HQL filter tests" );		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "region" ).setParameter( "region", "APAC" );		session.enableFilter( "effectiveDate" )		        .setParameter( "asOfDate", testData.lastMonth.getTime() );		log.info( "HQL against Salesperson..." );		List results = session.createQuery( "select s from Salesperson as s left join fetch s.orders" ).list();		assertTrue( "Incorrect filtered HQL result count [" + results.size() + "]", results.size() == 1 );		Salesperson result = ( Salesperson ) results.get( 0 );		assertTrue( "Incorrect collectionfilter count", result.getOrders().size() == 1 );		log.info( "HQL against Product..." );		results = session.createQuery( "from Product as p where p.stockNumber = ?" ).setInteger( 0, 124 ).list();		assertTrue( results.size() == 1 );		session.close();		testData.release();	}	public void testCriteriaQueryFilters() {		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		// Criteria-query test		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		log.info( "Starting Criteria-query filter tests" );		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "region" ).setParameter( "region", "APAC" );		session.enableFilter( "fulfilledOrders" )		        .setParameter( "asOfDate", testData.lastMonth.getTime() );		session.enableFilter( "effectiveDate" )		        .setParameter( "asOfDate", testData.lastMonth.getTime() );		log.info( "Criteria query against Salesperson..." );		List salespersons = session.createCriteria( Salesperson.class )		        .setFetchMode( "orders", FetchMode.JOIN )		        .list();		assertEquals( "Incorrect salesperson count", 1, salespersons.size() );		assertEquals( "Incorrect order count", 1, ( ( Salesperson ) salespersons.get( 0 ) ).getOrders().size() );		log.info( "Criteria query against Product..." );		List products = session.createCriteria( Product.class )		        .add( Restrictions.eq( "stockNumber", new Integer( 124 ) ) )		        .list();		assertEquals( "Incorrect product count", 1, products.size() );		session.close();		testData.release();	}	public void testGetFilters() {		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		// Get() test		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		log.info( "Starting get() filter tests (eager assoc. fetching)." );		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "region" ).setParameter( "region", "APAC" );		log.info( "Performing get()..." );		Salesperson salesperson = ( Salesperson ) session.get( Salesperson.class, testData.steveId );		assertNotNull( salesperson );		assertEquals( "Incorrect order count", 1, salesperson.getOrders().size() );		session.close();		testData.release();	}	public void testOneToManyFilters() {		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		// one-to-many loading tests		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		log.info( "Starting one-to-many collection loader filter tests." );		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "seniorSalespersons" )		        .setParameter( "asOfDate", testData.lastMonth.getTime() );		log.info( "Performing load of Department..." );		Department department = ( Department ) session.load( Department.class, testData.deptId );		Set salespersons = department.getSalespersons();		assertEquals( "Incorrect salesperson count", 1, salespersons.size() );		session.close();		testData.release();	}	public void testInStyleFilterParameter() {		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		// one-to-many loading tests		//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~		log.info( "Starting one-to-many collection loader filter tests." );		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "regionlist" )		        .setParameterList( "regions", new String[]{"LA", "APAC"} );		log.debug( "Performing query of Salespersons" );		List salespersons = session.createQuery( "from Salesperson" ).list();		assertEquals( "Incorrect salesperson count", 1, salespersons.size() );		session.close();		testData.release();	}	public void testManyToManyFilterOnCriteria() {		TestData testData = new TestData();		testData.prepare();		Session session = openSession();		session.enableFilter( "effectiveDate" ).setParameter( "asOfDate", new Date() );		Product prod = ( Product ) session.createCriteria( Product.class )		        .setResultTransformer( new DistinctRootEntityResultTransformer() )		        .add( Restrictions.eq( "id", testData.prod1Id ) )		        .uniqueResult();		assertNotNull( prod );		assertEquals( "Incorrect Product.categories count for filter", 1, prod.getCategories().size() );		session.close();		testData.release();	}	public void testManyToManyFilterOnLoad() {		TestData testData = new TestData();		testData.prepare();

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -