|
1 | 1 | #include <scratchcpp/project.h> |
2 | 2 | #include <scratchcpp/sprite.h> |
| 3 | +#include <scratchcpp/stage.h> |
3 | 4 | #include <scratchcpp/compiler.h> |
4 | 5 | #include <scratchcpp/script.h> |
5 | 6 | #include <scratchcpp/thread.h> |
|
9 | 10 | #include <gtest/gtest.h> |
10 | 11 |
|
11 | 12 | #include "penlayer.h" |
| 13 | +#include "spritemodel.h" |
| 14 | +#include "stagemodel.h" |
| 15 | +#include "renderedtarget.h" |
12 | 16 | #include "blocks/penblocks.h" |
13 | 17 |
|
14 | 18 | using namespace scratchcpprender; |
@@ -70,3 +74,45 @@ TEST_F(PenBlocksTest, Clear) |
70 | 74 | EXPECT_CALL(m_engineMock, requestRedraw()); |
71 | 75 | thread->run(); |
72 | 76 | } |
| 77 | + |
| 78 | +TEST_F(PenBlocksTest, Stamp_Sprite) |
| 79 | +{ |
| 80 | + auto sprite = std::make_shared<Sprite>(); |
| 81 | + sprite->setEngine(&m_engineMock); |
| 82 | + |
| 83 | + RenderedTarget renderedTarget; |
| 84 | + SpriteModel model; |
| 85 | + model.init(sprite.get()); |
| 86 | + model.setRenderedTarget(&renderedTarget); |
| 87 | + sprite->setInterface(&model); |
| 88 | + |
| 89 | + ScriptBuilder builder(m_extension.get(), m_engine, sprite); |
| 90 | + builder.addBlock("pen_stamp"); |
| 91 | + |
| 92 | + auto thread = buildScript(builder, sprite.get()); |
| 93 | + |
| 94 | + EXPECT_CALL(m_penLayer, stamp(&renderedTarget)); |
| 95 | + EXPECT_CALL(m_engineMock, requestRedraw()); |
| 96 | + thread->run(); |
| 97 | +} |
| 98 | + |
| 99 | +TEST_F(PenBlocksTest, Stamp_Stage) |
| 100 | +{ |
| 101 | + auto stage = std::make_shared<Stage>(); |
| 102 | + stage->setEngine(&m_engineMock); |
| 103 | + |
| 104 | + RenderedTarget renderedTarget; |
| 105 | + StageModel model; |
| 106 | + model.init(stage.get()); |
| 107 | + model.setRenderedTarget(&renderedTarget); |
| 108 | + stage->setInterface(&model); |
| 109 | + |
| 110 | + ScriptBuilder builder(m_extension.get(), m_engine, stage); |
| 111 | + builder.addBlock("pen_stamp"); |
| 112 | + |
| 113 | + auto thread = buildScript(builder, stage.get()); |
| 114 | + |
| 115 | + EXPECT_CALL(m_penLayer, stamp(&renderedTarget)); |
| 116 | + EXPECT_CALL(m_engineMock, requestRedraw()); |
| 117 | + thread->run(); |
| 118 | +} |
0 commit comments