3
0

AudioEngineWwiseTest.cpp 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  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/PlatformIncl.h>
  9. #include <AzTest/AzTest.h>
  10. #include <AzCore/IO/Path/Path.h>
  11. #include <AzCore/Component/ComponentApplicationBus.h>
  12. #include <AzCore/StringFunc/StringFunc.h>
  13. #include <AzCore/UnitTest/TestTypes.h>
  14. #include <AzCore/UserSettings/UserSettingsComponent.h>
  15. #include <AzFramework/IO/LocalFileIO.h>
  16. #include <AzFramework/Application/Application.h>
  17. #include <AudioSystemImpl_wwise.h>
  18. #include <AudioEngineWwise_Traits_Platform.h>
  19. #include <Config_wwise.h>
  20. #include <AK/SoundEngine/Common/AkSoundEngine.h>
  21. #include <AK/SoundEngine/Common/AkMemoryMgr.h>
  22. #include <AK/SoundEngine/Common/AkModule.h>
  23. #include <platform.h>
  24. #include <Mocks/IConsoleMock.h>
  25. #include <Mocks/ISystemMock.h>
  26. using namespace Audio;
  27. using ::testing::NiceMock;
  28. namespace UnitTest
  29. {
  30. class WwiseTestEnvironment
  31. : public AZ::Test::ITestEnvironment
  32. {
  33. public:
  34. WwiseTestEnvironment() = default;
  35. ~WwiseTestEnvironment() override = default;
  36. protected:
  37. struct MockHolder
  38. {
  39. NiceMock<ConsoleMock> m_console;
  40. NiceMock<SystemMock> m_system;
  41. };
  42. void SetupEnvironment() override
  43. {
  44. // Setup Mocks on a stub environment
  45. m_mocks = new MockHolder();
  46. m_stubEnv.pConsole = &m_mocks->m_console;
  47. m_stubEnv.pSystem = &m_mocks->m_system;
  48. gEnv = &m_stubEnv;
  49. }
  50. void TeardownEnvironment() override
  51. {
  52. delete m_mocks;
  53. m_mocks = nullptr;
  54. }
  55. private:
  56. SSystemGlobalEnvironment m_stubEnv;
  57. MockHolder* m_mocks = nullptr;
  58. };
  59. class AudioSystemImplWwiseTests
  60. : public ::testing::Test
  61. {
  62. protected:
  63. AudioSystemImplWwiseTests()
  64. : m_wwiseImpl("")
  65. {}
  66. void SetUp() override
  67. {
  68. #if !AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  69. // Init Wwise
  70. AkMemSettings memSettings;
  71. AK::MemoryMgr::GetDefaultSettings(memSettings);
  72. AK::MemoryMgr::Init(&memSettings);
  73. AkStreamMgrSettings strmSettings;
  74. AK::StreamMgr::GetDefaultSettings(strmSettings);
  75. AK::StreamMgr::Create(strmSettings);
  76. AkInitSettings initSettings;
  77. AK::SoundEngine::GetDefaultInitSettings(initSettings);
  78. AkPlatformInitSettings platSettings;
  79. AK::SoundEngine::GetDefaultPlatformInitSettings(platSettings);
  80. AK::SoundEngine::Init(&initSettings, &platSettings);
  81. #endif // !AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  82. }
  83. void TearDown() override
  84. {
  85. #if !AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  86. // Term Wwise
  87. AK::SoundEngine::Term();
  88. AK::IAkStreamMgr::Get()->Destroy();
  89. AK::MemoryMgr::Term();
  90. #endif // !AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  91. }
  92. CAudioSystemImpl_wwise m_wwiseImpl;
  93. };
  94. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  95. TEST_F(AudioSystemImplWwiseTests, DISABLED_WwiseSanityTest)
  96. #else
  97. TEST_F(AudioSystemImplWwiseTests, WwiseSanityTest)
  98. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  99. {
  100. // Tests that Setup/TearDown work as expected
  101. }
  102. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  103. TEST_F(AudioSystemImplWwiseTests, DISABLED_WwiseMultiPosition_GoodData)
  104. #else
  105. TEST_F(AudioSystemImplWwiseTests, WwiseMultiPosition_GoodData)
  106. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  107. {
  108. SATLAudioObjectData_wwise wwiseObject(1, true);
  109. MultiPositionParams params;
  110. params.m_positions.push_back(AZ::Vector3(1.f, 2.f, 3.f));
  111. params.m_type = MultiPositionBehaviorType::Blended;
  112. auto result = m_wwiseImpl.SetMultiplePositions(&wwiseObject, params);
  113. EXPECT_EQ(result, EAudioRequestStatus::Success);
  114. }
  115. #if AZ_TRAIT_AUDIOENGINEWWISE_DISABLE_MULTIPOSITION_TESTS
  116. TEST_F(AudioSystemImplWwiseTests, DISABLED_WwiseMultiPosition_BadObject)
  117. #else
  118. TEST_F(AudioSystemImplWwiseTests, WwiseMultiPosition_BadObject)
  119. #endif
  120. {
  121. MultiPositionParams params;
  122. params.m_positions.push_back(AZ::Vector3(1.f, 2.f, 3.f));
  123. params.m_type = MultiPositionBehaviorType::Separate;
  124. auto result = m_wwiseImpl.SetMultiplePositions(nullptr, params);
  125. EXPECT_EQ(result, EAudioRequestStatus::Failure);
  126. }
  127. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  128. TEST_F(AudioSystemImplWwiseTests, DISABLED_WwiseMultiPosition_ZeroPositions)
  129. #else
  130. TEST_F(AudioSystemImplWwiseTests, WwiseMultiPosition_ZeroPositions)
  131. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  132. {
  133. SATLAudioObjectData_wwise wwiseObject(1, true);
  134. MultiPositionParams params;
  135. auto result = m_wwiseImpl.SetMultiplePositions(&wwiseObject, params);
  136. EXPECT_EQ(result, EAudioRequestStatus::Success);
  137. }
  138. class AudioSystemImpl_wwise_Test
  139. : public CAudioSystemImpl_wwise
  140. {
  141. public:
  142. explicit AudioSystemImpl_wwise_Test(const char* assetPlatform)
  143. : CAudioSystemImpl_wwise(assetPlatform)
  144. {}
  145. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  146. friend class GTEST_TEST_CLASS_NAME_(AudioSystemImplWwiseConfigTests, DISABLED_WwiseSetBankPaths_NonDefaultPath_PathMatches);
  147. friend class GTEST_TEST_CLASS_NAME_(AudioSystemImplWwiseConfigTests, DISABLED_WwiseSetBankPaths_NoInitBnk_DefaultPath);
  148. #else
  149. friend class GTEST_TEST_CLASS_NAME_(AudioSystemImplWwiseConfigTests, WwiseSetBankPaths_NonDefaultPath_PathMatches);
  150. friend class GTEST_TEST_CLASS_NAME_(AudioSystemImplWwiseConfigTests, WwiseSetBankPaths_NoInitBnk_DefaultPath);
  151. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  152. };
  153. class AudioSystemImplWwiseConfigTests
  154. : public ::testing::Test
  155. {
  156. protected:
  157. AudioSystemImplWwiseConfigTests()
  158. : m_wwiseImpl("")
  159. {
  160. }
  161. void SetUp() override
  162. {
  163. m_app.Start(AZ::ComponentApplication::Descriptor());
  164. // Without this, the user settings component would attempt to save on finalize/shutdown. Since the file is
  165. // shared across the whole engine, if multiple tests are run in parallel, the saving could cause a crash
  166. // shared across the whole engine, if multiple tests are run in parallel, the saving could cause a crash
  167. // in the unit tests.
  168. AZ::UserSettingsComponentRequestBus::Broadcast(&AZ::UserSettingsComponentRequests::DisableSaveOnFinalize);
  169. // Store and remove the existing fileIO...
  170. m_prevFileIO = AZ::IO::FileIOBase::GetInstance();
  171. if (m_prevFileIO)
  172. {
  173. AZ::IO::FileIOBase::SetInstance(nullptr);
  174. }
  175. // Replace with a new LocalFileIO...
  176. m_fileIO = AZStd::make_unique<AZ::IO::LocalFileIO>();
  177. AZ::IO::FileIOBase::SetInstance(m_fileIO.get());
  178. // Reflect the wwise config settings...
  179. AZ::SerializeContext* serializeContext = nullptr;
  180. AZ::ComponentApplicationBus::BroadcastResult(serializeContext, &AZ::ComponentApplicationBus::Events::GetSerializeContext);
  181. AZ_TEST_ASSERT(serializeContext != nullptr);
  182. Audio::Wwise::ConfigurationSettings::Reflect(serializeContext);
  183. // Set the @products@ alias to the path where *this* cpp file lives.
  184. AZStd::string rootFolder(AZ::Test::GetCurrentExecutablePath());
  185. AZ::StringFunc::Path::Join(rootFolder.c_str(), "Test.Assets/Gems/AudioEngineWwise", rootFolder);
  186. m_fileIO->SetAlias("@products@", rootFolder.c_str());
  187. // So we don't have to compute it in each test...
  188. AZStd::string defaultBanksPath(Audio::Wwise::DefaultBanksPath);
  189. m_configFilePath = AZStd::string::format("%s/%s%s", rootFolder.c_str(), defaultBanksPath.c_str(), Audio::Wwise::ConfigFile);
  190. }
  191. void TearDown() override
  192. {
  193. // Destroy our LocalFileIO...
  194. m_fileIO.reset();
  195. // Replace the old fileIO (set instance to null first)...
  196. AZ::IO::FileIOBase::SetInstance(nullptr);
  197. if (m_prevFileIO)
  198. {
  199. AZ::IO::FileIOBase::SetInstance(m_prevFileIO);
  200. m_prevFileIO = nullptr;
  201. }
  202. m_app.Stop();
  203. }
  204. AZStd::unique_ptr<AZ::IO::LocalFileIO> m_fileIO;
  205. AZStd::string m_configFilePath;
  206. Audio::Wwise::ConfigurationSettings::PlatformMapping m_mapEntry;
  207. AudioSystemImpl_wwise_Test m_wwiseImpl;
  208. private:
  209. AzFramework::Application m_app;
  210. AZ::IO::FileIOBase* m_prevFileIO { nullptr };
  211. };
  212. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  213. TEST_F(AudioSystemImplWwiseConfigTests, DISABLED_WwiseSetBankPaths_NonDefaultPath_PathMatches)
  214. #else
  215. TEST_F(AudioSystemImplWwiseConfigTests, WwiseSetBankPaths_NonDefaultPath_PathMatches)
  216. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  217. {
  218. // The mapping here points to a custom directory that exists (and contains an init.bnk).
  219. // The custom bank path should be set.
  220. Audio::Wwise::ConfigurationSettings config;
  221. m_mapEntry.m_enginePlatform = AZ_TRAIT_OS_PLATFORM_NAME;
  222. m_mapEntry.m_bankSubPath = "soundbanks";
  223. config.m_platformMappings.push_back(m_mapEntry);
  224. config.Save(m_configFilePath);
  225. m_wwiseImpl.SetBankPaths();
  226. m_fileIO->Remove(m_configFilePath.c_str());
  227. EXPECT_STREQ(m_wwiseImpl.m_soundbankFolder.c_str(), "sounds/wwise/soundbanks/");
  228. }
  229. #if AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  230. TEST_F(AudioSystemImplWwiseConfigTests, DISABLED_WwiseSetBankPaths_NoInitBnk_DefaultPath)
  231. #else
  232. TEST_F(AudioSystemImplWwiseConfigTests, WwiseSetBankPaths_NoInitBnk_DefaultPath)
  233. #endif // AZ_TRAIT_DISABLE_FAILED_AUDIO_WWISE_TESTS
  234. {
  235. // The mapping here points to a directory that does not exist (and doesn't contain init.bnk).
  236. // The default bank path should be set.
  237. Audio::Wwise::ConfigurationSettings config;
  238. m_mapEntry.m_enginePlatform = AZ_TRAIT_OS_PLATFORM_NAME;
  239. m_mapEntry.m_bankSubPath = "no_soundbanks";
  240. config.m_platformMappings.push_back(m_mapEntry);
  241. config.Save(m_configFilePath);
  242. m_wwiseImpl.SetBankPaths();
  243. m_fileIO->Remove(m_configFilePath.c_str());
  244. EXPECT_STREQ(m_wwiseImpl.m_soundbankFolder.c_str(), Audio::Wwise::DefaultBanksPath);
  245. }
  246. } // namespace UnitTest
  247. AZ_UNIT_TEST_HOOK(new UnitTest::WwiseTestEnvironment);