mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
Merged HEAD-BUG-FIX (4.3/Cloud) to HEAD (4.3/Cloud)
69952: Merged V4.2-BUG-FIX (4.2.3) to HEAD-BUG-FIX (4.3/Cloud) 69917: Merged V4.1-BUG-FIX (4.1.9) to V4.2-BUG-FIX (4.2.3) 69831: MNT-11192: TestModel.java removed from alfresco-repository-xxx.jar - moved TestModel.java back from **/test-java/** to **/java/** git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@70468 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
144
source/java/org/alfresco/repo/dictionary/TestModel.java
Normal file
144
source/java/org/alfresco/repo/dictionary/TestModel.java
Normal file
@@ -0,0 +1,144 @@
|
||||
/*
|
||||
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
||||
*
|
||||
* This file is part of Alfresco
|
||||
*
|
||||
* Alfresco is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* Alfresco is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
package org.alfresco.repo.dictionary;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import net.sf.ehcache.Cache;
|
||||
import net.sf.ehcache.CacheManager;
|
||||
|
||||
import org.alfresco.repo.cache.EhCacheAdapter;
|
||||
import org.alfresco.repo.dictionary.DictionaryDAOImpl.DictionaryRegistry;
|
||||
import org.alfresco.repo.dictionary.NamespaceDAOImpl.NamespaceRegistry;
|
||||
import org.alfresco.repo.tenant.SingleTServiceImpl;
|
||||
import org.alfresco.repo.tenant.TenantService;
|
||||
|
||||
|
||||
/**
|
||||
* Test Model Definitions
|
||||
*/
|
||||
public class TestModel
|
||||
{
|
||||
/**
|
||||
* Test model
|
||||
*
|
||||
* Java command line client
|
||||
* <br />
|
||||
* Syntax:
|
||||
* <br />
|
||||
* TestModel [-h] [model filename]*
|
||||
* <p>
|
||||
* Returns 0 for success.
|
||||
*/
|
||||
public static void main(String[] args)
|
||||
{
|
||||
if (args != null && args.length > 0 && args[0].equals("-h"))
|
||||
{
|
||||
System.out.println("TestModel [model filename]*");
|
||||
System.exit(1);
|
||||
}
|
||||
|
||||
System.out.println("Testing dictionary model definitions...");
|
||||
|
||||
// construct list of models to test
|
||||
// include alfresco defaults
|
||||
List<String> bootstrapModels = new ArrayList<String>();
|
||||
bootstrapModels.add("alfresco/model/dictionaryModel.xml");
|
||||
bootstrapModels.add("alfresco/model/systemModel.xml");
|
||||
bootstrapModels.add("org/alfresco/repo/security/authentication/userModel.xml");
|
||||
bootstrapModels.add("alfresco/model/contentModel.xml");
|
||||
bootstrapModels.add("alfresco/model/wcmModel.xml");
|
||||
bootstrapModels.add("alfresco/model/applicationModel.xml");
|
||||
bootstrapModels.add("alfresco/model/bpmModel.xml");
|
||||
bootstrapModels.add("alfresco/model/wcmAppModel.xml");
|
||||
|
||||
// include models specified on command line
|
||||
for (String arg: args)
|
||||
{
|
||||
bootstrapModels.add(arg);
|
||||
}
|
||||
|
||||
for (String model : bootstrapModels)
|
||||
{
|
||||
System.out.println(" " + model);
|
||||
}
|
||||
|
||||
// construct dictionary dao
|
||||
TenantService tenantService = new SingleTServiceImpl();
|
||||
|
||||
NamespaceDAOImpl namespaceDAO = new NamespaceDAOImpl();
|
||||
namespaceDAO.setTenantService(tenantService);
|
||||
|
||||
initNamespaceCaches(namespaceDAO);
|
||||
|
||||
DictionaryDAOImpl dictionaryDAO = new DictionaryDAOImpl(namespaceDAO);
|
||||
dictionaryDAO.setTenantService(tenantService);
|
||||
|
||||
initDictionaryCaches(dictionaryDAO);
|
||||
|
||||
// bootstrap dao
|
||||
try
|
||||
{
|
||||
DictionaryBootstrap bootstrap = new DictionaryBootstrap();
|
||||
bootstrap.setModels(bootstrapModels);
|
||||
bootstrap.setDictionaryDAO(dictionaryDAO);
|
||||
bootstrap.bootstrap();
|
||||
System.out.println("Models are valid.");
|
||||
|
||||
System.exit(0); // Success
|
||||
|
||||
}
|
||||
catch(Exception e)
|
||||
{
|
||||
System.out.println("Found an invalid model...");
|
||||
Throwable t = e;
|
||||
while (t != null)
|
||||
{
|
||||
System.out.println(t.getMessage());
|
||||
t = t.getCause();
|
||||
}
|
||||
System.exit(2); // Not Success
|
||||
}
|
||||
}
|
||||
|
||||
private static void initDictionaryCaches(DictionaryDAOImpl dictionaryDAO)
|
||||
{
|
||||
CacheManager cacheManager = new CacheManager();
|
||||
|
||||
Cache dictionaryEhCache = new Cache("dictionaryCache", 50, false, true, 0L, 0L);
|
||||
cacheManager.addCache(dictionaryEhCache);
|
||||
EhCacheAdapter<String, DictionaryRegistry> dictionaryCache = new EhCacheAdapter<String, DictionaryRegistry>();
|
||||
dictionaryCache.setCache(dictionaryEhCache);
|
||||
|
||||
dictionaryDAO.setDictionaryRegistryCache(dictionaryCache);
|
||||
}
|
||||
|
||||
private static void initNamespaceCaches(NamespaceDAOImpl namespaceDAO)
|
||||
{
|
||||
CacheManager cacheManager = new CacheManager();
|
||||
|
||||
Cache namespaceEhCache = new Cache("namespaceCache", 50, false, true, 0L, 0L);
|
||||
cacheManager.addCache(namespaceEhCache);
|
||||
EhCacheAdapter<String, NamespaceRegistry> namespaceCache = new EhCacheAdapter<String, NamespaceRegistry>();
|
||||
namespaceCache.setCache(namespaceEhCache);
|
||||
|
||||
namespaceDAO.setNamespaceRegistryCache(namespaceCache);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user