blob: 5f55c2fa615197f1a008ad4389a51947f8485b16 [file] [log] [blame]
Austin Schuh812d0d12021-11-04 20:16:48 -07001// Copyright (c) FIRST and other WPILib contributors.
2// Open Source Software; you can modify and/or share it under the terms of
3// the WPILib BSD license file in the root directory of this project.
Brian Silverman8fce7482020-01-05 13:18:21 -08004
5#include "frc/Watchdog.h" // NOLINT(build/include_order)
6
7#include <stdint.h>
8
Austin Schuh1e69f942020-11-14 15:06:14 -08009#include "frc/simulation/SimHooks.h"
Brian Silverman8fce7482020-01-05 13:18:21 -080010#include "gtest/gtest.h"
11
12using namespace frc;
13
Austin Schuh1e69f942020-11-14 15:06:14 -080014namespace {
15class WatchdogTest : public ::testing::Test {
16 protected:
17 void SetUp() override { frc::sim::PauseTiming(); }
18
19 void TearDown() override { frc::sim::ResumeTiming(); }
20};
21
22} // namespace
23
24TEST_F(WatchdogTest, EnableDisable) {
Brian Silverman8fce7482020-01-05 13:18:21 -080025 uint32_t watchdogCounter = 0;
26
27 Watchdog watchdog(0.4_s, [&] { watchdogCounter++; });
28
Austin Schuh1e69f942020-11-14 15:06:14 -080029 // Run 1
Brian Silverman8fce7482020-01-05 13:18:21 -080030 watchdog.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -080031 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080032 watchdog.Disable();
33
34 EXPECT_EQ(0u, watchdogCounter) << "Watchdog triggered early";
35
Austin Schuh1e69f942020-11-14 15:06:14 -080036 // Run 2
Brian Silverman8fce7482020-01-05 13:18:21 -080037 watchdogCounter = 0;
38 watchdog.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -080039 frc::sim::StepTiming(0.4_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080040 watchdog.Disable();
41
42 EXPECT_EQ(1u, watchdogCounter)
43 << "Watchdog either didn't trigger or triggered more than once";
44
Austin Schuh1e69f942020-11-14 15:06:14 -080045 // Run 3
Brian Silverman8fce7482020-01-05 13:18:21 -080046 watchdogCounter = 0;
47 watchdog.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -080048 frc::sim::StepTiming(1_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080049 watchdog.Disable();
50
51 EXPECT_EQ(1u, watchdogCounter)
52 << "Watchdog either didn't trigger or triggered more than once";
53}
54
Austin Schuh1e69f942020-11-14 15:06:14 -080055TEST_F(WatchdogTest, Reset) {
Brian Silverman8fce7482020-01-05 13:18:21 -080056 uint32_t watchdogCounter = 0;
57
58 Watchdog watchdog(0.4_s, [&] { watchdogCounter++; });
59
60 watchdog.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -080061 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080062 watchdog.Reset();
Austin Schuh1e69f942020-11-14 15:06:14 -080063 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080064 watchdog.Disable();
65
66 EXPECT_EQ(0u, watchdogCounter) << "Watchdog triggered early";
67}
68
Austin Schuh1e69f942020-11-14 15:06:14 -080069TEST_F(WatchdogTest, SetTimeout) {
Brian Silverman8fce7482020-01-05 13:18:21 -080070 uint32_t watchdogCounter = 0;
71
Austin Schuh1e69f942020-11-14 15:06:14 -080072 Watchdog watchdog(1_s, [&] { watchdogCounter++; });
Brian Silverman8fce7482020-01-05 13:18:21 -080073
74 watchdog.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -080075 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080076 watchdog.SetTimeout(0.2_s);
77
Austin Schuh812d0d12021-11-04 20:16:48 -070078 EXPECT_EQ(0.2_s, watchdog.GetTimeout());
Brian Silverman8fce7482020-01-05 13:18:21 -080079 EXPECT_EQ(0u, watchdogCounter) << "Watchdog triggered early";
80
Austin Schuh1e69f942020-11-14 15:06:14 -080081 frc::sim::StepTiming(0.3_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080082 watchdog.Disable();
83
84 EXPECT_EQ(1u, watchdogCounter)
85 << "Watchdog either didn't trigger or triggered more than once";
86}
87
Austin Schuh1e69f942020-11-14 15:06:14 -080088TEST_F(WatchdogTest, IsExpired) {
Brian Silverman8fce7482020-01-05 13:18:21 -080089 Watchdog watchdog(0.2_s, [] {});
90 EXPECT_FALSE(watchdog.IsExpired());
91 watchdog.Enable();
92
93 EXPECT_FALSE(watchdog.IsExpired());
Austin Schuh1e69f942020-11-14 15:06:14 -080094 frc::sim::StepTiming(0.3_s);
Brian Silverman8fce7482020-01-05 13:18:21 -080095 EXPECT_TRUE(watchdog.IsExpired());
96
97 watchdog.Disable();
98 EXPECT_TRUE(watchdog.IsExpired());
99
100 watchdog.Reset();
101 EXPECT_FALSE(watchdog.IsExpired());
102}
103
Austin Schuh1e69f942020-11-14 15:06:14 -0800104TEST_F(WatchdogTest, Epochs) {
Brian Silverman8fce7482020-01-05 13:18:21 -0800105 uint32_t watchdogCounter = 0;
106
107 Watchdog watchdog(0.4_s, [&] { watchdogCounter++; });
108
Austin Schuh1e69f942020-11-14 15:06:14 -0800109 // Run 1
Brian Silverman8fce7482020-01-05 13:18:21 -0800110 watchdog.Enable();
111 watchdog.AddEpoch("Epoch 1");
Austin Schuh1e69f942020-11-14 15:06:14 -0800112 frc::sim::StepTiming(0.1_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800113 watchdog.AddEpoch("Epoch 2");
Austin Schuh1e69f942020-11-14 15:06:14 -0800114 frc::sim::StepTiming(0.1_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800115 watchdog.AddEpoch("Epoch 3");
116 watchdog.Disable();
117
118 EXPECT_EQ(0u, watchdogCounter) << "Watchdog triggered early";
119
Austin Schuh1e69f942020-11-14 15:06:14 -0800120 // Run 2
Brian Silverman8fce7482020-01-05 13:18:21 -0800121 watchdog.Enable();
122 watchdog.AddEpoch("Epoch 1");
Austin Schuh1e69f942020-11-14 15:06:14 -0800123 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800124 watchdog.Reset();
Austin Schuh1e69f942020-11-14 15:06:14 -0800125 frc::sim::StepTiming(0.2_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800126 watchdog.AddEpoch("Epoch 2");
127 watchdog.Disable();
128
129 EXPECT_EQ(0u, watchdogCounter) << "Watchdog triggered early";
130}
131
Austin Schuh1e69f942020-11-14 15:06:14 -0800132TEST_F(WatchdogTest, MultiWatchdog) {
Brian Silverman8fce7482020-01-05 13:18:21 -0800133 uint32_t watchdogCounter1 = 0;
134 uint32_t watchdogCounter2 = 0;
135
136 Watchdog watchdog1(0.2_s, [&] { watchdogCounter1++; });
137 Watchdog watchdog2(0.6_s, [&] { watchdogCounter2++; });
138
139 watchdog2.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -0800140 frc::sim::StepTiming(0.25_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800141 EXPECT_EQ(0u, watchdogCounter1) << "Watchdog triggered early";
142 EXPECT_EQ(0u, watchdogCounter2) << "Watchdog triggered early";
143
144 // Sleep enough such that only the watchdog enabled later times out first
145 watchdog1.Enable();
Austin Schuh1e69f942020-11-14 15:06:14 -0800146 frc::sim::StepTiming(0.25_s);
Brian Silverman8fce7482020-01-05 13:18:21 -0800147 watchdog1.Disable();
148 watchdog2.Disable();
149
150 EXPECT_EQ(1u, watchdogCounter1)
151 << "Watchdog either didn't trigger or triggered more than once";
152 EXPECT_EQ(0u, watchdogCounter2) << "Watchdog triggered early";
153}