10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#!/usr/bin/ksh
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER START
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# The contents of this file are subject to the terms of the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# Common Development and Distribution License (the "License").
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# You may not use this file except in compliance with the License.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# or http://www.opensolaris.org/os/licensing.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# See the License for the specific language governing permissions
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# and limitations under the License.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# When distributing Covered Code, include this CDDL HEADER in each
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# If applicable, add the following below this CDDL HEADER, with the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# fields enclosed by brackets "[]" replaced with your own identifying
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# information: Portions Copyright [yyyy] [name of copyright owner]
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# CDDL HEADER END
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# Test {tcp,ip}:::{send,receive} of IPv4 TCP to a remote host.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This may fail due to:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 1. A change to the ip stack breaking expected probe behavior,
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# which is the reason we are testing.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 2. No physical network interface is plumbed and up.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 3. No other hosts on this subnet are reachable and listening on ssh.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 4. An unlikely race causes the unlocked global send/receive
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# variables to be corrupted.
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# This test performs a TCP connection and checks that at least the
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# following packet counts were traced:
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 3 x ip:::send (2 during the TCP handshake, then a FIN)
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# 3 x tcp:::send (2 during the TCP handshake, then a FIN)
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan# 2 x ip:::receive (1 during the TCP handshake, then the FIN ACK)
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire# 2 x tcp:::receive (1 during the TCP handshake, then the FIN ACK)
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan#
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif (( $# != 1 )); then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan print -u2 "expected one argument: <dtrace-path>"
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 2
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendandtrace=$1
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendangetaddr=./get.ipv4remote.pl
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendantcpport=22
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanDIR=/var/tmp/dtest.$$
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif [[ ! -x $getaddr ]]; then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan print -u2 "could not find or execute sub program: $getaddr"
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 3
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan$getaddr $tcpport | read source dest
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanif (( $? != 0 )); then
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan exit 4
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanfi
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanmkdir $DIR
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendancd $DIR
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendancat > test.pl <<-EOPERL
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan use IO::Socket;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan my \$s = IO::Socket::INET->new(
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan Proto => "tcp",
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan PeerAddr => "$dest",
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan PeerPort => $tcpport,
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan Timeout => 3);
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan die "Could not connect to host $dest port $tcpport" unless \$s;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan close \$s;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanEOPERL
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
c090e5dfb10cc96e71e6b0f55bf98c18027b002cBryan Cantrill$dtrace -c 'perl test.pl' -qs /dev/stdin <<EODTRACE
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanBEGIN
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipsend = tcpsend = ipreceive = tcpreceive = 0;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanip:::send
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/args[2]->ip_saddr == "$source" && args[2]->ip_daddr == "$dest" &&
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan args[4]->ipv4_protocol == IPPROTO_TCP/
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipsend++;
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire}
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguiretcp:::send
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire/args[2]->ip_saddr == "$source" && args[2]->ip_daddr == "$dest"/
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire tcpsend++;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanip:::receive
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/args[2]->ip_saddr == "$dest" && args[2]->ip_daddr == "$source" &&
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan args[4]->ipv4_protocol == IPPROTO_TCP/
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire ipreceive++;
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire}
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguiretcp:::receive
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire/args[2]->ip_saddr == "$dest" && args[2]->ip_daddr == "$source"/
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire{
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire tcpreceive++;
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanEND
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan{
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan printf("Minimum TCP events seen\n\n");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("ip:::send - %s\n", ipsend >= 3 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("ip:::receive - %s\n", ipreceive >= 2 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("tcp:::send - %s\n", tcpsend >= 3 ? "yes" : "no");
9cd928fe5e3ea4e05f64cfb380beb54b2623e7dcAlan Maguire printf("tcp:::receive - %s\n", tcpreceive >= 2 ? "yes" : "no");
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan}
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanEODTRACE
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanstatus=$?
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendancd /
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan/usr/bin/rm -rf $DIR
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendan
10e6dadfe63181edabc58c8f42e3c56a1cd9ec95brendanexit $?