/* * Copyright 2009, Google Inc. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * * Neither the name of Google Inc. nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "tests/common/win/testing_common.h" #include "core/cross/matrix4_composition.h" #include "core/cross/math_utilities.h" #include "core/cross/object_manager.h" #include "core/cross/pack.h" #include "core/cross/service_dependency.h" namespace o3d { class Matrix4CompositionTest : public testing::Test { protected: Matrix4CompositionTest() : object_manager_(g_service_locator), pack_(NULL), composition_(NULL) { } virtual void SetUp() { pack_ = object_manager_->CreatePack(); composition_ = pack_->Create(); } virtual void TearDown() { pack_->Destroy(); } protected: ServiceDependency object_manager_; Pack* pack_; Matrix4Composition* composition_; }; TEST_F(Matrix4CompositionTest, OutputsInputMatrixIfNoParent) { Matrix4 input = Matrix4::scale(Vector3(2, 3, 4)); composition_->set_local_matrix(input); Matrix4 output_matrix = composition_->output_matrix(); ASSERT_NEAR(0.0f, FrobeniusNorm(input - output_matrix), 0.001f); } TEST_F(Matrix4CompositionTest, ComposesInputMatrixWithParentMatrix) { Matrix4 input = Matrix4::scale(Vector3(2, 3, 4)); composition_->set_local_matrix(input); Matrix4 parent = Matrix4::scale(Vector3(3, 4, 5)); composition_->set_input_matrix(parent); Matrix4 output_matrix = composition_->output_matrix(); Matrix4 expected = Matrix4::scale(Vector3(6, 12, 20)); ASSERT_NEAR(0.0f, FrobeniusNorm(expected - output_matrix), 0.001f); } } // namespace o3d