// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ash/webui/annotator/untrusted_annotator_page_handler_impl.h"
#include "ash/public/cpp/annotator/annotator_tool.h"
#include "ash/public/cpp/test/mock_annotator_controller.h"
#include "ash/webui/annotator/mojom/untrusted_annotator.mojom.h"
#include "ash/webui/annotator/public/mojom/annotator_structs.mojom.h"
#include "ash/webui/annotator/test/mock_annotator_client.h"
#include "ash/webui/annotator/test/mock_untrusted_annotator_page.h"
#include "base/test/task_environment.h"
#include "base/values.h"
#include "content/public/test/test_web_ui.h"
#include "mojo/public/cpp/bindings/receiver.h"
#include "mojo/public/cpp/bindings/remote.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "third_party/skia/include/core/SkColor.h"
namespace ash {
class UntrustedAnnotatorPageHandlerImplTest : public testing::Test {
public:
UntrustedAnnotatorPageHandlerImplTest() = default;
UntrustedAnnotatorPageHandlerImplTest(
const UntrustedAnnotatorPageHandlerImplTest&) = delete;
UntrustedAnnotatorPageHandlerImplTest& operator=(
const UntrustedAnnotatorPageHandlerImplTest&) = delete;
~UntrustedAnnotatorPageHandlerImplTest() override = default;
// testing::Test:
void SetUp() override {
annotator_ = std::make_unique<MockUntrustedAnnotatorPage>();
handler_ = std::make_unique<UntrustedAnnotatorPageHandlerImpl>(
annotator().remote().BindNewPipeAndPassReceiver(),
annotator().receiver().BindNewPipeAndPassRemote(),
/*web_ui=*/nullptr);
}
void TearDown() override {
annotator_.reset();
handler_.reset();
}
UntrustedAnnotatorPageHandlerImpl& handler() { return *handler_; }
MockAnnotatorController& controller() { return controller_; }
MockUntrustedAnnotatorPage& annotator() { return *annotator_; }
base::test::SingleThreadTaskEnvironment& task_environment() {
return task_environment_;
}
private:
base::test::SingleThreadTaskEnvironment task_environment_;
std::unique_ptr<MockUntrustedAnnotatorPage> annotator_;
std::unique_ptr<UntrustedAnnotatorPageHandlerImpl> handler_;
MockAnnotatorController controller_;
MockAnnotatorClient client_;
};
TEST_F(UntrustedAnnotatorPageHandlerImplTest, SetTool) {
AnnotatorTool expected_tool;
expected_tool.color = SkColorSetARGB(0xA1, 0xB2, 0xC3, 0xD4);
expected_tool.size = 5;
expected_tool.type = AnnotatorToolType::kPen;
EXPECT_CALL(annotator(), SetTool)
.WillOnce(testing::Invoke([&](annotator::mojom::AnnotatorToolPtr tool) {
EXPECT_EQ(tool->size, expected_tool.size);
EXPECT_EQ(tool->tool, expected_tool.GetToolString());
EXPECT_EQ(tool->color, expected_tool.GetColorHexString());
}));
handler().SetTool(expected_tool);
annotator().FlushReceiverForTesting();
}
TEST_F(UntrustedAnnotatorPageHandlerImplTest, Undo) {
EXPECT_CALL(annotator(), Undo());
handler().Undo();
annotator().FlushReceiverForTesting();
}
TEST_F(UntrustedAnnotatorPageHandlerImplTest, Redo) {
EXPECT_CALL(annotator(), Redo());
handler().Redo();
annotator().FlushReceiverForTesting();
}
TEST_F(UntrustedAnnotatorPageHandlerImplTest, Clear) {
EXPECT_CALL(annotator(), Clear());
handler().Clear();
annotator().FlushReceiverForTesting();
}
TEST_F(UntrustedAnnotatorPageHandlerImplTest, UndoRedoAvailabilityChanged) {
EXPECT_CALL(controller(), OnUndoRedoAvailabilityChanged(false, false));
annotator().SendUndoRedoAvailableChanged(false, false);
EXPECT_CALL(controller(), OnUndoRedoAvailabilityChanged(true, true));
annotator().SendUndoRedoAvailableChanged(true, true);
EXPECT_CALL(controller(), OnUndoRedoAvailabilityChanged(false, true));
annotator().SendUndoRedoAvailableChanged(false, true);
annotator().FlushRemoteForTesting();
}
TEST_F(UntrustedAnnotatorPageHandlerImplTest, CanvasInitialized) {
EXPECT_CALL(controller(), OnCanvasInitialized(true));
annotator().SendCanvasInitialized(true);
EXPECT_CALL(controller(), OnCanvasInitialized(false));
annotator().SendCanvasInitialized(false);
annotator().FlushRemoteForTesting();
}
} // namespace ash