blob: 82d13f126d0b22b70da8015f943b998f720aacc2 [file] [log] [blame]
Avi Drissmane4622aa2022-09-08 20:36:061// Copyright 2019 The Chromium Authors
Alan Cutter9b0e1ab2019-03-21 04:22:162// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "base/debug/task_trace.h"
6
7#include <ostream>
8
Keishi Hattori0e45c022021-11-27 09:25:529#include "base/memory/raw_ptr.h"
Ali Hijazia8877892022-11-10 20:51:0310#include "base/memory/raw_ref.h"
Alan Cutter9b0e1ab2019-03-21 04:22:1611#include "base/run_loop.h"
Sean Mahere672a662023-01-09 21:42:2812#include "base/task/single_thread_task_runner.h"
Guido Urdanetaef4e91942020-11-09 15:06:2413#include "base/test/bind.h"
Gabriel Charettec7108742019-08-23 03:31:4014#include "base/test/task_environment.h"
Alan Cutter9b0e1ab2019-03-21 04:22:1615#include "testing/gtest/include/gtest/gtest.h"
16
Peter Kasting811504a72025-01-09 03:18:5017namespace base::debug {
Alan Cutter9b0e1ab2019-03-21 04:22:1618
19TEST(TaskTraceTest, NoTask) {
20 TaskTrace task_trace;
21 EXPECT_TRUE(task_trace.empty());
Mark Brand82fbec842023-01-18 15:39:4622 std::array<const void*, 4> addresses = {0};
23 EXPECT_EQ(task_trace.GetAddresses(addresses), 0ul);
Alan Cutter9b0e1ab2019-03-21 04:22:1624}
25
26class ThreeTasksTest {
27 public:
Sorin Jianu1ed1f6c2024-09-28 00:31:4028 ThreeTasksTest() = default;
Alan Cutter9b0e1ab2019-03-21 04:22:1629
30 void Run() {
Ali Hijazia8877892022-11-10 20:51:0331 task_runner->PostTask(FROM_HERE, base::BindOnce(&ThreeTasksTest::TaskA,
32 base::Unretained(this)));
Alan Cutter9b0e1ab2019-03-21 04:22:1633 task_environment.RunUntilIdle();
34 }
35
36 void TaskA() {
37 TaskTrace task_trace;
38 EXPECT_FALSE(task_trace.empty());
Mark Brand82fbec842023-01-18 15:39:4639 std::array<const void*, 4> addresses = {0};
40 EXPECT_EQ(task_trace.GetAddresses(addresses), 1ul);
Alan Cutter9b0e1ab2019-03-21 04:22:1641 task_a_address = addresses[0];
Ali Hijazia8877892022-11-10 20:51:0342 task_runner->PostTask(FROM_HERE, base::BindOnce(&ThreeTasksTest::TaskB,
43 base::Unretained(this)));
Alan Cutter9b0e1ab2019-03-21 04:22:1644 }
45
46 void TaskB() {
47 TaskTrace task_trace;
48 EXPECT_FALSE(task_trace.empty());
Mark Brand82fbec842023-01-18 15:39:4649 std::array<const void*, 4> addresses = {0};
50 EXPECT_EQ(task_trace.GetAddresses(addresses), 2ul);
Alan Cutter9b0e1ab2019-03-21 04:22:1651 task_b_address = addresses[0];
52 EXPECT_EQ(addresses[1], task_a_address);
Ali Hijazia8877892022-11-10 20:51:0353 task_runner->PostTask(FROM_HERE, base::BindOnce(&ThreeTasksTest::TaskC,
54 base::Unretained(this)));
Alan Cutter9b0e1ab2019-03-21 04:22:1655 }
56
57 void TaskC() {
58 TaskTrace task_trace;
59 EXPECT_FALSE(task_trace.empty());
Mark Brand82fbec842023-01-18 15:39:4660 std::array<const void*, 4> addresses;
61 EXPECT_EQ(task_trace.GetAddresses(addresses), 3ul);
Alan Cutter9b0e1ab2019-03-21 04:22:1662 EXPECT_EQ(addresses[1], task_b_address);
63 EXPECT_EQ(addresses[2], task_a_address);
64 }
65
66 private:
Gabriel Charette694c3c332019-08-19 14:53:0567 base::test::TaskEnvironment task_environment;
Ali Hijazia8877892022-11-10 20:51:0368 const raw_ref<base::SingleThreadTaskRunner> task_runner{
69 *task_environment.GetMainThreadTaskRunner()};
Alan Cutter9b0e1ab2019-03-21 04:22:1670
Keishi Hattori0e45c022021-11-27 09:25:5271 raw_ptr<const void> task_a_address = nullptr;
72 raw_ptr<const void> task_b_address = nullptr;
Alan Cutter9b0e1ab2019-03-21 04:22:1673};
74
75TEST(TaskTraceTest, ThreeTasks) {
76 ThreeTasksTest().Run();
77}
78
Peter Kasting811504a72025-01-09 03:18:5079} // namespace base::debug