/* * Lokomo OneCMDB - An Open Source Software for Configuration * Management of Datacenter Resources * * Copyright (C) 2006 Lokomo Systems AB * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or (at * your option) any later version. * * This program 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 * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA * 02110-1301 USA. * * Lokomo Systems AB can be contacted via e-mail: info@lokomo.com or via * paper mail: Lokomo Systems AB, Sv�rdv�gen 27, SE-182 33 * Danderyd, Sweden. * */ package org.onecmdb.core.tests.performance; import java.util.Set; import org.onecmdb.core.ICi; import org.onecmdb.core.IModelService; import org.onecmdb.core.internal.model.Path; import org.onecmdb.core.internal.model.QueryCriteria; import org.onecmdb.core.internal.model.QueryResult; import org.onecmdb.core.tests.AbstractOneCmdbTestCase; import org.onecmdb.core.tests.OneCMDBTestConfig; public class TestQueryPerformance extends AbstractOneCmdbTestCase { @Override protected String getDatasourceResource() { return("org/onecmdb/core/tests/resources/datasource/mysql-15-update-datasource.xml"); } public void testQueryCI() { IModelService svc = (IModelService) session.getService(IModelService.class); ICi brukare = svc.findCi(new Path<String>("NetworkIF")); long start = System.currentTimeMillis(); Set<ICi> cis = brukare.getOffsprings(); long stop = System.currentTimeMillis(); System.out.println("Query: " + (stop-start) + "ms for " + cis.size() + " instances"); QueryCriteria crit = new QueryCriteria(); crit.setOffspringOfAlias("Resurs"); crit.setOffspringDepth(new Integer(1)); crit.setMatchCiInstances(true); start = System.currentTimeMillis(); QueryResult result = svc.query(crit); stop = System.currentTimeMillis(); System.out.println("Query: " + (stop-start) + "ms for " + result.size() + " instances"); } }