/******************************************************************************* * Copyright (c) 2011, 2015 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 v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Oracle - initial API and implementation ******************************************************************************/ package org.eclipse.persistence.testing.models.jpa.partitioned; import java.util.List; import org.eclipse.persistence.descriptors.partitioning.ReplicationPartitioningPolicy; import org.eclipse.persistence.internal.databaseaccess.Accessor; import org.eclipse.persistence.internal.sessions.AbstractRecord; import org.eclipse.persistence.internal.sessions.AbstractSession; import org.eclipse.persistence.queries.DatabaseQuery; /** * Used to test a custom policy. */ public class EmployeePartitioningPolicy extends ReplicationPartitioningPolicy { protected boolean replicate = true; public EmployeePartitioningPolicy() { addConnectionPool("default"); addConnectionPool("node2"); addConnectionPool("node3"); } /** * Allow replicate to be disabled on RAC. */ public List<Accessor> getConnectionsForQuery(AbstractSession session, DatabaseQuery query, AbstractRecord arguments) { if (!this.replicate) { return null; } return super.getConnectionsForQuery(session, query, arguments); } public boolean getReplicate() { return replicate; } public void setReplicate(boolean replicate) { this.replicate = replicate; } }