mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-19 08:37:54 +01:00

Running clang-format with chromium's style guide. The goal is n-fold: * providing consistency and readability (that's what code guidelines are for) * preventing noise with presubmit checks and git cl format * building on the previous point: making it easier to automatically fix format issues * you name it Please consider using git-hyper-blame to ignore this commit. Bug: webrtc:9340 Change-Id: I694567c4cdf8cee2860958cfe82bfaf25848bb87 Reviewed-on: https://webrtc-review.googlesource.com/81185 Reviewed-by: Patrik Höglund <phoglund@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23660}
95 lines
3 KiB
C++
95 lines
3 KiB
C++
/*
|
|
* Copyright (c) 2013 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#include <memory>
|
|
|
|
#include "modules/desktop_capture/desktop_capture_options.h"
|
|
#include "modules/desktop_capture/desktop_capturer.h"
|
|
#include "modules/desktop_capture/desktop_frame.h"
|
|
#include "modules/desktop_capture/desktop_region.h"
|
|
#include "test/gtest.h"
|
|
|
|
namespace webrtc {
|
|
|
|
class WindowCapturerTest : public testing::Test,
|
|
public DesktopCapturer::Callback {
|
|
public:
|
|
void SetUp() override {
|
|
capturer_ = DesktopCapturer::CreateWindowCapturer(
|
|
DesktopCaptureOptions::CreateDefault());
|
|
RTC_DCHECK(capturer_);
|
|
}
|
|
|
|
void TearDown() override {}
|
|
|
|
// DesktopCapturer::Callback interface
|
|
void OnCaptureResult(DesktopCapturer::Result result,
|
|
std::unique_ptr<DesktopFrame> frame) override {
|
|
frame_ = std::move(frame);
|
|
}
|
|
|
|
protected:
|
|
std::unique_ptr<DesktopCapturer> capturer_;
|
|
std::unique_ptr<DesktopFrame> frame_;
|
|
};
|
|
|
|
// Verify that we can enumerate windows.
|
|
TEST_F(WindowCapturerTest, Enumerate) {
|
|
DesktopCapturer::SourceList sources;
|
|
EXPECT_TRUE(capturer_->GetSourceList(&sources));
|
|
|
|
// Verify that window titles are set.
|
|
for (auto it = sources.begin(); it != sources.end(); ++it) {
|
|
EXPECT_FALSE(it->title.empty());
|
|
}
|
|
}
|
|
|
|
// Flaky on Linux. See: crbug.com/webrtc/7830
|
|
#if defined(WEBRTC_LINUX)
|
|
#define MAYBE_Capture DISABLED_Capture
|
|
#else
|
|
#define MAYBE_Capture Capture
|
|
#endif
|
|
// Verify we can capture a window.
|
|
//
|
|
// TODO(sergeyu): Currently this test just looks at the windows that already
|
|
// exist. Ideally it should create a test window and capture from it, but there
|
|
// is no easy cross-platform way to create new windows (potentially we could
|
|
// have a python script showing Tk dialog, but launching code will differ
|
|
// between platforms).
|
|
TEST_F(WindowCapturerTest, MAYBE_Capture) {
|
|
DesktopCapturer::SourceList sources;
|
|
capturer_->Start(this);
|
|
EXPECT_TRUE(capturer_->GetSourceList(&sources));
|
|
|
|
// Verify that we can select and capture each window.
|
|
for (auto it = sources.begin(); it != sources.end(); ++it) {
|
|
frame_.reset();
|
|
if (capturer_->SelectSource(it->id)) {
|
|
capturer_->CaptureFrame();
|
|
}
|
|
|
|
// If we failed to capture a window make sure it no longer exists.
|
|
if (!frame_.get()) {
|
|
DesktopCapturer::SourceList new_list;
|
|
EXPECT_TRUE(capturer_->GetSourceList(&new_list));
|
|
for (auto new_list_it = new_list.begin(); new_list_it != new_list.end();
|
|
++new_list_it) {
|
|
EXPECT_FALSE(it->id == new_list_it->id);
|
|
}
|
|
continue;
|
|
}
|
|
|
|
EXPECT_GT(frame_->size().width(), 0);
|
|
EXPECT_GT(frame_->size().height(), 0);
|
|
}
|
|
}
|
|
|
|
} // namespace webrtc
|