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

📄 coveragedatacontainer.java

📁 java覆盖率测试工具
💻 JAVA
字号:
/*
 * Cobertura - http://cobertura.sourceforge.net/
 *
 * Copyright (C) 2003 jcoverage ltd.
 * Copyright (C) 2005 Mark Doliner
 * Copyright (C) 2005 Jeremy Thomerson
 * Copyright (C) 2005 Mark Sinke
 *
 * Cobertura 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.
 *
 * Cobertura 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 Cobertura; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
 * USA
 */

package net.sourceforge.cobertura.coveragedata;

import java.io.Serializable;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Collections;

/**
 * <p>
 * Coverage data information is typically serialized to a file.
 * </p>
 *
 * <p>
 * This class implements HasBeenInstrumented so that when cobertura
 * instruments itself, it will omit this class.  It does this to
 * avoid an infinite recursion problem because instrumented classes
 * make use of this class.
 * </p>
 */
public abstract class CoverageDataContainer
		implements CoverageData, HasBeenInstrumented, Serializable
{

   private static final long serialVersionUID = 2;

	/**
	 * Each key is the name of a child, usually stored as a String or
	 * an Integer object.  Each value is information about the child,
	 * stored as an object that implements the CoverageData interface.
	 */
	Map children = Collections.synchronizedMap(new HashMap());

	/**
	 * Determine if this CoverageDataContainer is equal to
	 * another one.  Subclasses should override this and
	 * make sure they implement the hashCode method.
	 *
	 * @param obj An object to test for equality.
	 * @return True if the objects are equal.
	 */
	public boolean equals(Object obj)
	{
		if (this == obj)
			return true;
		if ((obj == null) || !(obj.getClass().equals(this.getClass())))
			return false;

		CoverageDataContainer coverageDataContainer = (CoverageDataContainer)obj;
		return this.children.equals(coverageDataContainer.children);
	}

	/**
	 * @return The average branch coverage rate for all children
	 *         in this container.
	 */
	public double getBranchCoverageRate()
	{
		int number = 0;
		int numberCovered = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfValidBranches();
			numberCovered += coverageContainer.getNumberOfCoveredBranches();
		}
		if (number == 0)
		{
			// no branches, therefore 100% branch coverage.
			return 1d;
		}
		return (double)numberCovered / number;
	}

	/**
	 * Get a child from this container with the specified
	 * key.
	 * @param name The key used to lookup the child in the
	 *        map.
	 * @return The child object, if found, or null if not found.
	 */
	public CoverageData getChild(String name)
	{
		return (CoverageData)this.children.get(name);
	}

	/**
	 * @return The average line coverage rate for all children
	 *         in this container.  This number will be a decimal
	 *         between 0 and 1, inclusive.
	 */
	public double getLineCoverageRate()
	{
		int number = 0;
		int numberCovered = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfValidLines();
			numberCovered += coverageContainer.getNumberOfCoveredLines();
		}
		if (number == 0)
		{
			// no lines, therefore 100% line coverage.
			return 1d;
		}
		return (double)numberCovered / number;
	}

	/**
	 * @return The number of children in this container.
	 */
	public int getNumberOfChildren()
	{
		return this.children.size();
	}

	public int getNumberOfCoveredBranches()
	{
		int number = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfCoveredBranches();
		}
		return number;
	}

	public int getNumberOfCoveredLines()
	{
		int number = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfCoveredLines();
		}
		return number;
	}

	public int getNumberOfValidBranches()
	{
		int number = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfValidBranches();
		}
		return number;
	}

	public int getNumberOfValidLines()
	{
		int number = 0;
		Iterator iter = this.children.values().iterator();
		while (iter.hasNext())
		{
			CoverageData coverageContainer = (CoverageData)iter.next();
			number += coverageContainer.getNumberOfValidLines();
		}
		return number;
	}

	/**
	 * It is highly recommended that classes extending this
	 * class override this hashCode method and generate a more
	 * effective hash code.
	 */
	public int hashCode()
	{
		return this.children.size();
	}

	/**
	 * Merge two <code>CoverageDataContainer</code>s.
	 *
	 * @param coverageData The container to merge into this one.
	 */
	public void merge(CoverageData coverageData)
	{
		CoverageDataContainer container = (CoverageDataContainer)coverageData;
		Iterator iter = container.children.keySet().iterator();
		while (iter.hasNext())
		{
			Object key = iter.next();
			CoverageData newChild = (CoverageData)container.children.get(key);
			CoverageData existingChild = (CoverageData)this.children.get(key);
			if (existingChild != null)
			{
				existingChild.merge(newChild);
			}
			else
			{
				// TODO: Shouldn't we be cloning newChild here?  I think so that
				//       would be better... but we would need to override the
				//       clone() method all over the place?
				this.children.put(key, newChild);
			}
		}
	}

}

⌨️ 快捷键说明

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