diff options
| author | Richard Linden <none@none> | 2013-12-02 14:57:29 -0800 | 
|---|---|---|
| committer | Richard Linden <none@none> | 2013-12-02 14:57:29 -0800 | 
| commit | 34ff2fc46ba8c623f0eab8fe1dccb5db327775a8 (patch) | |
| tree | 7bc422dd969e1d18e9d83e52a9a6dcfa2bd6139f /indra/newview/tests | |
| parent | 787ccaf297e81291469aaf269f563d862fb150a3 (diff) | |
| parent | d8e92867162f8c4ff9489d8eefde53546e907dff (diff) | |
merge with release
Diffstat (limited to 'indra/newview/tests')
| -rwxr-xr-x | indra/newview/tests/llcapabilitylistener_test.cpp | 12 | ||||
| -rwxr-xr-x | indra/newview/tests/llsimplestat_test.cpp | 580 | ||||
| -rwxr-xr-x | indra/newview/tests/lltexturestatsuploader_test.cpp | 2 | ||||
| -rwxr-xr-x | indra/newview/tests/llviewerassetstats_test.cpp | 686 | ||||
| -rwxr-xr-x | indra/newview/tests/llxmlrpclistener_test.cpp | 8 | 
5 files changed, 137 insertions, 1151 deletions
| diff --git a/indra/newview/tests/llcapabilitylistener_test.cpp b/indra/newview/tests/llcapabilitylistener_test.cpp index e1cbd28f92..bde991a01e 100755 --- a/indra/newview/tests/llcapabilitylistener_test.cpp +++ b/indra/newview/tests/llcapabilitylistener_test.cpp @@ -134,10 +134,10 @@ namespace tut          std::string threw;          try          { -            WrapLL_ERRS capture; +            WrapLLErrs capture;              regionPump.post(request);          } -        catch (const WrapLL_ERRS::FatalException& e) +        catch (const WrapLLErrs::FatalException& e)          {              threw = e.what();          } @@ -181,10 +181,10 @@ namespace tut          std::string threw;          try          { -            WrapLL_ERRS capture; +            WrapLLErrs capture;              regionPump.post(request);          } -        catch (const WrapLL_ERRS::FatalException& e) +        catch (const WrapLLErrs::FatalException& e)          {              threw = e.what();          } @@ -243,10 +243,10 @@ namespace tut          std::string threw;          try          { -            WrapLL_ERRS capture; +            WrapLLErrs capture;              regionPump.post(request);          } -        catch (const WrapLL_ERRS::FatalException& e) +        catch (const WrapLLErrs::FatalException& e)          {              threw = e.what();          } diff --git a/indra/newview/tests/llsimplestat_test.cpp b/indra/newview/tests/llsimplestat_test.cpp deleted file mode 100755 index b556941f4a..0000000000 --- a/indra/newview/tests/llsimplestat_test.cpp +++ /dev/null @@ -1,580 +0,0 @@ -/**  - * @file llsimplestats_test.cpp - * @date 2010-10-22 - * @brief Test cases for some of llsimplestat.h - * - * $LicenseInfo:firstyear=2010&license=viewerlgpl$ - * Second Life Viewer Source Code - * Copyright (C) 2010, Linden Research, Inc. - *  - * This library 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; - * version 2.1 of the License only. - *  - * This library 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 this library; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA - *  - * Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA - * $/LicenseInfo$ - */ - -#include "linden_common.h" - -#include <tut/tut.hpp> - -#include "lltut.h" -#include "../llsimplestat.h" -#include "llsd.h" -#include "llmath.h" - -// @brief Used as a pointer cast type to get access to LLSimpleStatCounter -class TutStatCounter: public LLSimpleStatCounter -{ -public: -	TutStatCounter();							// Not defined -	~TutStatCounter();							// Not defined -	void operator=(const TutStatCounter &);		// Not defined -	 -	void setRawCount(U32 c)				{ mCount = c; } -	U32 getRawCount() const				{ return mCount; } -}; - - -namespace tut -{ -	struct stat_counter_index -	{}; -	typedef test_group<stat_counter_index> stat_counter_index_t; -	typedef stat_counter_index_t::object stat_counter_index_object_t; -	tut::stat_counter_index_t tut_stat_counter_index("stat_counter_test"); - -	// Testing LLSimpleStatCounter's external interface -	template<> template<> -	void stat_counter_index_object_t::test<1>() -	{ -		LLSimpleStatCounter c1; -		ensure("Initialized counter is zero", (0 == c1.getCount())); - -		ensure("Counter increment return is 1", (1 == ++c1)); -		ensure("Counter increment return is 2", (2 == ++c1)); - -		ensure("Current counter is 2", (2 == c1.getCount())); - -		c1.reset(); -		ensure("Counter is 0 after reset", (0 == c1.getCount())); -		 -		ensure("Counter increment return is 1", (1 == ++c1)); -	} - -	// Testing LLSimpleStatCounter's internal state -	template<> template<> -	void stat_counter_index_object_t::test<2>() -	{ -		LLSimpleStatCounter c1; -		TutStatCounter * tc1 = (TutStatCounter *) &c1; -		 -		ensure("Initialized private counter is zero", (0 == tc1->getRawCount())); - -		++c1; -		++c1; -		 -		ensure("Current private counter is 2", (2 == tc1->getRawCount())); - -		c1.reset(); -		ensure("Raw counter is 0 after reset", (0 == tc1->getRawCount())); -	} - -	// Testing LLSimpleStatCounter's wrapping behavior -	template<> template<> -	void stat_counter_index_object_t::test<3>() -	{ -		LLSimpleStatCounter c1; -		TutStatCounter * tc1 = (TutStatCounter *) &c1; - -		tc1->setRawCount(U32_MAX); -		ensure("Initialized private counter is zero", (U32_MAX == c1.getCount())); - -		ensure("Increment of max value wraps to 0", (0 == ++c1)); -	} - -	// Testing LLSimpleStatMMM's external behavior -	template<> template<> -	void stat_counter_index_object_t::test<4>() -	{ -		LLSimpleStatMMM<> m1; -		typedef LLSimpleStatMMM<>::Value lcl_float; -		lcl_float zero(0); - -		// Freshly-constructed -		ensure("Constructed MMM<> has 0 count", (0 == m1.getCount())); -		ensure("Constructed MMM<> has 0 min", (zero == m1.getMin())); -		ensure("Constructed MMM<> has 0 max", (zero == m1.getMax())); -		ensure("Constructed MMM<> has 0 mean no div-by-zero", (zero == m1.getMean())); - -		// Single insert -		m1.record(1.0); -		ensure("Single insert MMM<> has 1 count", (1 == m1.getCount())); -		ensure("Single insert MMM<> has 1.0 min", (1.0 == m1.getMin())); -		ensure("Single insert MMM<> has 1.0 max", (1.0 == m1.getMax())); -		ensure("Single insert MMM<> has 1.0 mean", (1.0 == m1.getMean())); -		 -		// Second insert -		m1.record(3.0); -		ensure("2nd insert MMM<> has 2 count", (2 == m1.getCount())); -		ensure("2nd insert MMM<> has 1.0 min", (1.0 == m1.getMin())); -		ensure("2nd insert MMM<> has 3.0 max", (3.0 == m1.getMax())); -		ensure_approximately_equals("2nd insert MMM<> has 2.0 mean", m1.getMean(), lcl_float(2.0), 1); - -		// Third insert -		m1.record(5.0); -		ensure("3rd insert MMM<> has 3 count", (3 == m1.getCount())); -		ensure("3rd insert MMM<> has 1.0 min", (1.0 == m1.getMin())); -		ensure("3rd insert MMM<> has 5.0 max", (5.0 == m1.getMax())); -		ensure_approximately_equals("3rd insert MMM<> has 3.0 mean", m1.getMean(), lcl_float(3.0), 1); - -		// Fourth insert -		m1.record(1000000.0); -		ensure("4th insert MMM<> has 4 count", (4 == m1.getCount())); -		ensure("4th insert MMM<> has 1.0 min", (1.0 == m1.getMin())); -		ensure("4th insert MMM<> has 100000.0 max", (1000000.0 == m1.getMax())); -		ensure_approximately_equals("4th insert MMM<> has 250002.0 mean", m1.getMean(), lcl_float(250002.0), 1); - -		// Reset -		m1.reset(); -		ensure("Reset MMM<> has 0 count", (0 == m1.getCount())); -		ensure("Reset MMM<> has 0 min", (zero == m1.getMin())); -		ensure("Reset MMM<> has 0 max", (zero == m1.getMax())); -		ensure("Reset MMM<> has 0 mean no div-by-zero", (zero == m1.getMean())); -	} - -	// Testing LLSimpleStatMMM's response to large values -	template<> template<> -	void stat_counter_index_object_t::test<5>() -	{ -		LLSimpleStatMMM<> m1; -		typedef LLSimpleStatMMM<>::Value lcl_float; -		lcl_float zero(0); - -		// Insert overflowing values -		const lcl_float bignum(F32_MAX / 2); - -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(zero); - -		ensure("Overflowed MMM<> has 8 count", (8 == m1.getCount())); -		ensure("Overflowed MMM<> has 0 min", (zero == m1.getMin())); -		ensure("Overflowed MMM<> has huge max", (bignum == m1.getMax())); -		ensure("Overflowed MMM<> has fetchable mean", (1.0 == m1.getMean() || true)); -		// We should be infinte but not interested in proving the IEEE standard here. -		LLSD sd1(m1.getMean()); -		// std::cout << "Thingy:  " << m1.getMean() << " and as LLSD:  " << sd1 << std::endl; -		ensure("Overflowed MMM<> produces LLSDable Real", (sd1.isReal())); -	} - -	// Testing LLSimpleStatMMM<F32>'s external behavior -	template<> template<> -	void stat_counter_index_object_t::test<6>() -	{ -		LLSimpleStatMMM<F32> m1; -		typedef LLSimpleStatMMM<F32>::Value lcl_float; -		lcl_float zero(0); - -		// Freshly-constructed -		ensure("Constructed MMM<F32> has 0 count", (0 == m1.getCount())); -		ensure("Constructed MMM<F32> has 0 min", (zero == m1.getMin())); -		ensure("Constructed MMM<F32> has 0 max", (zero == m1.getMax())); -		ensure("Constructed MMM<F32> has 0 mean no div-by-zero", (zero == m1.getMean())); - -		// Single insert -		m1.record(1.0); -		ensure("Single insert MMM<F32> has 1 count", (1 == m1.getCount())); -		ensure("Single insert MMM<F32> has 1.0 min", (1.0 == m1.getMin())); -		ensure("Single insert MMM<F32> has 1.0 max", (1.0 == m1.getMax())); -		ensure("Single insert MMM<F32> has 1.0 mean", (1.0 == m1.getMean())); -		 -		// Second insert -		m1.record(3.0); -		ensure("2nd insert MMM<F32> has 2 count", (2 == m1.getCount())); -		ensure("2nd insert MMM<F32> has 1.0 min", (1.0 == m1.getMin())); -		ensure("2nd insert MMM<F32> has 3.0 max", (3.0 == m1.getMax())); -		ensure_approximately_equals("2nd insert MMM<F32> has 2.0 mean", m1.getMean(), lcl_float(2.0), 1); - -		// Third insert -		m1.record(5.0); -		ensure("3rd insert MMM<F32> has 3 count", (3 == m1.getCount())); -		ensure("3rd insert MMM<F32> has 1.0 min", (1.0 == m1.getMin())); -		ensure("3rd insert MMM<F32> has 5.0 max", (5.0 == m1.getMax())); -		ensure_approximately_equals("3rd insert MMM<F32> has 3.0 mean", m1.getMean(), lcl_float(3.0), 1); - -		// Fourth insert -		m1.record(1000000.0); -		ensure("4th insert MMM<F32> has 4 count", (4 == m1.getCount())); -		ensure("4th insert MMM<F32> has 1.0 min", (1.0 == m1.getMin())); -		ensure("4th insert MMM<F32> has 1000000.0 max", (1000000.0 == m1.getMax())); -		ensure_approximately_equals("4th insert MMM<F32> has 250002.0 mean", m1.getMean(), lcl_float(250002.0), 1); - -		// Reset -		m1.reset(); -		ensure("Reset MMM<F32> has 0 count", (0 == m1.getCount())); -		ensure("Reset MMM<F32> has 0 min", (zero == m1.getMin())); -		ensure("Reset MMM<F32> has 0 max", (zero == m1.getMax())); -		ensure("Reset MMM<F32> has 0 mean no div-by-zero", (zero == m1.getMean())); -	} - -	// Testing LLSimpleStatMMM's response to large values -	template<> template<> -	void stat_counter_index_object_t::test<7>() -	{ -		LLSimpleStatMMM<F32> m1; -		typedef LLSimpleStatMMM<F32>::Value lcl_float; -		lcl_float zero(0); - -		// Insert overflowing values -		const lcl_float bignum(F32_MAX / 2); - -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(zero); - -		ensure("Overflowed MMM<F32> has 8 count", (8 == m1.getCount())); -		ensure("Overflowed MMM<F32> has 0 min", (zero == m1.getMin())); -		ensure("Overflowed MMM<F32> has huge max", (bignum == m1.getMax())); -		ensure("Overflowed MMM<F32> has fetchable mean", (1.0 == m1.getMean() || true)); -		// We should be infinte but not interested in proving the IEEE standard here. -		LLSD sd1(m1.getMean()); -		// std::cout << "Thingy:  " << m1.getMean() << " and as LLSD:  " << sd1 << std::endl; -		ensure("Overflowed MMM<F32> produces LLSDable Real", (sd1.isReal())); -	} - -	// Testing LLSimpleStatMMM<F64>'s external behavior -	template<> template<> -	void stat_counter_index_object_t::test<8>() -	{ -		LLSimpleStatMMM<F64> m1; -		typedef LLSimpleStatMMM<F64>::Value lcl_float; -		lcl_float zero(0); - -		// Freshly-constructed -		ensure("Constructed MMM<F64> has 0 count", (0 == m1.getCount())); -		ensure("Constructed MMM<F64> has 0 min", (zero == m1.getMin())); -		ensure("Constructed MMM<F64> has 0 max", (zero == m1.getMax())); -		ensure("Constructed MMM<F64> has 0 mean no div-by-zero", (zero == m1.getMean())); - -		// Single insert -		m1.record(1.0); -		ensure("Single insert MMM<F64> has 1 count", (1 == m1.getCount())); -		ensure("Single insert MMM<F64> has 1.0 min", (1.0 == m1.getMin())); -		ensure("Single insert MMM<F64> has 1.0 max", (1.0 == m1.getMax())); -		ensure("Single insert MMM<F64> has 1.0 mean", (1.0 == m1.getMean())); -		 -		// Second insert -		m1.record(3.0); -		ensure("2nd insert MMM<F64> has 2 count", (2 == m1.getCount())); -		ensure("2nd insert MMM<F64> has 1.0 min", (1.0 == m1.getMin())); -		ensure("2nd insert MMM<F64> has 3.0 max", (3.0 == m1.getMax())); -		ensure_approximately_equals("2nd insert MMM<F64> has 2.0 mean", m1.getMean(), lcl_float(2.0), 1); - -		// Third insert -		m1.record(5.0); -		ensure("3rd insert MMM<F64> has 3 count", (3 == m1.getCount())); -		ensure("3rd insert MMM<F64> has 1.0 min", (1.0 == m1.getMin())); -		ensure("3rd insert MMM<F64> has 5.0 max", (5.0 == m1.getMax())); -		ensure_approximately_equals("3rd insert MMM<F64> has 3.0 mean", m1.getMean(), lcl_float(3.0), 1); - -		// Fourth insert -		m1.record(1000000.0); -		ensure("4th insert MMM<F64> has 4 count", (4 == m1.getCount())); -		ensure("4th insert MMM<F64> has 1.0 min", (1.0 == m1.getMin())); -		ensure("4th insert MMM<F64> has 1000000.0 max", (1000000.0 == m1.getMax())); -		ensure_approximately_equals("4th insert MMM<F64> has 250002.0 mean", m1.getMean(), lcl_float(250002.0), 1); - -		// Reset -		m1.reset(); -		ensure("Reset MMM<F64> has 0 count", (0 == m1.getCount())); -		ensure("Reset MMM<F64> has 0 min", (zero == m1.getMin())); -		ensure("Reset MMM<F64> has 0 max", (zero == m1.getMax())); -		ensure("Reset MMM<F64> has 0 mean no div-by-zero", (zero == m1.getMean())); -	} - -	// Testing LLSimpleStatMMM's response to large values -	template<> template<> -	void stat_counter_index_object_t::test<9>() -	{ -		LLSimpleStatMMM<F64> m1; -		typedef LLSimpleStatMMM<F64>::Value lcl_float; -		lcl_float zero(0); - -		// Insert overflowing values -		const lcl_float bignum(F64_MAX / 2); - -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(zero); - -		ensure("Overflowed MMM<F64> has 8 count", (8 == m1.getCount())); -		ensure("Overflowed MMM<F64> has 0 min", (zero == m1.getMin())); -		ensure("Overflowed MMM<F64> has huge max", (bignum == m1.getMax())); -		ensure("Overflowed MMM<F64> has fetchable mean", (1.0 == m1.getMean() || true)); -		// We should be infinte but not interested in proving the IEEE standard here. -		LLSD sd1(m1.getMean()); -		// std::cout << "Thingy:  " << m1.getMean() << " and as LLSD:  " << sd1 << std::endl; -		ensure("Overflowed MMM<F64> produces LLSDable Real", (sd1.isReal())); -	} - -	// Testing LLSimpleStatMMM<U64>'s external behavior -	template<> template<> -	void stat_counter_index_object_t::test<10>() -	{ -		LLSimpleStatMMM<U64> m1; -		typedef LLSimpleStatMMM<U64>::Value lcl_int; -		lcl_int zero(0); - -		// Freshly-constructed -		ensure("Constructed MMM<U64> has 0 count", (0 == m1.getCount())); -		ensure("Constructed MMM<U64> has 0 min", (zero == m1.getMin())); -		ensure("Constructed MMM<U64> has 0 max", (zero == m1.getMax())); -		ensure("Constructed MMM<U64> has 0 mean no div-by-zero", (zero == m1.getMean())); - -		// Single insert -		m1.record(1); -		ensure("Single insert MMM<U64> has 1 count", (1 == m1.getCount())); -		ensure("Single insert MMM<U64> has 1 min", (1 == m1.getMin())); -		ensure("Single insert MMM<U64> has 1 max", (1 == m1.getMax())); -		ensure("Single insert MMM<U64> has 1 mean", (1 == m1.getMean())); -		 -		// Second insert -		m1.record(3); -		ensure("2nd insert MMM<U64> has 2 count", (2 == m1.getCount())); -		ensure("2nd insert MMM<U64> has 1 min", (1 == m1.getMin())); -		ensure("2nd insert MMM<U64> has 3 max", (3 == m1.getMax())); -		ensure("2nd insert MMM<U64> has 2 mean", (2 == m1.getMean())); - -		// Third insert -		m1.record(5); -		ensure("3rd insert MMM<U64> has 3 count", (3 == m1.getCount())); -		ensure("3rd insert MMM<U64> has 1 min", (1 == m1.getMin())); -		ensure("3rd insert MMM<U64> has 5 max", (5 == m1.getMax())); -		ensure("3rd insert MMM<U64> has 3 mean", (3 == m1.getMean())); - -		// Fourth insert -		m1.record(U64L(1000000000000)); -		ensure("4th insert MMM<U64> has 4 count", (4 == m1.getCount())); -		ensure("4th insert MMM<U64> has 1 min", (1 == m1.getMin())); -		ensure("4th insert MMM<U64> has 1000000000000ULL max", (U64L(1000000000000) == m1.getMax())); -		ensure("4th insert MMM<U64> has 250000000002ULL mean", (U64L( 250000000002) == m1.getMean())); - -		// Reset -		m1.reset(); -		ensure("Reset MMM<U64> has 0 count", (0 == m1.getCount())); -		ensure("Reset MMM<U64> has 0 min", (zero == m1.getMin())); -		ensure("Reset MMM<U64> has 0 max", (zero == m1.getMax())); -		ensure("Reset MMM<U64> has 0 mean no div-by-zero", (zero == m1.getMean())); -	} - -	// Testing LLSimpleStatMMM's response to large values -	template<> template<> -	void stat_counter_index_object_t::test<11>() -	{ -		LLSimpleStatMMM<U64> m1; -		typedef LLSimpleStatMMM<U64>::Value lcl_int; -		lcl_int zero(0); - -		// Insert overflowing values -		const lcl_int bignum(U64L(0xffffffffffffffff) / 2); - -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(bignum); -		m1.record(zero); - -		ensure("Overflowed MMM<U64> has 8 count", (8 == m1.getCount())); -		ensure("Overflowed MMM<U64> has 0 min", (zero == m1.getMin())); -		ensure("Overflowed MMM<U64> has huge max", (bignum == m1.getMax())); -		ensure("Overflowed MMM<U64> has fetchable mean", (zero == m1.getMean() || true)); -	} - -    // Testing LLSimpleStatCounter's merge() method -	template<> template<> -	void stat_counter_index_object_t::test<12>() -	{ -		LLSimpleStatCounter c1; -		LLSimpleStatCounter c2; - -		++c1; -		++c1; -		++c1; -		++c1; - -		++c2; -		++c2; -		c2.merge(c1); -		 -		ensure_equals("4 merged into 2 results in 6", 6, c2.getCount()); - -		ensure_equals("Source of merge is undamaged", 4, c1.getCount()); -	} - -    // Testing LLSimpleStatMMM's merge() method -	template<> template<> -	void stat_counter_index_object_t::test<13>() -	{ -		LLSimpleStatMMM<> m1; -		LLSimpleStatMMM<> m2; - -		m1.record(3.5); -		m1.record(4.5); -		m1.record(5.5); -		m1.record(6.5); - -		m2.record(5.0); -		m2.record(7.0); -		m2.record(9.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p1)", 7, m2.getCount()); -		ensure_approximately_equals("Min after merge (p1)", F32(3.5), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p1)", F32(9.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p1)", F32(41.000/7.000), m2.getMean(), 22); -		 - -		ensure_equals("Source count of merge is undamaged (p1)", 4, m1.getCount()); -		ensure_approximately_equals("Source min of merge is undamaged (p1)", F32(3.5), m1.getMin(), 22); -		ensure_approximately_equals("Source max of merge is undamaged (p1)", F32(6.5), m1.getMax(), 22); -		ensure_approximately_equals("Source mean of merge is undamaged (p1)", F32(5.0), m1.getMean(), 22); - -		m2.reset(); - -		m2.record(-22.0); -		m2.record(-1.0); -		m2.record(30.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p2)", 7, m2.getCount()); -		ensure_approximately_equals("Min after merge (p2)", F32(-22.0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p2)", F32(30.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p2)", F32(27.000/7.000), m2.getMean(), 22); - -	} - -    // Testing LLSimpleStatMMM's merge() method when src contributes nothing -	template<> template<> -	void stat_counter_index_object_t::test<14>() -	{ -		LLSimpleStatMMM<> m1; -		LLSimpleStatMMM<> m2; - -		m2.record(5.0); -		m2.record(7.0); -		m2.record(9.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p1)", 3, m2.getCount()); -		ensure_approximately_equals("Min after merge (p1)", F32(5.0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p1)", F32(9.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p1)", F32(7.000), m2.getMean(), 22); - -		ensure_equals("Source count of merge is undamaged (p1)", 0, m1.getCount()); -		ensure_approximately_equals("Source min of merge is undamaged (p1)", F32(0), m1.getMin(), 22); -		ensure_approximately_equals("Source max of merge is undamaged (p1)", F32(0), m1.getMax(), 22); -		ensure_approximately_equals("Source mean of merge is undamaged (p1)", F32(0), m1.getMean(), 22); - -		m2.reset(); - -		m2.record(-22.0); -		m2.record(-1.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p2)", 2, m2.getCount()); -		ensure_approximately_equals("Min after merge (p2)", F32(-22.0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p2)", F32(-1.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p2)", F32(-11.5), m2.getMean(), 22); -	} - -    // Testing LLSimpleStatMMM's merge() method when dst contributes nothing -	template<> template<> -	void stat_counter_index_object_t::test<15>() -	{ -		LLSimpleStatMMM<> m1; -		LLSimpleStatMMM<> m2; - -		m1.record(5.0); -		m1.record(7.0); -		m1.record(9.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p1)", 3, m2.getCount()); -		ensure_approximately_equals("Min after merge (p1)", F32(5.0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p1)", F32(9.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p1)", F32(7.000), m2.getMean(), 22); - -		ensure_equals("Source count of merge is undamaged (p1)", 3, m1.getCount()); -		ensure_approximately_equals("Source min of merge is undamaged (p1)", F32(5.0), m1.getMin(), 22); -		ensure_approximately_equals("Source max of merge is undamaged (p1)", F32(9.0), m1.getMax(), 22); -		ensure_approximately_equals("Source mean of merge is undamaged (p1)", F32(7.0), m1.getMean(), 22); - -		m1.reset(); -		m2.reset(); -		 -		m1.record(-22.0); -		m1.record(-1.0); -		 -		m2.merge(m1); - -		ensure_equals("Count after merge (p2)", 2, m2.getCount()); -		ensure_approximately_equals("Min after merge (p2)", F32(-22.0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p2)", F32(-1.0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p2)", F32(-11.5), m2.getMean(), 22); -	} - -    // Testing LLSimpleStatMMM's merge() method when neither dst nor src contributes -	template<> template<> -	void stat_counter_index_object_t::test<16>() -	{ -		LLSimpleStatMMM<> m1; -		LLSimpleStatMMM<> m2; - -		m2.merge(m1); - -		ensure_equals("Count after merge (p1)", 0, m2.getCount()); -		ensure_approximately_equals("Min after merge (p1)", F32(0), m2.getMin(), 22); -		ensure_approximately_equals("Max after merge (p1)", F32(0), m2.getMax(), 22); -		ensure_approximately_equals("Mean after merge (p1)", F32(0), m2.getMean(), 22); - -		ensure_equals("Source count of merge is undamaged (p1)", 0, m1.getCount()); -		ensure_approximately_equals("Source min of merge is undamaged (p1)", F32(0), m1.getMin(), 22); -		ensure_approximately_equals("Source max of merge is undamaged (p1)", F32(0), m1.getMax(), 22); -		ensure_approximately_equals("Source mean of merge is undamaged (p1)", F32(0), m1.getMean(), 22); -	} -} diff --git a/indra/newview/tests/lltexturestatsuploader_test.cpp b/indra/newview/tests/lltexturestatsuploader_test.cpp index cfb2c267cc..4438523022 100755 --- a/indra/newview/tests/lltexturestatsuploader_test.cpp +++ b/indra/newview/tests/lltexturestatsuploader_test.cpp @@ -111,7 +111,7 @@ namespace tut  	void texturestatsuploader_object_t::test<1>()  	{  		LLTextureStatsUploader tsu; -		llinfos << &tsu << llendl; +		LL_INFOS() << &tsu << LL_ENDL;  		ensure("have we crashed?", true);  	} diff --git a/indra/newview/tests/llviewerassetstats_test.cpp b/indra/newview/tests/llviewerassetstats_test.cpp index a331d9aa9e..a08e32cb49 100755 --- a/indra/newview/tests/llviewerassetstats_test.cpp +++ b/indra/newview/tests/llviewerassetstats_test.cpp @@ -35,8 +35,38 @@  #include "lluuid.h"  #include "llsdutil.h"  #include "llregionhandle.h" +#include "lltracethreadrecorder.h"  #include "../llvoavatar.h" +namespace LLStatViewer +{ +	LLTrace::SampleStatHandle<>		FPS_SAMPLE("fpssample"); +} + +void LLVOAvatar::getNearbyRezzedStats(std::vector<S32>& counts) +{ +	counts.resize(3); +	counts[0] = 0; +	counts[1] = 0; +	counts[2] = 1; +} + +// static +std::string LLVOAvatar::rezStatusToString(S32 rez_status) +{ +	if (rez_status==0) return "cloud"; +	if (rez_status==1) return "gray"; +	if (rez_status==2) return "textured"; +	return "unknown"; +} + +// static +LLViewerStats::StatsAccumulator& LLViewerStats::PhaseMap::getPhaseStats(const std::string& phase_name) +{ +	static LLViewerStats::StatsAccumulator junk; +	return junk; +} +  static const char * all_keys[] =   {  	"duration", @@ -199,7 +229,19 @@ get_region(const LLSD & sd, U64 region_handle1)  namespace tut  {  	struct tst_viewerassetstats_index -	{}; +	{ +		tst_viewerassetstats_index() +		{ +			LLTrace::set_master_thread_recorder(&mThreadRecorder); +		} + +		~tst_viewerassetstats_index() +		{ +			LLTrace::set_master_thread_recorder(NULL); +		} + +		LLTrace::ThreadRecorder mThreadRecorder; +	};  	typedef test_group<tst_viewerassetstats_index> tst_viewerassetstats_index_t;  	typedef tst_viewerassetstats_index_t::object tst_viewerassetstats_index_object_t;  	tut::tst_viewerassetstats_index_t tut_tst_viewerassetstats_index("tst_viewerassetstats_test"); @@ -209,24 +251,24 @@ namespace tut  	void tst_viewerassetstats_index_object_t::test<1>()  	{  		// Check that helpers aren't bothered by missing global stats -		ensure("Global gViewerAssetStatsMain should be NULL", (NULL == gViewerAssetStatsMain)); +		ensure("Global gViewerAssetStats should be NULL", (NULL == gViewerAssetStats)); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_response_main(LLViewerAssetType::AT_GESTURE, false, false, 12300000ULL); +		LLViewerAssetStatsFF::record_response(LLViewerAssetType::AT_GESTURE, false, false, (U64Microseconds)12300000ULL);  	}  	// Create a non-global instance and check the structure  	template<> template<>  	void tst_viewerassetstats_index_object_t::test<2>()  	{ -		ensure("Global gViewerAssetStatsMain should be NULL", (NULL == gViewerAssetStatsMain)); +		ensure("Global gViewerAssetStats should be NULL", (NULL == gViewerAssetStats));  		LLViewerAssetStats * it = new LLViewerAssetStats(); -		ensure("Global gViewerAssetStatsMain should still be NULL", (NULL == gViewerAssetStatsMain)); +		ensure("Global gViewerAssetStats should still be NULL", (NULL == gViewerAssetStats));  		LLSD sd_full = it->asLLSD(false); @@ -293,16 +335,16 @@ namespace tut  	template<> template<>  	void tst_viewerassetstats_index_object_t::test<4>()  	{ -		gViewerAssetStatsMain = new LLViewerAssetStats(); -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		gViewerAssetStats = new LLViewerAssetStats(); +		LLViewerAssetStatsFF::set_region(region1_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, false); -		LLSD sd = gViewerAssetStatsMain->asLLSD(false); +		LLSD sd = gViewerAssetStats->asLLSD(false);  		ensure("Correct single-key LLSD map root", is_double_key_map(sd, "regions", "duration"));  		ensure("Correct single-slot LLSD array regions", is_single_slot_array(sd["regions"], region1_handle));  		sd = sd["regions"][0]; @@ -316,80 +358,38 @@ namespace tut  		// Reset and check zeros...  		// Reset leaves current region in place -		gViewerAssetStatsMain->reset(); -		sd = gViewerAssetStatsMain->asLLSD(false)["regions"][region1_handle_str]; +		gViewerAssetStats->reset(); +		sd = gViewerAssetStats->asLLSD(false)["regions"][region1_handle_str]; -		delete gViewerAssetStatsMain; -		gViewerAssetStatsMain = NULL; +		delete gViewerAssetStats; +		gViewerAssetStats = NULL;  		ensure("sd[get_texture_non_temp_udp][enqueued] is reset", (0 == sd["get_texture_non_temp_udp"]["enqueued"].asInteger()));  		ensure("sd[get_gesture_udp][dequeued] is reset", (0 == sd["get_gesture_udp"]["dequeued"].asInteger()));  	} -	// Create two global instances and verify no interactions +    // Check multiple region collection  	template<> template<>  	void tst_viewerassetstats_index_object_t::test<5>()  	{ -		gViewerAssetStatsThread1 = new LLViewerAssetStats(); -		gViewerAssetStatsMain = new LLViewerAssetStats(); -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		gViewerAssetStats = new LLViewerAssetStats(); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::set_region(region1_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLSD sd = gViewerAssetStatsThread1->asLLSD(false); -		ensure("Other collector is empty", is_no_stats_map(sd)); -		sd = gViewerAssetStatsMain->asLLSD(false); -		ensure("Correct single-key LLSD map root", is_double_key_map(sd, "regions", "duration")); -		ensure("Correct single-slot LLSD array regions", is_single_slot_array(sd["regions"], region1_handle)); -		sd = sd["regions"][0]; +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, false); -		// Check a few points on the tree for content -		ensure("sd[get_texture_non_temp_udp][enqueued] is 1", (1 == sd["get_texture_non_temp_udp"]["enqueued"].asInteger())); -		ensure("sd[get_texture_temp_udp][enqueued] is 0", (0 == sd["get_texture_temp_udp"]["enqueued"].asInteger())); -		ensure("sd[get_texture_non_temp_http][enqueued] is 0", (0 == sd["get_texture_non_temp_http"]["enqueued"].asInteger())); -		ensure("sd[get_texture_temp_http][enqueued] is 0", (0 == sd["get_texture_temp_http"]["enqueued"].asInteger())); -		ensure("sd[get_gesture_udp][dequeued] is 0", (0 == sd["get_gesture_udp"]["dequeued"].asInteger())); - -		// Reset and check zeros... -		// Reset leaves current region in place -		gViewerAssetStatsMain->reset(); -		sd = gViewerAssetStatsMain->asLLSD(false)["regions"][0]; -		 -		delete gViewerAssetStatsMain; -		gViewerAssetStatsMain = NULL; -		delete gViewerAssetStatsThread1; -		gViewerAssetStatsThread1 = NULL; - -		ensure("sd[get_texture_non_temp_udp][enqueued] is reset", (0 == sd["get_texture_non_temp_udp"]["enqueued"].asInteger())); -		ensure("sd[get_gesture_udp][dequeued] is reset", (0 == sd["get_gesture_udp"]["dequeued"].asInteger())); -	} - -    // Check multiple region collection -	template<> template<> -	void tst_viewerassetstats_index_object_t::test<6>() -	{ -		gViewerAssetStatsMain = new LLViewerAssetStats(); - -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		LLViewerAssetStatsFF::set_region(region2_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); - -		LLViewerAssetStatsFF::set_region_main(region2_handle); - -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); - -		LLSD sd = gViewerAssetStatsMain->asLLSD(false); +		LLSD sd = gViewerAssetStats->asLLSD(false);  		// std::cout << sd << std::endl; @@ -414,14 +414,14 @@ namespace tut  		// Reset and check zeros...  		// Reset leaves current region in place -		gViewerAssetStatsMain->reset(); -		sd = gViewerAssetStatsMain->asLLSD(false); +		gViewerAssetStats->reset(); +		sd = gViewerAssetStats->asLLSD(false);  		ensure("Correct single-key LLSD map root", is_double_key_map(sd, "regions", "duration"));  		ensure("Correct single-slot LLSD array regions (p2)", is_single_slot_array(sd["regions"], region2_handle));  		sd2 = sd["regions"][0]; -		delete gViewerAssetStatsMain; -		gViewerAssetStatsMain = NULL; +		delete gViewerAssetStats; +		gViewerAssetStats = NULL;  		ensure("sd2[get_texture_non_temp_udp][enqueued] is reset", (0 == sd2["get_texture_non_temp_udp"]["enqueued"].asInteger()));  		ensure("sd2[get_gesture_udp][enqueued] is reset", (0 == sd2["get_gesture_udp"]["enqueued"].asInteger())); @@ -429,41 +429,41 @@ namespace tut      // Check multiple region collection jumping back-and-forth between regions  	template<> template<> -	void tst_viewerassetstats_index_object_t::test<7>() +	void tst_viewerassetstats_index_object_t::test<6>()  	{ -		gViewerAssetStatsMain = new LLViewerAssetStats(); +		gViewerAssetStats = new LLViewerAssetStats(); -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		LLViewerAssetStatsFF::set_region(region1_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::set_region_main(region2_handle); +		LLViewerAssetStatsFF::set_region(region2_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		LLViewerAssetStatsFF::set_region(region1_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, true, true); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, true, true); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, true, true); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, true, true); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::set_region_main(region2_handle); +		LLViewerAssetStatsFF::set_region(region2_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_GESTURE, false, false); -		LLSD sd = gViewerAssetStatsMain->asLLSD(false); +		LLSD sd = gViewerAssetStats->asLLSD(false);  		ensure("Correct double-key LLSD map root", is_double_key_map(sd, "duration", "regions"));  		ensure("Correct double-slot LLSD array regions", is_double_slot_array(sd["regions"], region1_handle, region2_handle)); @@ -486,15 +486,15 @@ namespace tut  		// Reset and check zeros...  		// Reset leaves current region in place -		gViewerAssetStatsMain->reset(); -		sd = gViewerAssetStatsMain->asLLSD(false); +		gViewerAssetStats->reset(); +		sd = gViewerAssetStats->asLLSD(false);  		ensure("Correct single-key LLSD map root", is_double_key_map(sd, "duration", "regions"));  		ensure("Correct single-slot LLSD array regions (p2)", is_single_slot_array(sd["regions"], region2_handle));  		sd2 = get_region(sd, region2_handle);  		ensure("Region2 is present in results", sd2.isMap()); -		delete gViewerAssetStatsMain; -		gViewerAssetStatsMain = NULL; +		delete gViewerAssetStats; +		gViewerAssetStats = NULL;  		ensure_equals("sd2[get_texture_non_temp_udp][enqueued] is reset", sd2["get_texture_non_temp_udp"]["enqueued"].asInteger(), 0);  		ensure_equals("sd2[get_gesture_udp][enqueued] is reset", sd2["get_gesture_udp"]["enqueued"].asInteger(), 0); @@ -502,38 +502,35 @@ namespace tut  	// Non-texture assets ignore transport and persistence flags  	template<> template<> -	void tst_viewerassetstats_index_object_t::test<8>() +	void tst_viewerassetstats_index_object_t::test<7>()  	{ -		gViewerAssetStatsThread1 = new LLViewerAssetStats(); -		gViewerAssetStatsMain = new LLViewerAssetStats(); -		LLViewerAssetStatsFF::set_region_main(region1_handle); +		gViewerAssetStats = new LLViewerAssetStats(); +		LLViewerAssetStatsFF::set_region(region1_handle); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_TEXTURE, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_TEXTURE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, false, true); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, false, true); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, false, true); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, false, true); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, true, false); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, true, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, true, false); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, true, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_BODYPART, true, true); -		LLViewerAssetStatsFF::record_dequeue_main(LLViewerAssetType::AT_BODYPART, true, true); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_BODYPART, true, true); +		LLViewerAssetStatsFF::record_dequeue(LLViewerAssetType::AT_BODYPART, true, true); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_LSL_BYTECODE, false, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_LSL_BYTECODE, false, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_LSL_BYTECODE, false, true); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_LSL_BYTECODE, false, true); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_LSL_BYTECODE, true, false); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_LSL_BYTECODE, true, false); -		LLViewerAssetStatsFF::record_enqueue_main(LLViewerAssetType::AT_LSL_BYTECODE, true, true); +		LLViewerAssetStatsFF::record_enqueue(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		LLSD sd = gViewerAssetStatsThread1->asLLSD(false); -		ensure("Other collector is empty", is_no_stats_map(sd)); -		sd = gViewerAssetStatsMain->asLLSD(false); +		LLSD sd = gViewerAssetStats->asLLSD(false);  		ensure("Correct single-key LLSD map root", is_double_key_map(sd, "regions", "duration"));  		ensure("Correct single-slot LLSD array regions", is_single_slot_array(sd["regions"], region1_handle));  		sd = get_region(sd, region1_handle); @@ -551,445 +548,14 @@ namespace tut  		// Reset and check zeros...  		// Reset leaves current region in place -		gViewerAssetStatsMain->reset(); -		sd = get_region(gViewerAssetStatsMain->asLLSD(false), region1_handle); +		gViewerAssetStats->reset(); +		sd = get_region(gViewerAssetStats->asLLSD(false), region1_handle);  		ensure("Region1 is present in results", sd.isMap()); -		delete gViewerAssetStatsMain; -		gViewerAssetStatsMain = NULL; -		delete gViewerAssetStatsThread1; -		gViewerAssetStatsThread1 = NULL; +		delete gViewerAssetStats; +		gViewerAssetStats = NULL;  		ensure_equals("sd[get_texture_non_temp_udp][enqueued] is reset", sd["get_texture_non_temp_udp"]["enqueued"].asInteger(), 0);  		ensure_equals("sd[get_gesture_udp][dequeued] is reset", sd["get_gesture_udp"]["dequeued"].asInteger(), 0);  	} - - -	// LLViewerAssetStats::merge() basic functions work -	template<> template<> -	void tst_viewerassetstats_index_object_t::test<9>() -	{ -		LLViewerAssetStats s1; -		LLViewerAssetStats s2; - -		s1.setRegion(region1_handle); -		s2.setRegion(region1_handle); - -		s1.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 5000000); -		s1.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 6000000); -		s1.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 8000000); -		s1.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 7000000); -		s1.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 9000000); -		 -		s2.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 2000000); -		s2.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 3000000); -		s2.recordGetServiced(LLViewerAssetType::AT_TEXTURE, true, true, 4000000); - -		s2.merge(s1); - -		LLSD s2_llsd = get_region(s2.asLLSD(false), region1_handle); -		ensure("Region1 is present in results", s2_llsd.isMap()); -		 -		ensure_equals("count after merge", s2_llsd["get_texture_temp_http"]["resp_count"].asInteger(), 8); -		ensure_approximately_equals("min after merge", s2_llsd["get_texture_temp_http"]["resp_min"].asReal(), 2.0, 22); -		ensure_approximately_equals("max after merge", s2_llsd["get_texture_temp_http"]["resp_max"].asReal(), 9.0, 22); -		ensure_approximately_equals("max after merge", s2_llsd["get_texture_temp_http"]["resp_mean"].asReal(), 5.5, 22); -	} - -	// LLViewerAssetStats::merge() basic functions work without corrupting source data -	template<> template<> -	void tst_viewerassetstats_index_object_t::test<10>() -	{ -		LLViewerAssetStats s1; -		LLViewerAssetStats s2; - -		s1.setRegion(region1_handle); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 23289200); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 282900); - -		 -		s2.setRegion(region2_handle); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 6500000); -		s2.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 10000); - -		{ -			s2.merge(s1); -			 -			LLSD src = s1.asLLSD(false); -			LLSD dst = s2.asLLSD(false); - -			ensure_equals("merge src has single region", src["regions"].size(), 1); -			ensure_equals("merge dst has dual regions", dst["regions"].size(), 2); -			 -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); -			dst["regions"][1].erase("duration"); - -			LLSD s1_llsd = get_region(src, region1_handle); -			ensure("Region1 is present in src", s1_llsd.isMap()); -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); - -			ensure("result from src is in dst", llsd_equals(s1_llsd, s2_llsd)); -		} - -		s1.setRegion(region1_handle); -		s2.setRegion(region1_handle); -		s1.reset(); -		s2.reset(); -		 -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 23289200); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 282900); - -		 -		s2.setRegion(region1_handle); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 6500000); -		s2.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 10000); - -		{ -			s2.merge(s1); -			 -			LLSD src = s1.asLLSD(false); -			LLSD dst = s2.asLLSD(false); - -			ensure_equals("merge src has single region (p2)", src["regions"].size(), 1); -			ensure_equals("merge dst has single region (p2)", dst["regions"].size(), 1); - -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); -			 -			LLSD s1_llsd = get_region(src, region1_handle); -			ensure("Region1 is present in src", s1_llsd.isMap()); -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); - -			ensure_equals("src counts okay (enq)", s1_llsd["get_other"]["enqueued"].asInteger(), 4); -			ensure_equals("src counts okay (deq)", s1_llsd["get_other"]["dequeued"].asInteger(), 4); -			ensure_equals("src resp counts okay", s1_llsd["get_other"]["resp_count"].asInteger(), 2); -			ensure_approximately_equals("src respmin okay", s1_llsd["get_other"]["resp_min"].asReal(), 0.2829, 20); -			ensure_approximately_equals("src respmax okay", s1_llsd["get_other"]["resp_max"].asReal(), 23.2892, 20); -			 -			ensure_equals("dst counts okay (enq)", s2_llsd["get_other"]["enqueued"].asInteger(), 12); -			ensure_equals("src counts okay (deq)", s2_llsd["get_other"]["dequeued"].asInteger(), 11); -			ensure_equals("dst resp counts okay", s2_llsd["get_other"]["resp_count"].asInteger(), 4); -			ensure_approximately_equals("dst respmin okay", s2_llsd["get_other"]["resp_min"].asReal(), 0.010, 20); -			ensure_approximately_equals("dst respmax okay", s2_llsd["get_other"]["resp_max"].asReal(), 23.2892, 20); -		} -	} - - -    // Maximum merges are interesting when one side contributes nothing -	template<> template<> -	void tst_viewerassetstats_index_object_t::test<11>() -	{ -		LLViewerAssetStats s1; -		LLViewerAssetStats s2; - -		s1.setRegion(region1_handle); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		// Want to test negative numbers here but have to work in U64 -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); - -		s2.setRegion(region1_handle); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		{ -			s2.merge(s1); -			 -			LLSD src = s1.asLLSD(false); -			LLSD dst = s2.asLLSD(false); - -			ensure_equals("merge src has single region", src["regions"].size(), 1); -			ensure_equals("merge dst has single region", dst["regions"].size(), 1); -			 -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); - -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); -			 -			ensure_equals("dst counts come from src only", s2_llsd["get_other"]["resp_count"].asInteger(), 3); - -			ensure_approximately_equals("dst maximum with count 0 does not contribute to merged maximum", -										s2_llsd["get_other"]["resp_max"].asReal(), F64(0.0), 20); -		} - -		// Other way around -		s1.setRegion(region1_handle); -		s2.setRegion(region1_handle); -		s1.reset(); -		s2.reset(); - -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		// Want to test negative numbers here but have to work in U64 -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 0); - -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		{ -			s1.merge(s2); -			 -			LLSD src = s2.asLLSD(false); -			LLSD dst = s1.asLLSD(false); - -			ensure_equals("merge src has single region", src["regions"].size(), 1); -			ensure_equals("merge dst has single region", dst["regions"].size(), 1); -			 -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); - -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); - -			ensure_equals("dst counts come from src only (flipped)", s2_llsd["get_other"]["resp_count"].asInteger(), 3); - -			ensure_approximately_equals("dst maximum with count 0 does not contribute to merged maximum (flipped)", -										s2_llsd["get_other"]["resp_max"].asReal(), F64(0.0), 20); -		} -	} - -    // Minimum merges are interesting when one side contributes nothing -	template<> template<> -	void tst_viewerassetstats_index_object_t::test<12>() -	{ -		LLViewerAssetStats s1; -		LLViewerAssetStats s2; - -		s1.setRegion(region1_handle); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 3800000); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 2700000); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 2900000); - -		s2.setRegion(region1_handle); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		{ -			s2.merge(s1); -			 -			LLSD src = s1.asLLSD(false); -			LLSD dst = s2.asLLSD(false); - -			ensure_equals("merge src has single region", src["regions"].size(), 1); -			ensure_equals("merge dst has single region", dst["regions"].size(), 1); -			 -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); - -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); - -			ensure_equals("dst counts come from src only", s2_llsd["get_other"]["resp_count"].asInteger(), 3); - -			ensure_approximately_equals("dst minimum with count 0 does not contribute to merged minimum", -										s2_llsd["get_other"]["resp_min"].asReal(), F64(2.7), 20); -		} - -		// Other way around -		s1.setRegion(region1_handle); -		s2.setRegion(region1_handle); -		s1.reset(); -		s2.reset(); - -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s1.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 3800000); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 2700000); -		s1.recordGetServiced(LLViewerAssetType::AT_LSL_BYTECODE, true, true, 2900000); - -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetEnqueued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); -		s2.recordGetDequeued(LLViewerAssetType::AT_LSL_BYTECODE, true, true); - -		{ -			s1.merge(s2); -			 -			LLSD src = s2.asLLSD(false); -			LLSD dst = s1.asLLSD(false); - -			ensure_equals("merge src has single region", src["regions"].size(), 1); -			ensure_equals("merge dst has single region", dst["regions"].size(), 1); -			 -			// Remove time stamps, they're a problem -			src.erase("duration"); -			src["regions"][0].erase("duration"); -			dst.erase("duration"); -			dst["regions"][0].erase("duration"); - -			LLSD s2_llsd = get_region(dst, region1_handle); -			ensure("Region1 is present in dst", s2_llsd.isMap()); - -			ensure_equals("dst counts come from src only (flipped)", s2_llsd["get_other"]["resp_count"].asInteger(), 3); - -			ensure_approximately_equals("dst minimum with count 0 does not contribute to merged minimum (flipped)", -										s2_llsd["get_other"]["resp_min"].asReal(), F64(2.7), 20); -		} -	} -  } diff --git a/indra/newview/tests/llxmlrpclistener_test.cpp b/indra/newview/tests/llxmlrpclistener_test.cpp index 20f913b670..6e9756e7d5 100755 --- a/indra/newview/tests/llxmlrpclistener_test.cpp +++ b/indra/newview/tests/llxmlrpclistener_test.cpp @@ -85,7 +85,7 @@ namespace tut      void object::test<1>()      {          set_test_name("request validation"); -        WrapLL_ERRS capture; +        WrapLLErrs capture;          LLSD request;          request["uri"] = uri;          std::string threw; @@ -93,7 +93,7 @@ namespace tut          {              pumps.obtain("LLXMLRPCTransaction").post(request);          } -        catch (const WrapLL_ERRS::FatalException& e) +        catch (const WrapLLErrs::FatalException& e)          {              threw = e.what();          } @@ -106,7 +106,7 @@ namespace tut      void object::test<2>()      {          set_test_name("param types validation"); -        WrapLL_ERRS capture; +        WrapLLErrs capture;          LLSD request;          request["uri"] = uri;          request["method"] = "hello"; @@ -118,7 +118,7 @@ namespace tut          {              pumps.obtain("LLXMLRPCTransaction").post(request);          } -        catch (const WrapLL_ERRS::FatalException& e) +        catch (const WrapLLErrs::FatalException& e)          {              threw = e.what();          } | 
