rendering: split managed default backend from fallback pipeline
This commit is contained in:
@@ -4825,8 +4825,19 @@ TEST(
|
||||
ASSERT_NE(host, nullptr);
|
||||
EXPECT_EQ(
|
||||
host->GetPipelineBackendAsset(),
|
||||
Internal::CreateDefaultPipelineBackendAsset().get());
|
||||
Internal::CreateDefaultSceneDrawBackendAsset().get());
|
||||
EXPECT_NE(host->GetPipelineBackend(), nullptr);
|
||||
auto* backendPipeline =
|
||||
dynamic_cast<RenderPipeline*>(host->GetPipelineBackend());
|
||||
ASSERT_NE(backendPipeline, nullptr);
|
||||
EXPECT_EQ(
|
||||
backendPipeline->GetCameraFrameStandalonePass(
|
||||
CameraFrameStage::DepthOnly),
|
||||
nullptr);
|
||||
EXPECT_EQ(
|
||||
backendPipeline->GetCameraFrameStandalonePass(
|
||||
CameraFrameStage::ShadowCaster),
|
||||
nullptr);
|
||||
EXPECT_NE(host->GetStageRecorder(), nullptr);
|
||||
EXPECT_EQ(runtimeState->getPipelineRendererAssetCalls, 0);
|
||||
|
||||
@@ -4882,6 +4893,32 @@ TEST(
|
||||
nullptr);
|
||||
}
|
||||
|
||||
TEST(
|
||||
DefaultSceneDrawBackendAsset_Test,
|
||||
CreatesSceneOnlyPipelineWithoutFallbackStandalonePasses) {
|
||||
const std::shared_ptr<const RenderPipelineAsset> backendAsset =
|
||||
Internal::CreateDefaultSceneDrawBackendAsset();
|
||||
ASSERT_NE(backendAsset, nullptr);
|
||||
|
||||
std::unique_ptr<RenderPipeline> pipeline = backendAsset->CreatePipeline();
|
||||
ASSERT_NE(pipeline, nullptr);
|
||||
|
||||
auto* sceneDrawBackend =
|
||||
dynamic_cast<SceneDrawBackend*>(pipeline.get());
|
||||
ASSERT_NE(sceneDrawBackend, nullptr);
|
||||
SceneRenderFeatureHost* const featureHost =
|
||||
sceneDrawBackend->GetSceneFeatureHost();
|
||||
ASSERT_NE(featureHost, nullptr);
|
||||
EXPECT_EQ(featureHost->GetFeaturePassCount(), 2u);
|
||||
|
||||
EXPECT_EQ(
|
||||
pipeline->GetCameraFrameStandalonePass(CameraFrameStage::DepthOnly),
|
||||
nullptr);
|
||||
EXPECT_EQ(
|
||||
pipeline->GetCameraFrameStandalonePass(CameraFrameStage::ShadowCaster),
|
||||
nullptr);
|
||||
}
|
||||
|
||||
TEST(ManagedScriptableRenderPipelineAsset_Test, LetsManagedBridgeConfigureCameraRenderRequests) {
|
||||
Pipelines::ClearManagedRenderPipelineBridge();
|
||||
|
||||
|
||||
Reference in New Issue
Block a user