diff options
author | Dalai Felinto <dfelinto@gmail.com> | 2017-06-15 14:46:52 +0300 |
---|---|---|
committer | Dalai Felinto <dfelinto@gmail.com> | 2017-06-15 14:47:14 +0300 |
commit | 32cd8ac71065857ef5f638c4840d3422be531a9e (patch) | |
tree | 869913f82623f99bcad8a26b2e579af01192ccae /tests | |
parent | 830df9b33d3e2afdf3bb23b469378899c34fda78 (diff) |
Layers: Scene copy should copy selection as well.
We need this for Depsgraph, otherwise CoW scene will have different selection properties.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/python/render_layer/CMakeLists.txt | 1 | ||||
-rw-r--r-- | tests/python/render_layer/test_scene_copy_e.py | 52 |
2 files changed, 53 insertions, 0 deletions
diff --git a/tests/python/render_layer/CMakeLists.txt b/tests/python/render_layer/CMakeLists.txt index 9d19985000d..526b169bc3d 100644 --- a/tests/python/render_layer/CMakeLists.txt +++ b/tests/python/render_layer/CMakeLists.txt @@ -169,4 +169,5 @@ RENDER_LAYER_TEST(scene_copy_a) RENDER_LAYER_TEST(scene_copy_b) RENDER_LAYER_TEST(scene_copy_c) RENDER_LAYER_TEST(scene_copy_d) +RENDER_LAYER_TEST(scene_copy_e) RENDER_LAYER_TEST(scene_write_read) diff --git a/tests/python/render_layer/test_scene_copy_e.py b/tests/python/render_layer/test_scene_copy_e.py new file mode 100644 index 00000000000..350729d14e0 --- /dev/null +++ b/tests/python/render_layer/test_scene_copy_e.py @@ -0,0 +1,52 @@ +# ############################################################ +# Importing - Same For All Render Layer Tests +# ############################################################ + +import unittest +import os +import sys + +from render_layer_common import * + + +# ############################################################ +# Testing +# ############################################################ + +class UnitTesting(RenderLayerTesting): + def test_shared_layer_collections_copy_full(self): + """ + See if scene copying 'FULL_COPY' is working for scene collections + with a shared object + """ + import os + import bpy + + scene = bpy.context.scene + layer = bpy.context.render_layer + + original_cube = layer.objects.get('Cube') + original_cube.select_set('SELECT') + self.assertTrue(original_cube.select_get()) + + bpy.ops.scene.new(type='FULL_COPY') + new_layer = bpy.context.render_layer + + self.assertNotEqual(layer, new_layer) + new_cube = new_layer.objects.get('Cube.001') + self.assertNotEqual(original_cube, new_cube) + self.assertTrue(new_cube.select_get()) + + +# ############################################################ +# Main - Same For All Render Layer Tests +# ############################################################ + +if __name__ == '__main__': + import sys + + extra_arguments = sys.argv[sys.argv.index("--") + 1:] if "--" in sys.argv else [] + sys.argv = [__file__] + (sys.argv[sys.argv.index("--") + 2:] if "--" in sys.argv else []) + + UnitTesting._extra_arguments = extra_arguments + unittest.main() |