Files
UnrealEngineUWP/Engine/Source/Runtime/AutomationWorker/Private/AutomationWorkerModule.h
Richard TalbotWatkin 36e63cd46d Various fixes for in-game / in-editor screenshot.
#jira UE-14213 - Using the command "highresshot" will corrupt future screenshots until game is relaunched

Summary of changes:
- Editor now no longer relies on the delegate registered by the AutomationWorkerModule to save the image as a .png.
- Removed the OnPNGScreenshotCaptured delegate as it was only being used by the AutomationWorkerModule, and made .png the default format for saving screenshots.
- AutomationWorkerModule registers a HandlePreTestingEvent and HandlePostTestingEvent with the AutomationTestFramework, whose purpose is to hook in to the UGameViewportClient::OnScreenshotCaptured delegate, to override the default screenshot capture behaviour.
- Removed one of the FScreenshotRequest::RequestScreenshot implementations and united the funcionality to be able to specify whether the UI should be captured, and whether a unique filename suffix should be added to the supplied name.

[CL 2528072 by Richard TalbotWatkin in Main branch]
2015-04-28 02:55:47 -04:00

136 lines
4.0 KiB
C++

// Copyright 1998-2015 Epic Games, Inc. All Rights Reserved.
#pragma once
/**
* Implements the Automation Worker module.
*/
class FAutomationWorkerModule
: public IAutomationWorkerModule
{
public:
// Begin IModuleInterface interface
virtual void StartupModule() override;
virtual void ShutdownModule() override;
virtual bool SupportsDynamicReloading() override;
// End IModuleInterface interface
public:
// Begin IAutomationWorkerModule interface
virtual void Tick() override;
virtual void RunTest( const FString& InTestToRun, const int32 InRoleIndex, FStopTestEvent const& InStopTestEvent ) override;
// End IAutomationWorkerModule interface
protected:
/**
* Execute all latent commands and when complete send results message back to the automation controller
*/
bool ExecuteLatentCommands();
/**
* Execute all network commands and when complete send results message back to the automation controller
*/
bool ExecuteNetworkCommands();
/**
* Initializes the automation worker.
*/
void Initialize();
/**
* Network phase is complete (if there were any network commands). Send ping back to the controller
*/
void ReportNetworkCommandComplete();
/**
* Test is complete. Send results back to controller
*/
void ReportTestComplete();
/**
* Send a list of all the tests supported by the worker
*
* @param ControllerAddress The message address of the controller that requested the tests.
*/
void SendTests( const FMessageAddress& ControllerAddress );
private:
// Handles FAutomationWorkerFindWorkers messages.
void HandleFindWorkersMessage( const FAutomationWorkerFindWorkers& Message, const IMessageContextRef& Context );
// Handles message endpoint shutdowns.
void HandleMessageEndpointShutdown();
// Handles FAutomationWorkerNextNetworkCommandReply messages.
void HandleNextNetworkCommandReplyMessage( const FAutomationWorkerNextNetworkCommandReply& Message, const IMessageContextRef& Context );
// Handles FAutomationWorkerPing messages.
void HandlePingMessage( const FAutomationWorkerPing& Message, const IMessageContextRef& Context );
// Handles FAutomationWorkerResetTests messages.
void HandleResetTests( const FAutomationWorkerResetTests& Message, const IMessageContextRef& Context );
// Handles FAutomationWorkerRequestTests messages.
void HandleRequestTestsMessage( const FAutomationWorkerRequestTests& Message, const IMessageContextRef& Context );
// Handles FAutomationWorkerRunTests messages.
void HandleRunTestsMessage( const FAutomationWorkerRunTests& Message, const IMessageContextRef& Context );
// Handles FAutomationTestFramework PreTestingEvents.
void HandlePreTestingEvent();
// Handles FAutomationTestFramework PostTestingEvents.
void HandlePostTestingEvent();
#if WITH_ENGINE
/** Invoked when we have screen shot to send. */
void HandleScreenShotCaptured(int32 Width, int32 Height, const TArray<FColor>& Bitmap);
void HandleScreenShotCapturedWithName(int32 Width, int32 Height, const TArray<FColor>& Bitmap, const FString& ScreenShotName);
#endif
private:
// The collection of test data we are to send to a controller
TArray<FAutomationTestInfo> TestInfo;
private:
/** Holds the messaging endpoint. */
FMessageEndpointPtr MessageEndpoint;
/** Message address of the controller sending the test request. */
FMessageAddress TestRequesterAddress;
/** Identifier for the controller to know if the results should be discarded or not. */
uint32 ExecutionCount;
/** Execute one of the tests by request of the controller. */
FString TestName;
/** Whether the controller has requested that the network command should execute */
bool bExecuteNextNetworkCommand;
/** Whether we are processing sub-commands of a network command */
bool bExecutingNetworkCommandResults;
/** Delegate to fire when the test is complete */
FStopTestEvent StopTestEvent;
// Holds the automation command line arguments.
TArray<FString> DeferredAutomationCommands;
// Cycles through and executes the automation commands in the deferred array.
void RunDeferredAutomationCommands();
};