Skip to content

Commit

Permalink
Turned back on debug unit tests (flutter#42261)
Browse files Browse the repository at this point in the history
I refactored the `EXPECT_EXIT` tests since they are unsafe to execute in a process with multiple threads.

This leaves `flutter_desktop_darwin_unittests` disabled since it has existing issues.

fixes flutter/flutter#103757

[C++, Objective-C, Java style guides]: https://github.com/flutter/engine/blob/main/CONTRIBUTING.md#style
  • Loading branch information
gaaclarke authored May 23, 2023
1 parent 76afb43 commit aba9dc4
Show file tree
Hide file tree
Showing 6 changed files with 84 additions and 25 deletions.
2 changes: 1 addition & 1 deletion ci/builders/mac_host_engine.json
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@
"--variant",
"host_debug",
"--type",
"dart",
"dart,engine",
"--engine-capture-core-dump"
],
"script": "flutter/testing/run_tests.py"
Expand Down
57 changes: 50 additions & 7 deletions flow/frame_timings.cc
Original file line number Diff line number Diff line change
Expand Up @@ -103,32 +103,75 @@ size_t FrameTimingsRecorder::GetPictureCacheBytes() const {

void FrameTimingsRecorder::RecordVsync(fml::TimePoint vsync_start,
fml::TimePoint vsync_target) {
fml::Status status = RecordVsyncImpl(vsync_start, vsync_target);
FML_DCHECK(status.ok());
(void)status;
}

void FrameTimingsRecorder::RecordBuildStart(fml::TimePoint build_start) {
fml::Status status = RecordBuildStartImpl(build_start);
FML_DCHECK(status.ok());
(void)status;
}

void FrameTimingsRecorder::RecordBuildEnd(fml::TimePoint build_end) {
fml::Status status = RecordBuildEndImpl(build_end);
FML_DCHECK(status.ok());
(void)status;
}

void FrameTimingsRecorder::RecordRasterStart(fml::TimePoint raster_start) {
fml::Status status = RecordRasterStartImpl(raster_start);
FML_DCHECK(status.ok());
(void)status;
}

fml::Status FrameTimingsRecorder::RecordVsyncImpl(fml::TimePoint vsync_start,
fml::TimePoint vsync_target) {
std::scoped_lock state_lock(state_mutex_);
FML_DCHECK(state_ == State::kUninitialized);
if (state_ != State::kUninitialized) {
return fml::Status(fml::StatusCode::kFailedPrecondition,
"Check failed: state_ == State::kUninitialized.");
}
state_ = State::kVsync;
vsync_start_ = vsync_start;
vsync_target_ = vsync_target;
return fml::Status();
}

void FrameTimingsRecorder::RecordBuildStart(fml::TimePoint build_start) {
fml::Status FrameTimingsRecorder::RecordBuildStartImpl(
fml::TimePoint build_start) {
std::scoped_lock state_lock(state_mutex_);
FML_DCHECK(state_ == State::kVsync);
if (state_ != State::kVsync) {
return fml::Status(fml::StatusCode::kFailedPrecondition,
"Check failed: state_ == State::kVsync.");
}
state_ = State::kBuildStart;
build_start_ = build_start;
return fml::Status();
}

void FrameTimingsRecorder::RecordBuildEnd(fml::TimePoint build_end) {
fml::Status FrameTimingsRecorder::RecordBuildEndImpl(fml::TimePoint build_end) {
std::scoped_lock state_lock(state_mutex_);
FML_DCHECK(state_ == State::kBuildStart);
if (state_ != State::kBuildStart) {
return fml::Status(fml::StatusCode::kFailedPrecondition,
"Check failed: state_ == State::kBuildStart.");
}
state_ = State::kBuildEnd;
build_end_ = build_end;
return fml::Status();
}

void FrameTimingsRecorder::RecordRasterStart(fml::TimePoint raster_start) {
fml::Status FrameTimingsRecorder::RecordRasterStartImpl(
fml::TimePoint raster_start) {
std::scoped_lock state_lock(state_mutex_);
FML_DCHECK(state_ == State::kBuildEnd);
if (state_ != State::kBuildEnd) {
return fml::Status(fml::StatusCode::kFailedPrecondition,
"Check failed: state_ == State::kBuildEnd.");
}
state_ = State::kRasterStart;
raster_start_ = raster_start;
return fml::Status();
}

FrameTiming FrameTimingsRecorder::RecordRasterEnd(const RasterCache* cache) {
Expand Down
11 changes: 11 additions & 0 deletions flow/frame_timings.h
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#include "flutter/common/settings.h"
#include "flutter/flow/raster_cache.h"
#include "flutter/fml/macros.h"
#include "flutter/fml/status.h"
#include "flutter/fml/time/time_delta.h"
#include "flutter/fml/time/time_point.h"

Expand Down Expand Up @@ -114,6 +115,16 @@ class FrameTimingsRecorder {
FrameTiming GetRecordedTime() const;

private:
FML_FRIEND_TEST(FrameTimingsRecorderTest, ThrowWhenRecordBuildBeforeVsync);
FML_FRIEND_TEST(FrameTimingsRecorderTest,
ThrowWhenRecordRasterBeforeBuildEnd);

[[nodiscard]] fml::Status RecordVsyncImpl(fml::TimePoint vsync_start,
fml::TimePoint vsync_target);
[[nodiscard]] fml::Status RecordBuildStartImpl(fml::TimePoint build_start);
[[nodiscard]] fml::Status RecordBuildEndImpl(fml::TimePoint build_end);
[[nodiscard]] fml::Status RecordRasterStartImpl(fml::TimePoint raster_start);

static std::atomic<uint64_t> frame_number_gen_;

mutable std::mutex state_mutex_;
Expand Down
19 changes: 9 additions & 10 deletions flow/frame_timings_recorder_unittests.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,21 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include <thread>
#include "flutter/flow/frame_timings.h"
#include "flutter/flow/testing/layer_test.h"
#include "flutter/flow/testing/mock_layer.h"
#include "flutter/flow/testing/mock_raster_cache.h"
#include "third_party/skia/include/core/SkPictureRecorder.h"

#include <thread>

#include "flutter/fml/time/time_delta.h"
#include "flutter/fml/time/time_point.h"

#include "gtest/gtest.h"

namespace flutter {
namespace testing {

using testing::MockRasterCache;

TEST(FrameTimingsRecorderTest, RecordVsync) {
auto recorder = std::make_unique<FrameTimingsRecorder>();
Expand Down Expand Up @@ -130,9 +130,9 @@ TEST(FrameTimingsRecorderTest, ThrowWhenRecordBuildBeforeVsync) {
auto recorder = std::make_unique<FrameTimingsRecorder>();

const auto build_start = fml::TimePoint::Now();
EXPECT_EXIT(recorder->RecordBuildStart(build_start),
::testing::KilledBySignal(SIGABRT),
"Check failed: state_ == State::kVsync.");
fml::Status status = recorder->RecordBuildStartImpl(build_start);
EXPECT_FALSE(status.ok());
EXPECT_EQ(status.message(), "Check failed: state_ == State::kVsync.");
}

TEST(FrameTimingsRecorderTest, ThrowWhenRecordRasterBeforeBuildEnd) {
Expand All @@ -143,9 +143,9 @@ TEST(FrameTimingsRecorderTest, ThrowWhenRecordRasterBeforeBuildEnd) {
recorder->RecordVsync(st, en);

const auto raster_start = fml::TimePoint::Now();
EXPECT_EXIT(recorder->RecordRasterStart(raster_start),
::testing::KilledBySignal(SIGABRT),
"Check failed: state_ == State::kBuildEnd.");
fml::Status status = recorder->RecordRasterStartImpl(raster_start);
EXPECT_FALSE(status.ok());
EXPECT_EQ(status.message(), "Check failed: state_ == State::kBuildEnd.");
}

#endif
Expand Down Expand Up @@ -297,5 +297,4 @@ TEST(FrameTimingsRecorderTest, FrameNumberTraceArgIsValid) {
ASSERT_EQ(actual_arg, expected_arg);
}

} // namespace testing
} // namespace flutter
3 changes: 3 additions & 0 deletions fml/macros.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,4 +38,7 @@
TypeName() = delete; \
FML_DISALLOW_COPY_ASSIGN_AND_MOVE(TypeName)

#define FML_FRIEND_TEST(test_case_name, test_name) \
friend class test_case_name##_##test_name##_Test

#endif // FLUTTER_FML_MACROS_H_
17 changes: 10 additions & 7 deletions testing/run_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -471,13 +471,16 @@ def make_test(name, flags=None, extra_env=None):
# flutter_desktop_darwin_unittests uses global state that isn't handled
# correctly by gtest-parallel.
# https://github.com/flutter/flutter/issues/104789
run_engine_executable(
build_dir,
'flutter_desktop_darwin_unittests',
executable_filter,
shuffle_flags,
coverage=coverage
)
if not os.path.basename(build_dir).startswith('host_debug'):
# Test is disabled for flaking in debug runs:
# https://github.com/flutter/flutter/issues/127441
run_engine_executable(
build_dir,
'flutter_desktop_darwin_unittests',
executable_filter,
shuffle_flags,
coverage=coverage
)
extra_env = {
# pylint: disable=line-too-long
# See https://developer.apple.com/documentation/metal/diagnosing_metal_programming_issues_early?language=objc
Expand Down

0 comments on commit aba9dc4

Please sign in to comment.