11e268105SWilliam A. Kennington III#!/bin/bash
21e268105SWilliam A. Kennington III# Copyright 2021 Google LLC
31e268105SWilliam A. Kennington III#
41e268105SWilliam A. Kennington III# Licensed under the Apache License, Version 2.0 (the "License");
51e268105SWilliam A. Kennington III# you may not use this file except in compliance with the License.
61e268105SWilliam A. Kennington III# You may obtain a copy of the License at
71e268105SWilliam A. Kennington III#
81e268105SWilliam A. Kennington III#      http://www.apache.org/licenses/LICENSE-2.0
91e268105SWilliam A. Kennington III#
101e268105SWilliam A. Kennington III# Unless required by applicable law or agreed to in writing, software
111e268105SWilliam A. Kennington III# distributed under the License is distributed on an "AS IS" BASIS,
121e268105SWilliam A. Kennington III# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
131e268105SWilliam A. Kennington III# See the License for the specific language governing permissions and
141e268105SWilliam A. Kennington III# limitations under the License.
151e268105SWilliam A. Kennington III
161e268105SWilliam A. Kennington IIIcd "$(dirname "$0")"
171e268105SWilliam A. Kennington IIIif [ -e ../network-sh.bb ]; then
181e268105SWilliam A. Kennington III  source '../../test/test-sh/lib.sh'
191e268105SWilliam A. Kennington IIIelse
201e268105SWilliam A. Kennington III  source "$SYSROOT/usr/share/test/lib.sh"
211e268105SWilliam A. Kennington IIIfi
221e268105SWilliam A. Kennington IIIsource lib.sh
231e268105SWilliam A. Kennington III
2470264b98SWilliam A. Kennington IIIexpect_array_numeq() {
2570264b98SWilliam A. Kennington III  local -n a1="$1"
2670264b98SWilliam A. Kennington III  local -n a2="$2"
2770264b98SWilliam A. Kennington III
2870264b98SWilliam A. Kennington III  if (( "${#a1[@]}" != "${#a2[@]}" )); then
2970264b98SWilliam A. Kennington III    echo "  Line ${BASH_LINENO[0]} Array Size ${#a1[@]} != ${#a2[@]}" >&2
3070264b98SWilliam A. Kennington III    test_err=1
3170264b98SWilliam A. Kennington III  else
3270264b98SWilliam A. Kennington III    local i
3370264b98SWilliam A. Kennington III    for (( i=0; i < ${#a1[@]}; ++i )); do
3470264b98SWilliam A. Kennington III      expect_numeq "${a1[$i]}" "${a2[$i]}"
3570264b98SWilliam A. Kennington III    done
3670264b98SWilliam A. Kennington III  fi
3770264b98SWilliam A. Kennington III}
3870264b98SWilliam A. Kennington III
391e268105SWilliam A. Kennington IIItest_mac_to_bytes() {
401e268105SWilliam A. Kennington III  out=()
411e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out ''
421e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out '00'
431e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out '12:34:56:78:90:'
441e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out ':12:34:56:78:90'
451e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out '12:34:56:78:90:0:'
461e268105SWilliam A. Kennington III  expect_err 1 mac_to_bytes out '12:34:56:78:90:0:2'
471e268105SWilliam A. Kennington III
481e268105SWilliam A. Kennington III  expect_err 0 mac_to_bytes out 'a2:0:f:de:0:29'
491e268105SWilliam A. Kennington III  expected=(0xa2 0 0xf 0xde 0 0x29)
5070264b98SWilliam A. Kennington III  expect_array_numeq out expected
511e268105SWilliam A. Kennington III}
521e268105SWilliam A. Kennington III
536ca70339SWilliam A. Kennington IIItest_mac_to_eui48() {
541e268105SWilliam A. Kennington III  str="$(mac_to_eui48 '12:34:56:78:90:af')" || fail
556ca70339SWilliam A. Kennington III  expect_streq "$str" '::1234:5678:90af'
561e268105SWilliam A. Kennington III}
571e268105SWilliam A. Kennington III
586ca70339SWilliam A. Kennington IIItest_mac_to_eui64() {
591e268105SWilliam A. Kennington III  str="$(mac_to_eui64 '12:34:56:78:90:af')" || fail
60*fc8c436cSWilliam A. Kennington III  expect_streq "$str" '::1034:56ff:fe78:90af'
611e268105SWilliam A. Kennington III}
621e268105SWilliam A. Kennington III
6370264b98SWilliam A. Kennington IIItest_ip4_to_bytes() {
6470264b98SWilliam A. Kennington III  out=()
6570264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out ''
6670264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0.'
6770264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '.0.1.1'
6870264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0'
6970264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0..0'
7070264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '.10.0.0.0'
7170264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0.0.'
7270264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0.256'
7370264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0.0.256'
7470264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '10.0.0.0.1'
7570264b98SWilliam A. Kennington III
7670264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out '10.0.0.1'
7770264b98SWilliam A. Kennington III  expected=(10 0 0 1)
7870264b98SWilliam A. Kennington III  expect_array_numeq out expected
7970264b98SWilliam A. Kennington III}
8070264b98SWilliam A. Kennington III
8170264b98SWilliam A. Kennington IIItest_ip6_to_bytes() {
8270264b98SWilliam A. Kennington III  out=()
8370264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out ''
8470264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out ':::'
8570264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '::z'
8670264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '1::1::1'
8770264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '1:1:1'
8870264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out ':1::1'
8970264b98SWilliam A. Kennington III  expect_err 1 ip_to_bytes out '1::1:'
9070264b98SWilliam A. Kennington III
9170264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out '::'
9270264b98SWilliam A. Kennington III  expected=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
9370264b98SWilliam A. Kennington III  expect_array_numeq out expected
9470264b98SWilliam A. Kennington III  out=()
9570264b98SWilliam A. Kennington III
9670264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out '::1'
9770264b98SWilliam A. Kennington III  expected=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1)
9870264b98SWilliam A. Kennington III  expect_array_numeq out expected
9970264b98SWilliam A. Kennington III  out=()
10070264b98SWilliam A. Kennington III
10170264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out 'fd00::'
10270264b98SWilliam A. Kennington III  expected=(0xfd 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
10370264b98SWilliam A. Kennington III  expect_array_numeq out expected
10470264b98SWilliam A. Kennington III  out=()
10570264b98SWilliam A. Kennington III
10670264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out 'fd00:ffee::ddff:22'
10770264b98SWilliam A. Kennington III  expected=(0xfd 0 0xff 0xee 0 0 0 0 0 0 0 0 0xdd 0xff 0 0x22)
10870264b98SWilliam A. Kennington III  expect_array_numeq out expected
10970264b98SWilliam A. Kennington III  out=()
11070264b98SWilliam A. Kennington III
11170264b98SWilliam A. Kennington III  expect_err 0 ip_to_bytes out '1:2:3:4:5:6:7:8'
11270264b98SWilliam A. Kennington III  expected=(0 1 0 2 0 3 0 4 0 5 0 6 0 7 0 8)
11370264b98SWilliam A. Kennington III  expect_array_numeq out expected
11470264b98SWilliam A. Kennington III  out=()
11570264b98SWilliam A. Kennington III}
11670264b98SWilliam A. Kennington III
11780776788SWilliam A. Kennington IIItest_ip4_bytes_str() {
11880776788SWilliam A. Kennington III  in=(10 0 255 1)
11980776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
12080776788SWilliam A. Kennington III  expect_streq "$str" '10.0.255.1'
12180776788SWilliam A. Kennington III}
12280776788SWilliam A. Kennington III
12380776788SWilliam A. Kennington IIItest_ip6_bytes_str() {
12480776788SWilliam A. Kennington III  in=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
12580776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
12680776788SWilliam A. Kennington III  expect_streq "$str" '::'
12780776788SWilliam A. Kennington III  in=(0xfd 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0)
12880776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
12980776788SWilliam A. Kennington III  expect_streq "$str" 'fd00::'
13080776788SWilliam A. Kennington III  in=(0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0xfd)
13180776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
13280776788SWilliam A. Kennington III  expect_streq "$str" '::fd'
13380776788SWilliam A. Kennington III  in=(0xfd 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1)
13480776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
13580776788SWilliam A. Kennington III  expect_streq "$str" 'fd01::1'
13680776788SWilliam A. Kennington III  in=(0xfd 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1)
13780776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
13880776788SWilliam A. Kennington III  expect_streq "$str" 'fd01::1:0:0:1'
13980776788SWilliam A. Kennington III  in=(0xfd 1 0 0 0 0 0 1 0 1 0 0 0 0 0 1)
14080776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
14180776788SWilliam A. Kennington III  expect_streq "$str" 'fd01:0:0:1:1::1'
14280776788SWilliam A. Kennington III  in=(0 1 0 1 0xdd 0xdd 0 1 0 1 0 1 0 1 0 1)
14380776788SWilliam A. Kennington III  str="$(ip_bytes_to_str in)" || fail
14480776788SWilliam A. Kennington III  expect_streq "$str" '1:1:dddd:1:1:1:1:1'
14580776788SWilliam A. Kennington III}
14680776788SWilliam A. Kennington III
1476ca70339SWilliam A. Kennington IIItest_ip_pfx_concat() {
1481e268105SWilliam A. Kennington III  # Invalid inputs
1496ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd/64' '::1234:5678:90af'
1506ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::' '::1234:5678:90af'
1516ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01:' '::1234:5678:90af'
1526ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/a0' '::1234:5678:90af'
1536ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/64' ':1234:5678:90af'
1546ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/64' ''
1556ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/129' '::1'
1561e268105SWilliam A. Kennington III
1571e268105SWilliam A. Kennington III  # Too many address bits
1586ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01:1:1:1:1::/64' '::1234:5678:90af'
1596ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/64' '::1:0:1234:5678:90af'
1606ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/79' '::3:1234:5678:90af'
1616ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat 'fd01::/15' '::3:1234:5678:90af'
1626ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_concat '10.0.0.1/31' '0.0.0.0'
1631e268105SWilliam A. Kennington III
1646ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat '::1/128' '::0')" || fail
1656ca70339SWilliam A. Kennington III  expect_streq "$str" '::1/128'
1666ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd01::/64' '::1')" || fail
1671e268105SWilliam A. Kennington III  expect_streq "$str" 'fd01::1/64'
1686ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd01::/127' '::1')" || fail
1696ca70339SWilliam A. Kennington III  expect_streq "$str" 'fd01::1/127'
1706ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd02::/15' '::1')" || fail
1716ca70339SWilliam A. Kennington III  expect_streq "$str" 'fd02::1/15'
1726ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd01::/72' '::1234:5678:90af')" || fail
1731e268105SWilliam A. Kennington III  expect_streq "$str" 'fd01::1234:5678:90af/72'
1746ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd01:eeee:aaaa:cccc::/64' '::a:1234:5678:90af')" || fail
1751e268105SWilliam A. Kennington III  expect_streq "$str" 'fd01:eeee:aaaa:cccc:a:1234:5678:90af/64'
1766ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat 'fd01::fd00:0:0:0/80' '::1')" || fail
1776ca70339SWilliam A. Kennington III  expect_streq "$str" 'fd01::fd00:0:0:1/80'
1786ca70339SWilliam A. Kennington III
1796ca70339SWilliam A. Kennington III  str="$(ip_pfx_concat '10.0.0.0/24' '0.0.0.1')" || fail
1806ca70339SWilliam A. Kennington III  expect_streq "$str" '10.0.0.1/24'
1811e268105SWilliam A. Kennington III}
1821e268105SWilliam A. Kennington III
1836ca70339SWilliam A. Kennington IIItest_ip_pfx_to_cidr() {
1846ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_to_cidr 'z/64'
1856ca70339SWilliam A. Kennington III  expect_err 1 ip_pfx_to_cidr '64'
1861e268105SWilliam A. Kennington III
1876ca70339SWilliam A. Kennington III  cidr="$(ip_pfx_to_cidr 'fd01::/64')" || fail
1881e268105SWilliam A. Kennington III  expect_numeq "$cidr" 64
1896ca70339SWilliam A. Kennington III  cidr="$(ip_pfx_to_cidr 'fd01:eeee:aaaa:cccc:a:1234:5678:90af/128')" || fail
1901e268105SWilliam A. Kennington III  expect_numeq "$cidr" 128
1916ca70339SWilliam A. Kennington III  cidr="$(ip_pfx_to_cidr '10.0.0.1/24')" || fail
1926ca70339SWilliam A. Kennington III  expect_numeq "$cidr" 24
1936ca70339SWilliam A. Kennington III}
1946ca70339SWilliam A. Kennington III
1956ca70339SWilliam A. Kennington IIItest_normalize_ip() {
1966ca70339SWilliam A. Kennington III  ip="$(normalize_ip 'fd01:1::0:0:1')" || fail
1976ca70339SWilliam A. Kennington III  expect_streq "$ip" 'fd01:1::1'
1981e268105SWilliam A. Kennington III}
1991e268105SWilliam A. Kennington III
2001e268105SWilliam A. Kennington IIIreturn 0 2>/dev/null
2011e268105SWilliam A. Kennington IIImain
202