/* * ModeShape (http://www.modeshape.org) * * Licensed 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.modeshape.jcr.cache.document; import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import org.modeshape.jcr.ExecutionContext; import org.modeshape.jcr.RepositoryEnvironment; import org.modeshape.jcr.bus.RepositoryChangeBus; import org.modeshape.jcr.cache.CachedNode; import org.modeshape.jcr.cache.NodeCache; import org.modeshape.jcr.cache.NodeKey; import org.modeshape.jcr.cache.SessionCache; import org.modeshape.jcr.cache.change.PrintingChangeSetListener; /** * Abstract base class for tests that operate against a SessionCache. Note that all methods must be able to operate against all * SessionCache implementations (e.g., {@link ReadOnlySessionCache} and {@link WritableSessionCache}). */ public abstract class AbstractSessionCacheTest extends AbstractNodeCacheTest { private ExecutorService executor; private RepositoryChangeBus changeBus; private PrintingChangeSetListener listener; protected WorkspaceCache workspaceCache; protected SessionCache session1; protected SessionCache session2; @Override protected NodeCache createCache() { executor = Executors.newCachedThreadPool(); changeBus = new RepositoryChangeBus("repo", executor); listener = new PrintingChangeSetListener(); changeBus.register(listener); ConcurrentMap<NodeKey, CachedNode> nodeCache = new ConcurrentHashMap<>(); DocumentStore documentStore = new LocalDocumentStore(schematicDb, repoEnv); DocumentTranslator translator = new DocumentTranslator(context, documentStore, 100L); workspaceCache = new WorkspaceCache(context, "repo", "ws", null, documentStore, translator, ROOT_KEY_WS1, nodeCache, changeBus, null); loadJsonDocuments(resource(resourceNameForWorkspaceContentDocument())); TransactionalWorkspaceCaches txWsCaches = new TransactionalWorkspaceCaches(repoEnv.getTransactions()); session1 = createSessionCache(context, workspaceCache, txWsCaches, repoEnv); session2 = createSessionCache(context, workspaceCache, txWsCaches, repoEnv); return session1; } @Override protected void shutdownCache( NodeCache cache ) { super.shutdownCache(cache); try { changeBus.shutdown(); } finally { executor.shutdownNow(); } } protected abstract SessionCache createSessionCache( ExecutionContext context, WorkspaceCache cache, TransactionalWorkspaceCaches txWsCaches, RepositoryEnvironment sessionEnv ); protected SessionCache session() { return (SessionCache)cache; } /** * @see org.modeshape.jcr.cache.document.AbstractNodeCacheTest#print(boolean) */ @Override protected void print( boolean onOrOff ) { super.print(onOrOff); listener.print = onOrOff; } protected NodeKey newKey() { return session1.createNodeKey(); } protected NodeKey newKey( String identifier ) { return session1.createNodeKeyWithIdentifier(identifier); } }