123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- /*
- * Copyright (c) Contributors to the Open 3D Engine Project.
- * For complete copyright and license terms please see the LICENSE at the root of this distribution.
- *
- * SPDX-License-Identifier: Apache-2.0 OR MIT
- *
- */
- #include "ApplicationManagerTests.h"
- #include <QCoreApplication>
- #include <tests/assetmanager/MockAssetProcessorManager.h>
- #include <tests/assetmanager/MockFileProcessor.h>
- #include <AzToolsFramework/Archive/ArchiveComponent.h>
- #include <native/FileWatcher/FileWatcher.h>
- #include <native/utilities/AssetServerHandler.h>
- #include <native/resourcecompiler/rcjob.h>
- #include <AzCore/Utils/Utils.h>
- #include <AzCore/Settings/SettingsRegistryImpl.h>
- #include <unittests/UnitTestUtils.h>
- namespace UnitTests
- {
- void ApplicationManagerTest::SetUp()
- {
- LeakDetectionFixture::SetUp();
- AZ::IO::Path assetRootDir(m_databaseLocationListener.GetAssetRootDir());
- // We need a QCoreApplication to run the event loop
- int argc = 0;
- m_coreApplication = AZStd::make_unique<QCoreApplication>(argc, nullptr);
- m_applicationManager = AZStd::make_unique<MockBatchApplicationManager>(&argc, nullptr);
- m_applicationManager->m_platformConfiguration = new AssetProcessor::PlatformConfiguration{ nullptr };
- m_applicationManager->m_fileStateCache = AZStd::make_unique<AssetProcessor::FileStateCache>();
- m_mockAPM = AZStd::make_unique<MockAssetProcessorManager>(m_applicationManager->m_platformConfiguration, nullptr);
- m_applicationManager->m_assetProcessorManager = m_mockAPM.get();
- AZStd::vector<AssetBuilderSDK::PlatformInfo> platforms;
- m_applicationManager->m_platformConfiguration->EnablePlatform(AssetBuilderSDK::PlatformInfo{ "pc", { "tag" } });
- m_applicationManager->m_platformConfiguration->PopulatePlatformsForScanFolder(platforms);
- m_applicationManager->m_platformConfiguration->AddScanFolder(
- AssetProcessor::ScanFolderInfo{ assetRootDir.c_str(), "test", "test", true, true, platforms });
- m_apmThread = AZStd::make_unique<QThread>(nullptr);
- m_apmThread->setObjectName("APM Thread");
- m_applicationManager->m_assetProcessorManager->moveToThread(m_apmThread.get());
- m_apmThread->start();
- m_fileProcessorThread = AZStd::make_unique<QThread>(nullptr);
- m_fileProcessorThread->setObjectName("File Processor Thread");
- auto fileProcessor = AZStd::make_unique<MockFileProcessor>(m_applicationManager->m_platformConfiguration);
- fileProcessor->moveToThread(m_fileProcessorThread.get());
- m_mockFileProcessor = fileProcessor.get();
- m_applicationManager->m_fileProcessor = AZStd::move(fileProcessor); // The manager is taking ownership
- m_fileProcessorThread->start();
- m_applicationManager->InitUuidManager();
- auto fileWatcher = AZStd::make_unique<FileWatcher>();
- m_fileWatcher = fileWatcher.get();
- // This is what we're testing, it will set up connections between the fileWatcher and the 2 QObject handlers we'll check
- m_applicationManager->InitFileMonitor(AZStd::move(fileWatcher)); // The manager is going to take ownership of the file watcher
- m_applicationManager->InitUuidManager();
- }
- void ApplicationManagerTest::TearDown()
- {
- m_applicationManager->DestroyFileMonitor();
- m_apmThread->quit();
- m_fileProcessorThread->quit();
- m_apmThread->wait();
- m_fileProcessorThread->wait();
- m_mockAPM = nullptr;
- LeakDetectionFixture::TearDown();
- }
- using BatchApplicationManagerTest = ::UnitTest::LeakDetectionFixture;
- TEST_F(ApplicationManagerTest, FileWatcherEventsTriggered_ProperlySignalledOnCorrectThread_SUITE_sandbox)
- {
- AZ::IO::Path assetRootDir(m_databaseLocationListener.GetAssetRootDir());
- Q_EMIT m_fileWatcher->fileAdded((assetRootDir / "test").c_str());
- Q_EMIT m_fileWatcher->fileModified((assetRootDir / "test2").c_str());
- Q_EMIT m_fileWatcher->fileRemoved((assetRootDir / "test3").c_str());
- EXPECT_TRUE(m_mockAPM->m_events[Added].WaitAndCheck()) << "APM Added event failed";
- EXPECT_TRUE(m_mockAPM->m_events[Modified].WaitAndCheck()) << "APM Modified event failed";
- EXPECT_TRUE(m_mockAPM->m_events[Deleted].WaitAndCheck()) << "APM Deleted event failed";
- EXPECT_TRUE(m_mockFileProcessor->m_events[Added].WaitAndCheck()) << "File Processor Added event failed";
- EXPECT_TRUE(m_mockFileProcessor->m_events[Deleted].WaitAndCheck()) << "File Processor Deleted event failed";
- }
- TEST(AssetProcessorAZApplicationTest, AssetProcessorAZApplication_ArchiveComponent_Exists)
- {
- int argc = 0;
- AssetProcessorAZApplication assetProcessorAZApplication {&argc, nullptr};
- auto componentList = assetProcessorAZApplication.GetRequiredSystemComponents();
- auto iterator = AZStd::find(componentList.begin(), componentList.end(), azrtti_typeid<AzToolsFramework::ArchiveComponent>());
- EXPECT_NE(iterator, componentList.end()) << "AzToolsFramework::ArchiveComponent is not a required component";
- }
- TEST(AssetProcessorAssetServerHandler, AssetServerHandler_FutureCalls_FailsNoExceptions)
- {
- char executablePath[AZ_MAX_PATH_LEN];
- AZ::Utils::GetExecutablePath(executablePath, AZ_MAX_PATH_LEN);
- struct MockAssetServerInfoBus final
- : public AssetProcessor::AssetServerInfoBus::Handler
- {
- explicit MockAssetServerInfoBus(const char* filename)
- : m_filename(filename)
- {
- AssetProcessor::AssetServerInfoBus::Handler::BusConnect();
- }
- ~MockAssetServerInfoBus()
- {
- AssetProcessor::AssetServerInfoBus::Handler::BusDisconnect();
- }
- const AZStd::string& ComputeArchiveFilePath(const AssetProcessor::BuilderParams&) override
- {
- return m_filename;
- }
- AZStd::string m_filename;
- };
- AssetProcessor::JobDetails jobDetails;
- jobDetails.m_jobEntry.m_sourceFileUUID = AZ::Uuid::CreateRandom();
- jobDetails.m_checkServer = true;
- AssetProcessor::RCJob rcJob;
- rcJob.Init(jobDetails);
- AssetProcessor::BuilderParams buildParams { &rcJob };
- buildParams.m_processJobRequest.m_sourceFile = executablePath;
- buildParams.m_serverKey = "fake.product";
- // These should fail, but not throw an exception
- // mock storing an archive
- {
- MockAssetServerInfoBus mockAssetServerInfoBus("fake.asset");
- AssetProcessor::AssetServerHandler assetServerHandler{};
- AZStd::vector<AZStd::string> files({ buildParams.m_serverKey.toUtf8().toStdString().c_str() });
- EXPECT_FALSE(assetServerHandler.StoreJobResult(buildParams, files));
- }
- // mock retrieving an archive
- {
- MockAssetServerInfoBus mockAssetServerInfoBus(executablePath);
- AssetProcessor::AssetServerHandler assetServerHandler{};
- EXPECT_FALSE(assetServerHandler.RetrieveJobResult(buildParams));
- }
- }
- }
|