rendering: split managed default backend from fallback pipeline

This commit is contained in:
2026-04-26 12:24:34 +08:00
parent b7bf11001f
commit 2ccebb3488
4 changed files with 65 additions and 2 deletions

View File

@@ -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();