SphereTests.cpp 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * Copyright (c) Contributors to the Open 3D Engine Project.
  3. * For complete copyright and license terms please see the LICENSE at the root of this distribution.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0 OR MIT
  6. *
  7. */
  8. #include <AzCore/Math/Sphere.h>
  9. #include <AzCore/UnitTest/TestTypes.h>
  10. #include <AZTestShared/Math/MathTestHelpers.h>
  11. namespace UnitTest
  12. {
  13. TEST(MATH_Sphere, TestCreateUnitSphere)
  14. {
  15. AZ::Sphere unitSphere = AZ::Sphere::CreateUnitSphere();
  16. EXPECT_THAT(unitSphere.GetCenter(), IsClose(AZ::Vector3::CreateZero()));
  17. EXPECT_NEAR(unitSphere.GetRadius(), 1.f, 0.0001f);
  18. }
  19. TEST(MATH_Sphere, TestCreateFromAabb)
  20. {
  21. AZ::Aabb testBox = AZ::Aabb::CreateFromMinMax(AZ::Vector3(-1.0f), AZ::Vector3(1.0f));
  22. AZ::Sphere testSphere = AZ::Sphere::CreateFromAabb(testBox);
  23. EXPECT_THAT(testSphere.GetCenter(), IsClose(AZ::Vector3::CreateZero()));
  24. EXPECT_NEAR(testSphere.GetRadius(), 1.f, 0.0001f);
  25. }
  26. TEST(MATH_Sphere, TestConstructFromVec3AndRadius)
  27. {
  28. AZ::Sphere sphere1(AZ::Vector3(10.f, 10.f, 10.f), 15.f);
  29. EXPECT_THAT(sphere1.GetCenter(), IsClose(AZ::Vector3(10.f, 10.f, 10.f)));
  30. EXPECT_NEAR(sphere1.GetRadius(), 15.f, 0.0001f);
  31. }
  32. TEST(MATH_Sphere, TestSet)
  33. {
  34. AZ::Sphere sphere1(AZ::Vector3(10.f, 10.f, 10.f), 15.f);
  35. AZ::Sphere sphere2(AZ::Vector3(12.f, 12.f, 12.f), 13.f);
  36. EXPECT_NE(sphere2, sphere1);
  37. sphere1.Set(sphere2);
  38. EXPECT_EQ(sphere2, sphere1);
  39. }
  40. TEST(MATH_Sphere, TestSetCenterAndRadius)
  41. {
  42. AZ::Sphere sphere2(AZ::Vector3(12.f, 12.f, 12.f), 13.f);
  43. AZ::Sphere sphere3(AZ::Vector3(10.f, 10.f, 10.f), 15.f);
  44. sphere3.SetCenter(AZ::Vector3(12.f, 12.f, 12.f));
  45. sphere3.SetRadius(13.f);
  46. EXPECT_EQ(sphere2, sphere3);
  47. }
  48. TEST(MATH_Sphere, TestAssignment)
  49. {
  50. AZ::Sphere unitSphere = AZ::Sphere::CreateUnitSphere();
  51. AZ::Sphere sphere2(AZ::Vector3(12.f, 12.f, 12.f), 13.f);
  52. sphere2 = unitSphere;
  53. EXPECT_EQ(sphere2, unitSphere);
  54. }
  55. TEST(MATH_Sphere, TestCopyConstructor)
  56. {
  57. AZ::Sphere unitSphere = AZ::Sphere::CreateUnitSphere();
  58. AZ::Sphere sphere2(unitSphere);
  59. EXPECT_EQ(sphere2, unitSphere);
  60. }
  61. } // namespace UnitTest