summaryrefslogtreecommitdiff
path: root/server/BandwidthControllerTest.cpp
diff options
context:
space:
mode:
authorLorenzo Colitti <lorenzo@google.com>2016-03-27 17:46:30 +0900
committerLorenzo Colitti <lorenzo@google.com>2016-03-28 13:48:40 +0900
commit13debb8996ca9cd3ce5d7f2817fe19e5df148f08 (patch)
tree8b22104985ca77783ca26bab92d0260f74261ba1 /server/BandwidthControllerTest.cpp
parenta0dc8a54c3d1a805294c5608dbeb78292014d2a5 (diff)
Use iptables-restore in BandwidthController startup.
This saves approximately 800ms on boot. From the perspective of the rules, this change is a no-op. As the unit test shows, the commands are the same, though some are in a slightly different order because iptables-restore requires that COMMIT be called between different tables (e.g., filter and mangle). For simplicity, enableBandwidthControl runs two iptables-restore commands instead of one. This is not semantically different from the previous code because the previous code just ran iptables commands one by one, which provides no atomicity. Running two commands is a bit slower than running one, but it's still much faster than using iptables. Using iptables-restore allows us to do things like ":<chain> -", which both creates the chain (if it does not already exist) and flushes it. This allows us to remove IPT_CLEANUP_COMMANDS and IPT_SETUP_COMMANDS. Those two sets of commands, which basically just did "-X bw_<foo>" and "-N bw_<foo>" were only necessary because the preceding "-F bw_<foo>" command would not create bw_<foo> if it did not already exist (e.g. in setupIptablesHooks, which runs on netd startup). Bug: 21725996 Change-Id: I6656aed4287dfcb2311c94800f430c143fb0b1a5
Diffstat (limited to 'server/BandwidthControllerTest.cpp')
-rw-r--r--server/BandwidthControllerTest.cpp136
1 files changed, 84 insertions, 52 deletions
diff --git a/server/BandwidthControllerTest.cpp b/server/BandwidthControllerTest.cpp
index 6d261edd..ff9738e7 100644
--- a/server/BandwidthControllerTest.cpp
+++ b/server/BandwidthControllerTest.cpp
@@ -22,9 +22,12 @@
#include <gtest/gtest.h>
+#include <android-base/strings.h>
+
#include "BandwidthController.h"
std::vector<std::string> gCmds = {};
+std::vector<std::string> gRestoreCmds = {};
int fake_android_fork_exec(int argc, char* argv[], int *status, bool, bool) {
std::string cmd = argv[0];
@@ -41,6 +44,12 @@ FILE *fake_popen(const char *, const char *) {
return NULL;
};
+int fakeExecIptablesRestore(IptablesTarget target, const std::string& commands) {
+ EXPECT_EQ(V4V6, target);
+ gRestoreCmds.push_back(commands);
+ return 0;
+}
+
void expectIptablesCommands(std::vector<std::string> expectedCmds) {
EXPECT_EQ(expectedCmds.size() * 2, gCmds.size());
if (expectedCmds.size() * 2 != gCmds.size()) return;
@@ -53,80 +62,103 @@ void expectIptablesCommands(std::vector<std::string> expectedCmds) {
gCmds.clear();
}
+void expectIptablesRestoreCommands(std::vector<std::string> expectedCmds) {
+ EXPECT_EQ(expectedCmds.size(), gRestoreCmds.size());
+ EXPECT_EQ(expectedCmds, gRestoreCmds);
+ gRestoreCmds.clear();
+}
+
class BandwidthControllerTest : public ::testing::Test {
public:
BandwidthControllerTest() {
BandwidthController::execFunction = fake_android_fork_exec;
BandwidthController::popenFunction = fake_popen;
+ BandwidthController::iptablesRestoreFunction = fakeExecIptablesRestore;
gCmds.clear();
+ gRestoreCmds.clear();
}
BandwidthController mBw;
};
-
TEST_F(BandwidthControllerTest, TestSetupIptablesHooks) {
mBw.setupIptablesHooks();
std::vector<std::string> expected = {
- "-F bw_INPUT",
- "-F bw_OUTPUT",
- "-F bw_FORWARD",
- "-F bw_happy_box",
- "-F bw_penalty_box",
- "-F bw_data_saver",
- "-F bw_costly_shared",
- "-t raw -F bw_raw_PREROUTING",
- "-t mangle -F bw_mangle_POSTROUTING",
- "-X bw_happy_box",
- "-X bw_penalty_box",
- "-X bw_data_saver",
- "-X bw_costly_shared",
- "-N bw_happy_box",
- "-N bw_penalty_box",
- "-N bw_data_saver",
- "-N bw_costly_shared",
+ "*filter\n"
+ ":bw_INPUT -\n"
+ ":bw_OUTPUT -\n"
+ ":bw_FORWARD -\n"
+ ":bw_happy_box -\n"
+ ":bw_penalty_box -\n"
+ ":bw_data_saver -\n"
+ ":bw_costly_shared -\n"
+ "COMMIT\n"
+ "*raw\n"
+ ":bw_raw_PREROUTING -\n"
+ "COMMIT\n"
+ "*mangle\n"
+ ":bw_mangle_POSTROUTING -\n"
+ "COMMIT\n\x04"
};
- expectIptablesCommands(expected);
+ expectIptablesRestoreCommands(expected);
}
TEST_F(BandwidthControllerTest, TestEnableBandwidthControl) {
mBw.enableBandwidthControl(false);
- std::vector<std::string> expected = {
- "-F bw_INPUT",
- "-F bw_OUTPUT",
- "-F bw_FORWARD",
- "-F bw_happy_box",
- "-F bw_penalty_box",
- "-F bw_data_saver",
- "-F bw_costly_shared",
- "-t raw -F bw_raw_PREROUTING",
- "-t mangle -F bw_mangle_POSTROUTING",
- "-A bw_INPUT -m owner --socket-exists",
- "-A bw_OUTPUT -m owner --socket-exists",
- "-t raw -A bw_raw_PREROUTING -m owner --socket-exists",
- "-t mangle -A bw_mangle_POSTROUTING -m owner --socket-exists",
- "-A bw_costly_shared --jump bw_penalty_box",
- "-A bw_penalty_box --jump bw_happy_box",
- "-A bw_happy_box --jump bw_data_saver",
- "-A bw_data_saver -j RETURN",
- "-I bw_happy_box -m owner --uid-owner 0-9999 --jump RETURN",
- };
- expectIptablesCommands(expected);
+ std::string expectedFlush =
+ "*filter\n"
+ ":bw_INPUT -\n"
+ ":bw_OUTPUT -\n"
+ ":bw_FORWARD -\n"
+ ":bw_happy_box -\n"
+ ":bw_penalty_box -\n"
+ ":bw_data_saver -\n"
+ ":bw_costly_shared -\n"
+ "COMMIT\n"
+ "*raw\n"
+ ":bw_raw_PREROUTING -\n"
+ "COMMIT\n"
+ "*mangle\n"
+ ":bw_mangle_POSTROUTING -\n"
+ "COMMIT\n\x04";
+ std::string expectedAccounting =
+ "*filter\n"
+ "-A bw_INPUT -m owner --socket-exists\n"
+ "-A bw_OUTPUT -m owner --socket-exists\n"
+ "-A bw_costly_shared --jump bw_penalty_box\n"
+ "-A bw_penalty_box --jump bw_happy_box\n"
+ "-A bw_happy_box --jump bw_data_saver\n"
+ "-A bw_data_saver -j RETURN\n"
+ "-I bw_happy_box -m owner --uid-owner 0-9999 --jump RETURN\n"
+ "COMMIT\n"
+ "*raw\n"
+ "-A bw_raw_PREROUTING -m owner --socket-exists\n"
+ "COMMIT\n"
+ "*mangle\n"
+ "-A bw_mangle_POSTROUTING -m owner --socket-exists\n"
+ "COMMIT\n\x04";
+
+ expectIptablesRestoreCommands({ expectedFlush, expectedAccounting });
}
TEST_F(BandwidthControllerTest, TestDisableBandwidthControl) {
mBw.disableBandwidthControl();
- std::vector<std::string> expected = {
- "-F bw_INPUT",
- "-F bw_OUTPUT",
- "-F bw_FORWARD",
- "-F bw_happy_box",
- "-F bw_penalty_box",
- "-F bw_data_saver",
- "-F bw_costly_shared",
- "-t raw -F bw_raw_PREROUTING",
- "-t mangle -F bw_mangle_POSTROUTING",
- };
- expectIptablesCommands(expected);
+ const std::string expected =
+ "*filter\n"
+ ":bw_INPUT -\n"
+ ":bw_OUTPUT -\n"
+ ":bw_FORWARD -\n"
+ ":bw_happy_box -\n"
+ ":bw_penalty_box -\n"
+ ":bw_data_saver -\n"
+ ":bw_costly_shared -\n"
+ "COMMIT\n"
+ "*raw\n"
+ ":bw_raw_PREROUTING -\n"
+ "COMMIT\n"
+ "*mangle\n"
+ ":bw_mangle_POSTROUTING -\n"
+ "COMMIT\n\x04";
+ expectIptablesRestoreCommands({ expected });
}
TEST_F(BandwidthControllerTest, TestEnableDataSaver) {