Skip to content
Snippets Groups Projects
Commit 336f3c10 authored by Yang Sun's avatar Yang Sun Committed by Gerrit Code Review
Browse files

Merge changes I395560fb,If6abc33c into main

* changes:
  Add support for NLM_F_DUMP request in StructNLMsgHdr
  Mark NetworkStaticLibTestsLib as test for lint
parents d0535553 9ea3be13
No related branches found
No related tags found
No related merge requests found
...@@ -142,6 +142,7 @@ public class NetlinkMessage { ...@@ -142,6 +142,7 @@ public class NetlinkMessage {
return (NetlinkMessage) RtNetlinkAddressMessage.parse(nlmsghdr, byteBuffer); return (NetlinkMessage) RtNetlinkAddressMessage.parse(nlmsghdr, byteBuffer);
case NetlinkConstants.RTM_NEWROUTE: case NetlinkConstants.RTM_NEWROUTE:
case NetlinkConstants.RTM_DELROUTE: case NetlinkConstants.RTM_DELROUTE:
case NetlinkConstants.RTM_GETROUTE:
return (NetlinkMessage) RtNetlinkRouteMessage.parse(nlmsghdr, byteBuffer); return (NetlinkMessage) RtNetlinkRouteMessage.parse(nlmsghdr, byteBuffer);
case NetlinkConstants.RTM_NEWNEIGH: case NetlinkConstants.RTM_NEWNEIGH:
case NetlinkConstants.RTM_DELNEIGH: case NetlinkConstants.RTM_DELNEIGH:
......
...@@ -71,13 +71,17 @@ public class StructNlMsgHdr { ...@@ -71,13 +71,17 @@ public class StructNlMsgHdr {
} }
sb.append("NLM_F_ECHO"); sb.append("NLM_F_ECHO");
} }
if ((flags & NLM_F_ROOT) != 0) { if ((flags & NLM_F_DUMP) == NLM_F_DUMP) {
if (sb.length() > 0) {
sb.append("|");
}
sb.append("NLM_F_DUMP");
} else if ((flags & NLM_F_ROOT) != 0) { // NLM_F_DUMP = NLM_F_ROOT | NLM_F_MATCH
if (sb.length() > 0) { if (sb.length() > 0) {
sb.append("|"); sb.append("|");
} }
sb.append("NLM_F_ROOT"); sb.append("NLM_F_ROOT");
} } else if ((flags & NLM_F_MATCH) != 0) {
if ((flags & NLM_F_MATCH) != 0) {
if (sb.length() > 0) { if (sb.length() > 0) {
sb.append("|"); sb.append("|");
} }
......
...@@ -33,7 +33,10 @@ android_library { ...@@ -33,7 +33,10 @@ android_library {
"//packages/modules/Connectivity/Tethering/tests:__subpackages__", "//packages/modules/Connectivity/Tethering/tests:__subpackages__",
"//packages/modules/NetworkStack/tests/integration", "//packages/modules/NetworkStack/tests/integration",
], ],
lint: { strict_updatability_linting: true }, lint: {
strict_updatability_linting: true,
test: true
},
} }
android_test { android_test {
......
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
package com.android.net.module.util.netlink; package com.android.net.module.util.netlink;
import static com.android.net.module.util.netlink.StructNlMsgHdr.NLM_F_DUMP;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import android.system.OsConstants; import android.system.OsConstants;
...@@ -48,10 +49,14 @@ public class StructNlMsgHdrTest { ...@@ -48,10 +49,14 @@ public class StructNlMsgHdrTest {
public static final String TEST_NLMSG_PID_STR = "nlmsg_pid{5678}"; public static final String TEST_NLMSG_PID_STR = "nlmsg_pid{5678}";
private StructNlMsgHdr makeStructNlMsgHdr(short type) { private StructNlMsgHdr makeStructNlMsgHdr(short type) {
return makeStructNlMsgHdr(type, TEST_NLMSG_FLAGS);
}
private StructNlMsgHdr makeStructNlMsgHdr(short type, short flags) {
final StructNlMsgHdr struct = new StructNlMsgHdr(); final StructNlMsgHdr struct = new StructNlMsgHdr();
struct.nlmsg_len = TEST_NLMSG_LEN; struct.nlmsg_len = TEST_NLMSG_LEN;
struct.nlmsg_type = type; struct.nlmsg_type = type;
struct.nlmsg_flags = TEST_NLMSG_FLAGS; struct.nlmsg_flags = flags;
struct.nlmsg_seq = TEST_NLMSG_SEQ; struct.nlmsg_seq = TEST_NLMSG_SEQ;
struct.nlmsg_pid = TEST_NLMSG_PID; struct.nlmsg_pid = TEST_NLMSG_PID;
return struct; return struct;
...@@ -62,6 +67,11 @@ public class StructNlMsgHdrTest { ...@@ -62,6 +67,11 @@ public class StructNlMsgHdrTest {
fail("\"" + actualValue + "\" does not contain \"" + expectedSubstring + "\""); fail("\"" + actualValue + "\" does not contain \"" + expectedSubstring + "\"");
} }
private static void assertNotContains(String actualValue, String unexpectedSubstring) {
if (!actualValue.contains(unexpectedSubstring)) return;
fail("\"" + actualValue + "\" contains \"" + unexpectedSubstring + "\"");
}
@Test @Test
public void testToString() { public void testToString() {
StructNlMsgHdr struct = makeStructNlMsgHdr(NetlinkConstants.RTM_NEWADDR); StructNlMsgHdr struct = makeStructNlMsgHdr(NetlinkConstants.RTM_NEWADDR);
...@@ -99,4 +109,31 @@ public class StructNlMsgHdrTest { ...@@ -99,4 +109,31 @@ public class StructNlMsgHdrTest {
assertContains(s, TEST_NLMSG_PID_STR); assertContains(s, TEST_NLMSG_PID_STR);
assertContains(s, "nlmsg_type{20(SOCK_DIAG_BY_FAMILY)}"); assertContains(s, "nlmsg_type{20(SOCK_DIAG_BY_FAMILY)}");
} }
@Test
public void testToString_flags_dumpRequest() {
final short flags = StructNlMsgHdr.NLM_F_REQUEST | StructNlMsgHdr.NLM_F_DUMP;
StructNlMsgHdr struct = makeStructNlMsgHdr(NetlinkConstants.RTM_GETROUTE, flags);
String s = struct.toString(OsConstants.NETLINK_ROUTE);
assertContains(s, "RTM_GETROUTE");
assertContains(s, "NLM_F_REQUEST");
assertContains(s, "NLM_F_DUMP");
// NLM_F_DUMP = NLM_F_ROOT | NLM_F_MATCH;
assertNotContains(s, "NLM_F_MATCH");
assertNotContains(s, "NLM_F_ROOT");
}
@Test
public void testToString_flags_root() {
final short flags = StructNlMsgHdr.NLM_F_ROOT;
StructNlMsgHdr struct = makeStructNlMsgHdr(NetlinkConstants.RTM_GETROUTE, flags);
String s = struct.toString(OsConstants.NETLINK_ROUTE);
assertContains(s, "NLM_F_ROOT");
// NLM_F_DUMP = NLM_F_ROOT | NLM_F_MATCH;
assertNotContains(s, "NLM_F_DUMP");
}
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment