diff options
author | Sybren A. Stüvel <sybren@blender.org> | 2021-10-21 17:23:50 +0300 |
---|---|---|
committer | Sybren A. Stüvel <sybren@blender.org> | 2021-10-21 17:23:56 +0300 |
commit | 16c79d3b8276493a5ce70e74d50cf066f64894c2 (patch) | |
tree | fa09919ea2fe254cdeb4473a3c436621c6f7ff32 /source/blender/blenkernel/intern/asset_catalog_test.cc | |
parent | ff46afb4dd3e04f22640a5f2e49e75ed088e3a93 (diff) |
Asset Catalogs: add test for backslashed catalog paths
No functional changes necessary, test already succeeds.
Diffstat (limited to 'source/blender/blenkernel/intern/asset_catalog_test.cc')
-rw-r--r-- | source/blender/blenkernel/intern/asset_catalog_test.cc | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/source/blender/blenkernel/intern/asset_catalog_test.cc b/source/blender/blenkernel/intern/asset_catalog_test.cc index ebb282a7371..b41fa0fe833 100644 --- a/source/blender/blenkernel/intern/asset_catalog_test.cc +++ b/source/blender/blenkernel/intern/asset_catalog_test.cc @@ -300,6 +300,26 @@ TEST_F(AssetCatalogTest, load_single_file) EXPECT_EQ("Another Ružena", another_ruzena->simple_name); } +TEST_F(AssetCatalogTest, load_catalog_path_backslashes) +{ + AssetCatalogService service(asset_library_root_); + service.load_from_disk(asset_library_root_ + "/" + "blender_assets.cats.txt"); + + const bUUID ELLIE_BACKSLASHES_UUID("a51e17ae-34fc-47d5-ba0f-64c2c9b771f7"); + const AssetCatalog *found_by_id = service.find_catalog(ELLIE_BACKSLASHES_UUID); + ASSERT_NE(nullptr, found_by_id); + EXPECT_EQ(AssetCatalogPath("character/Ellie/backslashes"), found_by_id->path) + << "Backslashes should be normalised when loading from disk."; + EXPECT_EQ(StringRefNull("Windows For Life!"), found_by_id->simple_name); + + const AssetCatalog *found_by_path = service.find_catalog_by_path("character/Ellie/backslashes"); + EXPECT_EQ(found_by_id, found_by_path) + << "Catalog with backslashed path should be findable by the normalized path."; + + EXPECT_EQ(nullptr, service.find_catalog_by_path("character\\Ellie\\backslashes")) + << "Nothing should be found when searching for backslashes."; +} + TEST_F(AssetCatalogTest, is_first_loaded_flag) { AssetCatalogService service(asset_library_root_); @@ -413,6 +433,7 @@ TEST_F(AssetCatalogTest, load_single_file_into_tree) std::vector<AssetCatalogPath> expected_paths{ "character", "character/Ellie", + "character/Ellie/backslashes", "character/Ellie/poselib", "character/Ellie/poselib/tailslash", "character/Ellie/poselib/white space", @@ -759,6 +780,7 @@ TEST_F(AssetCatalogTest, delete_catalog_leaf) std::vector<AssetCatalogPath> expected_paths{ "character", "character/Ellie", + "character/Ellie/backslashes", "character/Ellie/poselib", "character/Ellie/poselib/tailslash", "character/Ellie/poselib/white space", @@ -795,7 +817,8 @@ TEST_F(AssetCatalogTest, delete_catalog_parent_by_path) service.load_from_disk(asset_library_root_ + "/" + "blender_assets.cats.txt"); /* Create an extra catalog with the to-be-deleted path, and one with a child of that. - * This creates some duplicates that are bound to occur in production asset libraries as well. */ + * This creates some duplicates that are bound to occur in production asset libraries as well. + */ const bUUID cat1_uuid = service.create_catalog("character/Ružena/poselib")->catalog_id; const bUUID cat2_uuid = service.create_catalog("character/Ružena/poselib/body")->catalog_id; @@ -814,6 +837,7 @@ TEST_F(AssetCatalogTest, delete_catalog_parent_by_path) std::vector<AssetCatalogPath> expected_paths{ "character", "character/Ellie", + "character/Ellie/backslashes", "character/Ellie/poselib", "character/Ellie/poselib/tailslash", "character/Ellie/poselib/white space", @@ -889,9 +913,9 @@ TEST_F(AssetCatalogTest, update_catalog_path_simple_name) AssetCatalogService::DEFAULT_CATALOG_FILENAME); service.update_catalog_path(UUID_POSES_RUZENA, "charlib/Ružena"); - /* This may not be valid forever; maybe at some point we'll expose the simple name to users & let - * them change it from the UI. Until then, automatically updating it is better, because otherwise - * all simple names would be "Catalog". */ + /* This may not be valid forever; maybe at some point we'll expose the simple name to users & + * let them change it from the UI. Until then, automatically updating it is better, because + * otherwise all simple names would be "Catalog". */ EXPECT_EQ("charlib-Ružena", service.find_catalog(UUID_POSES_RUZENA)->simple_name) << "Changing the path should update the simplename."; EXPECT_EQ("charlib-Ružena-face", service.find_catalog(UUID_POSES_RUZENA_FACE)->simple_name) |