platform_bionic/tests/netinet_in_test.cpp
Elliott Hughes 64f355ffbd Use in_addr in ip_mreq_source and ip_msfilter.
This adds a new mechanism to say "replace struct S with #include <bits/S.h>".

Also switch epoll_event over to the new mechanism.

Also use the kernel's struct sockaddr_storage directly rather than behind
an unnecessary #define.

This patch also removes some dead code in the header scrubber. This code
still needs rewriting completely. I learned that a "block" isn't necessarily
a single struct definition, say; it might be a run of them. It seems like
a block is a run of preprocessor directives or a run of regular code.

Bug: https://issuetracker.google.com/36987220
Test: new test
Change-Id: Ic6a5c09559766a4babe3cd4c3ea538b885e07308
2017-12-14 10:07:27 -08:00

86 lines
2.2 KiB
C++

/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <netinet/in.h>
#include <errno.h>
#include <gtest/gtest.h>
#include <android-base/macros.h>
static constexpr uint16_t le16 = 0x1234;
static constexpr uint32_t le32 = 0x12345678;
static constexpr uint64_t le64 = 0x123456789abcdef0;
static constexpr uint16_t be16 = 0x3412;
static constexpr uint32_t be32 = 0x78563412;
static constexpr uint64_t be64 = 0xf0debc9a78563412;
TEST(netinet_in, bindresvport) {
// This isn't something we can usually test, so just check the symbol's there.
ASSERT_EQ(-1, bindresvport(-1, nullptr));
}
TEST(netinet_in, in6addr_any) {
in6_addr any = IN6ADDR_ANY_INIT;
ASSERT_EQ(0, memcmp(&any, &in6addr_any, sizeof(in6addr_any)));
}
TEST(netinet_in, in6addr_loopback) {
in6_addr loopback = IN6ADDR_LOOPBACK_INIT;
ASSERT_EQ(0, memcmp(&loopback, &in6addr_loopback, sizeof(in6addr_loopback)));
}
TEST(netinet_in, htons_function) {
ASSERT_EQ(be16, (htons)(le16));
}
TEST(netinet_in, htonl_function) {
ASSERT_EQ(be32, (htonl)(le32));
}
TEST(netinet_in, htonq_macro) {
#if defined(__BIONIC__)
ASSERT_EQ(be64, htonq(le64));
#else
UNUSED(be64);
#endif
}
TEST(netinet_in, ntohs_function) {
ASSERT_EQ(le16, (ntohs)(be16));
}
TEST(netinet_in, ntohl_function) {
ASSERT_EQ(le32, (ntohl)(be32));
}
TEST(netinet_in, ntohq_macro) {
#if defined(__BIONIC__)
ASSERT_EQ(le64, ntohq(be64));
#else
UNUSED(le64);
#endif
}
TEST(netinet_in, ip_mreq_source_fields) {
// https://issuetracker.google.com/36987220
ip_mreq_source mreq;
mreq.imr_interface.s_addr = htonl(INADDR_ANY);
mreq.imr_multiaddr.s_addr = htonl(INADDR_ANY);
mreq.imr_sourceaddr.s_addr = htonl(INADDR_ANY);
}