network_manager: Make it possible to reload without refresh
Change-Id: I2bef32285cd620c93914907eb74864c5801258bf
Signed-off-by: William A. Kennington III <wak@google.com>
diff --git a/src/network_manager.cpp b/src/network_manager.cpp
index f69cd74..beb677a 100644
--- a/src/network_manager.cpp
+++ b/src/network_manager.cpp
@@ -177,9 +177,14 @@
#endif
-void Manager::reloadConfigs()
+void Manager::reloadConfigsNoRefresh()
{
reloadTimer->restartOnce(reloadTimeout);
+}
+
+void Manager::reloadConfigs()
+{
+ reloadConfigsNoRefresh();
// Ensure that the next refresh happens after reconfiguration
refreshObjectTimer->setRemaining(reloadTimeout + refreshTimeout);
}
@@ -212,7 +217,10 @@
elog<InternalFailure>();
}
// Ensure reconfiguration has enough time
- refreshObjectTimer->setRemaining(refreshTimeout);
+ if (refreshObjectTimer->isEnabled())
+ {
+ refreshObjectTimer->setRemaining(refreshTimeout);
+ }
}
} // namespace network
diff --git a/src/network_manager.hpp b/src/network_manager.hpp
index 0f37134..f265439 100644
--- a/src/network_manager.hpp
+++ b/src/network_manager.hpp
@@ -118,6 +118,7 @@
/** @brief Arms a timer to tell systemd-network to reload all of the network
* configurations
*/
+ virtual void reloadConfigsNoRefresh();
virtual void reloadConfigs();
/** @brief Tell systemd-network to reload all of the network configurations
diff --git a/test/mock_network_manager.hpp b/test/mock_network_manager.hpp
index 637ce69..fd344bf 100644
--- a/test/mock_network_manager.hpp
+++ b/test/mock_network_manager.hpp
@@ -41,6 +41,7 @@
}
MOCK_METHOD(void, reloadConfigs, (), (override));
+ MOCK_METHOD(void, reloadConfigsNoRefresh, (), (override));
};
} // namespace network